From 3e640b73a724c2d0e816178a64eb19790f12892d Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 3 Sep 2021 11:41:39 -0400 Subject: [PATCH 001/328] MMF groundwater parameter processing --- ldt/arch/Config.pl | 3 +- ldt/params/Noah/Noah_parmsMod.F90 | 504 +++++---------------- ldt/params/Noah/module_MMF_groundwater.F90 | 309 +++++++++++++ ldt/params/Noah/read_geogrid.c | 134 ++++++ ldt/params/Noah/write_geogrid.c | 122 +++++ 5 files changed, 676 insertions(+), 396 deletions(-) create mode 100644 ldt/params/Noah/module_MMF_groundwater.F90 create mode 100644 ldt/params/Noah/read_geogrid.c create mode 100644 ldt/params/Noah/write_geogrid.c diff --git a/ldt/arch/Config.pl b/ldt/arch/Config.pl index b7bf19c36..09f53bb8a 100755 --- a/ldt/arch/Config.pl +++ b/ldt/arch/Config.pl @@ -824,7 +824,8 @@ #printf misc_file "%s\n","#undef SPMD"; printf misc_file "%s\n","#define BILHEADER_FILE_READ_METHOD_1_"; printf misc_file "%s\n","#define BILREAD_ASSUME_BIG_ENDIAN_"; - +printf misc_file "%s\n","#define VERIFY_(A) IF(A/=0)THEN;PRINT *,'ERROR AT LINE ', __LINE__;STOP;ENDIF"; +printf misc_file "%s\n","#define ASSERT_(A) if(.not.A)then;print *,'Error:',__FILE__,__LINE__;stop;endif"; close(misc_file); open(netcdf_file,">LDT_NetCDF_inc.h"); diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 568258cd5..f72715392 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -25,14 +25,16 @@ module Noah_parmsMod ! !REVISION HISTORY: ! ! 08 Aug 2005: Sujay Kumar; Initial implementation -! 04 Aug 2012: K. Arsenault: Made updates to Tbot inputs -! +! 04 Aug 2012: K. Arsenault: Made updates to Tbot inputs +! 27 Aug 2021: Sarith Mahanama: MMF groundwater parameters were added. + use ESMF use LDT_coreMod use LDT_historyMod use LDT_paramDataMod use LDT_logMod use LDT_paramMaskCheckMod + use MMF_groundwater, ONLY : MMF_BCsReader implicit none @@ -63,40 +65,38 @@ module Noah_parmsMod character*50 :: tbot_proj character*50 :: slopetype_proj + character*140 :: mmf_fdepth_dir + character*140 :: mmf_rechclim_dir + character*140 :: mmf_riverbed_dir + character*140 :: mmf_eqwtd_dir + character*50 :: mmf_transform + real :: pblh_value ! - Noah LSM-specific: type(LDT_paramEntry) :: tbot ! Bottom temperature (Noah) type(LDT_paramEntry) :: slopetype ! Slope type index (Noah) type(LDT_paramEntry) :: pblh ! Planetary Boundary Layer Height (Noah-MP) - + type(LDT_paramEntry) :: fdepth + type(LDT_paramEntry) :: rechclim + type(LDT_paramEntry) :: riverbed + type(LDT_paramEntry) :: eqwtd + end type noah_type_dec type(noah_type_dec), allocatable :: Noah_struc(:) - - contains - subroutine NoahParms_init(flag) - - integer :: flag - - if(flag.eq.0) then - call NoahParms_init_LIS() - elseif(flag.eq.1) then - call NoahParms_init_LISHydro(flag) - endif - end subroutine NoahParms_init - !BOP ! -! !ROUTINE: NoahParms_init_LIS -! \label{NoahParms_init_LIS} +! !ROUTINE: NoahParms_init +! \label{NoahParms_init} ! ! !INTERFACE: - subroutine NoahParms_init_LIS -! !USES: + + subroutine NoahParms_init (flag) + ! !USES: use LDT_fileIOMod, only : LDT_readDomainConfigSpecs use LDT_logMod, only : LDT_verify use LDT_paramOptCheckMod, only: LDT_noahparmsOptChecks, & @@ -115,6 +115,7 @@ subroutine NoahParms_init_LIS ! !EOP implicit none + integer, intent (in) :: flag integer :: n,i,c,r,m integer :: rc real :: temp @@ -125,14 +126,25 @@ subroutine NoahParms_init_LIS real, allocatable :: force_elev(:,:) character*50 :: tbot_proj character*50 :: slopetype_proj + type(LDT_fillopts) :: MMF_fillopts + character*50 :: MMF_proj + type(MMF_BCsReader):: MBR ! _____________________________________________________________________ allocate( Noah_struc(LDT_rc%nnest) ) do n=1,LDT_rc%nnest - call set_param_attribs(Noah_struc(n)%tbot, "TBOT",& - units="K", & - full_name="Noah LSM bottom temperature") + + if(flag == 0) then + call set_param_attribs(Noah_struc(n)%tbot, "TBOT",& + units="K", & + full_name="Noah LSM bottom temperature") + elseif (flag == 1) then + call set_param_attribs(Noah_struc(n)%tbot, "SOILTEMP",& + units="K", & + full_name="Noah LSM bottom temperature") + endif + call set_param_attribs(Noah_struc(n)%slopetype,"SLOPETYPE",& units="-", & full_name="Noah LSM slope type") @@ -142,6 +154,20 @@ subroutine NoahParms_init_LIS call set_param_attribs(Noah_struc(n)%pblh,"NOAHMP36_PBLH",& units="m", & full_name="Noah-MP LSM planetary boundary height") + + call set_param_attribs(Noah_struc(n)%fdepth,"MMF_FDEPTH",& + units="m", & + full_name="transmissivity e-folding depth") + call set_param_attribs(Noah_struc(n)%rechclim,"MMF_RECHCLIM",& + units="mm", & + full_name="climatological recharge") + call set_param_attribs(Noah_struc(n)%riverbed,"MMF_RIVERBED",& + units="m", & + full_name="riverbed elevation") + call set_param_attribs(Noah_struc(n)%eqwtd,"MMF_EQWTD",& + units="m", & + full_name="equilibrium water table depth") + endif enddo @@ -454,382 +480,59 @@ subroutine NoahParms_init_LIS enddo endif - - end subroutine NoahParms_init_LIS - -!BOP -! -! !ROUTINE: NoahParms_init -! \label{NoahParms_init} -! -! !INTERFACE: - subroutine NoahParms_init_LISHydro(flag) -! !USES: - use LDT_fileIOMod, only : LDT_readDomainConfigSpecs - use LDT_logMod, only : LDT_verify - use LDT_paramOptCheckMod, only: LDT_noahparmsOptChecks, & - LDT_gridOptChecks,LDT_soilsOptChecks -! -! !DESCRIPTION: -! -! Allocates memory for data structures for reading -! the noahParms fraction datasets -! -! The routines invoked are: -! \begin{description} -! \item[noahParmssetup](\ref{noahParmssetup}) \newline -! calls the registry to invoke the noahParms setup methods. -! \end{description} -! -!EOP - implicit none - integer :: flag - integer :: n,i,c,r,m - integer :: rc - real :: temp - logical :: file_exists - logical :: check_data - type(LDT_fillopts) :: tbot - type(LDT_fillopts) :: slopetype - real, allocatable :: force_elev(:,:) - character*50 :: tbot_proj - character*50 :: slopetype_proj - - character*100 :: SOILTEMP - character*100 :: SLOPECAT -! _____________________________________________________________________ - - SOILTEMP = "TBOT" - SLOPECAT = "SLOPETYPE" - allocate( Noah_struc(LDT_rc%nnest) ) - do n=1,LDT_rc%nnest - call set_param_attribs(Noah_struc(n)%tbot, "SOILTEMP",& - units="K", & - full_name="Noah LSM bottom temperature") - call set_param_attribs(Noah_struc(n)%slopetype,"SLOPETYPE",& - units="-", & - full_name="Noah LSM slope type") - - if ((LDT_rc%lsm.eq."Noah-MP.3.6").or. & - (LDT_rc%lsm.eq."Noah-MP.4.0.1")) then - call set_param_attribs(Noah_struc(n)%pblh,"NOAHMP36_PBLH",& - units="m", & - full_name="Noah-MP LSM planetary boundary height") - endif - enddo - -! -- Slope type: -- - - check_data = .false. - - call ESMF_ConfigFindLabel(LDT_config,"Slope type data source:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%slopetype%source,rc=rc) - call LDT_verify(rc,"Slope type data source: not defined") - - if( Noah_struc(n)%slopetype%source.eq."none" ) then - Noah_struc(n)%slopetype%selectOpt = 0 - endif - if( Noah_struc(n)%slopetype%selectOpt.eq.1 ) then - check_data = .true. - allocate(Noah_struc(n)%slopetype%value(& - LDT_rc%lnc(n),LDT_rc%lnr(n),& - Noah_struc(n)%slopetype%num_bins)) - endif - enddo - - if(check_data) then - write(LDT_logunit,*)" - - - - - - - - - Slope Type Parameter - - - - - - - - - - - -" - - ! Read in slope type file config entries: - call ESMF_ConfigFindLabel(LDT_config,"Slope type map:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%slopetypefile,rc=rc) - enddo - call ESMF_ConfigGetAttribute(LDT_config,slopetype_proj,& - label="Slope type map projection:",rc=rc) - call LDT_verify(rc,'Slope type map projection: option not specified in the config file') - Noah_struc(:)%slopetype_proj = slopetype_proj - - call ESMF_ConfigFindLabel(LDT_config,"Slope type spatial transform:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%slopetype_gridtransform,& - rc=rc) - call LDT_verify(rc,'Slope type spatial tranform: option not specified in the config file') - enddo + !== MMF parameters + + check_data = .false. + + write(LDT_logunit,*)" - - - - - - - MMF Groundwater Parameters - - - - - - - - - -" + + do n = 1,LDT_rc%nnest - ! Read in Slope type "fill" options: - slopetype%filltype = "none" - call ESMF_ConfigGetAttribute(LDT_config, slopetype%filltype, & - label="Slope type fill option:",rc=rc) - call LDT_verify(rc,"Slope type fill option: option not specified in the config file") + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_fdepth_dir, label='MMF transmissivity dir:', rc=rc) + call LDT_verify(rc,"MMF Groundwater parameter directory not defined") + check_data = .true. + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_rechclim_dir, label='MMF climatological recharge dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_riverbed_dir, label='MMF riverbed elevation dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_eqwtd_dir , label='MMF equilibrium water table depth dir:', RC=RC) - if( slopetype%filltype == "neighbor" ) then - call ESMF_ConfigGetAttribute(LDT_config, slopetype%fillradius, & - label="Slope type fill radius:",rc=rc) - call LDT_verify(rc,"Slope type fill radius: option not specified in the config file") + end do + + if (check_data) then + + call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) + call LDT_verify(rc,"MMF map projection is not defined in the config file.") + call ESMF_ConfigGetAttribute(LDT_config, MMF_fillopts%filltype, label='MMF fill option:', rc=rc) + call LDT_verify(rc,"MMF fill option is not defined in the config file.") + call ESMF_ConfigGetAttribute(LDT_config, MMF_fillopts%fillradius, label='MMF fill radius:', rc=rc) + call LDT_verify(rc,"MMF fill radius is not defined in the config file.") + + do n = 1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config, slopetype%fillvalue, & - label="Slope type fill value:",rc=rc) - call LDT_verify(rc,"Slope type fill value: option not specified in the config file") - if( slopetype%fillvalue > 9. ) then - slopetype%fillvalue = 9. ! Set slopetype upper limit to 9 - end if - elseif( slopetype%filltype == "none" ) then - write(LDT_logunit,*) " -- 'NONE' Parameter-Mask Agreement Option Selected for Slope type" - else - write(LDT_logunit,*) "[ERR] Fill option for Slope type is not valid: ",trim(slopetype%filltype) - write(LDT_logunit,*) " Please select one of these: none or neighbor " - write(LDT_logunit,*) " Programming stopping ..." - call LDT_endrun - end if - - do n=1,LDT_rc%nnest - if( index(Noah_struc(n)%slopetype%source,"Native").eq.0 .and. & - index(Noah_struc(n)%slopetype%source,"CONSTANT").eq.0 ) then - call LDT_readDomainConfigSpecs("Slope type", & - slopetype_proj, Noah_struc(n)%slopetype_gridDesc) - if( slopetype_proj == "latlon" ) then - call LDT_gridOptChecks( n, "Slope type", Noah_struc(n)%slopetype_gridtransform,& - slopetype_proj, Noah_struc(n)%slopetype_gridDesc(9) ) - endif - endif - call LDT_soilsOptChecks(n, "Slope type", & - slopetype_proj, & - Noah_struc(n)%slopetype_gridtransform ) + allocate (Noah_struc(n)%fdepth%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%fdepth%num_bins )) + allocate (Noah_struc(n)%rechclim%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%rechclim%num_bins)) + allocate (Noah_struc(n)%riverbed%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%riverbed%num_bins)) + allocate (Noah_struc(n)%eqwtd%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) + + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) + call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") + + ! Read in MMF parameters + + call MBR%mi (n, MMF_proj) + + call MBR%mr (n, 'T', trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value, MMF_fillopts) + call MBR%mr (n, 'R', trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value,MMF_fillopts) + call MBR%mr (n, 'E', trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value,MMF_fillopts) + call MBR%mr (n, 'W', trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value, MMF_fillopts) + + end do - !- Read in slope type map (mostly used for Noah LSM): - select case ( Noah_struc(n)%slopetype%source ) - case ( "NCEP_LIS" ) - call read_NCEP_slopetype(n,& - Noah_struc(n)%slopetype%value) - case ( "NCEP_GFS" ) - call read_GFS_slopetype(n,& - Noah_struc(n)%slopetype%value) - case ( "NCEP_Native" ) - call read_NCEPNative_slopetype(n,& - Noah_struc(n)%slopetype%value) - case ( "CONSTANT" ) - call read_CONSTANT_slopetype(n,& - Noah_struc(n)%slopetype%value) - case default - write(LDT_logunit,*) "[WARN] Slopetype data source has not been selected." - write(LDT_logunit,*) " Your Noah LSM will not run without this parameter set." - write(LDT_logunit,*) " Please select one of the following: " - write(LDT_logunit,*) " -- NCEP_LIS, NCEP_Native, NCEP_GFS, CONSTANT " - write(LDT_logunit,*) "Program stopping ..." - call LDT_endrun - end select - - ! Fill where parameter values are missing compared to land/water mask: - if( slopetype%filltype == "neighbor" ) then - write(LDT_logunit,*) "Checking/filling mask values for: ", & - trim(Noah_struc(n)%slopetype%short_name) - write(fill_logunit,*) "Checking/filling mask values for: ", & - trim(Noah_struc(n)%slopetype%short_name) - slopetype%watervalue = 0. - call LDT_discreteParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%slopetype_gridtransform, & - Noah_struc(n)%slopetype%num_bins, & - Noah_struc(n)%slopetype%value, slopetype%watervalue, & - LDT_LSMparam_struc(n)%landmask2%value, & - slopetype%filltype, slopetype%fillvalue, slopetype%fillradius ) - endif - enddo - - end if ! Slopetype selection check - - -!-- Bottom soil temperature (K) field: - - call ESMF_ConfigFindLabel(LDT_config,"Bottom temperature data source:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%tbot%source,rc=rc) - call LDT_verify(rc,'Bottom temperature data source: not specified') - enddo - - check_data = .false. - do n=1,LDT_rc%nnest - if(Noah_struc(n)%tbot%source.eq."none") then - Noah_struc(n)%tbot%selectOpt = 0 - endif - if(Noah_struc(n)%tbot%selectOpt.eq.1) then - check_data = .true. - allocate(Noah_struc(n)%tbot%value(& - LDT_rc%lnc(n),LDT_rc%lnr(n),& - Noah_struc(n)%tbot%vlevels)) - endif - enddo - - if( check_data ) then - write(LDT_logunit,*)" - - - - - - - - - Bottom Temperature Parameter - - - - - - - - - - - -" - - call ESMF_ConfigFindLabel(LDT_config,"Bottom temperature map:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%tbotfile,rc=rc) - call LDT_verify(rc,'Bottom temperature map: not specified') - enddo - call ESMF_ConfigGetAttribute(LDT_config, tbot_proj,& - label="Bottom temperature map projection:",rc=rc) - call LDT_verify(rc,'Bottom temperature map projection: option not specified in the config file') - Noah_struc(:)%tbot_proj = tbot_proj - - call ESMF_ConfigFindLabel(LDT_config,"Bottom temperature spatial transform:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%tbot_gridtransform,& - rc=rc) - call LDT_verify(rc,'Bottom temperature tranform: option not specified in the config file') - enddo - - Noah_struc(:)%tbot_topocorr = "none" - call ESMF_ConfigFindLabel(LDT_config,"Bottom temperature topographic downscaling:",rc=rc) - do n=1,LDT_rc%nnest - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%tbot_topocorr,rc=rc) - call LDT_verify(rc,'Bottom temperature topographic downscaling: not specified') - ! Allow for mis-entered lapse-rate option entry: - if( Noah_struc(n)%tbot_topocorr == "lapse_rate" ) Noah_struc(n)%tbot_topocorr="lapse-rate" - if( Noah_struc(n)%tbot_topocorr == "lapse rate" ) Noah_struc(n)%tbot_topocorr="lapse-rate" - if( Noah_struc(n)%tbot_topocorr == "Lapse-rate" ) Noah_struc(n)%tbot_topocorr="lapse-rate" - enddo - - ! Read in "fill" option entries: - tbot%filltype = "none" - call ESMF_ConfigGetAttribute(LDT_config, tbot%filltype, & - label="Bottom temperature fill option:",rc=rc) - call LDT_verify(rc,"Bottom temperature fill option: option not specified in the config file") - - if( tbot%filltype == "neighbor" .or. tbot%filltype == "average" ) then - call ESMF_ConfigGetAttribute(LDT_config, tbot%fillvalue, & - label="Bottom temperature fill value:",rc=rc) - call LDT_verify(rc,"Bottom temperature fill value: option not specified in the config file") - - call ESMF_ConfigGetAttribute(LDT_config, tbot%fillradius, & - label="Bottom temperature fill radius:",rc=rc) - call LDT_verify(rc,"Bottom temperature fill radius: option not specified in the config file") - elseif( tbot%filltype == "none" ) then - write(LDT_logunit,*) " -- 'NONE' Parameter-Mask Agreement Option Selected for Bottom Temperature" - else - write(LDT_logunit,*) "[ERR] Fill option for Bottom Temperature is not valid: ",trim(tbot%filltype) - write(LDT_logunit,*) " Please select one of these: none, neighbor or average " - write(LDT_logunit,*) " Programming stopping ..." - call LDT_endrun - - end if - - ! Don't need to read in "Native" grid extents/resolution, just for LIS inputs - do n=1,LDT_rc%nnest - if( index(Noah_struc(n)%tbot%source,"Native").eq.0 .and. & - index(Noah_struc(n)%tbot%source,"ISLSCP1").eq.0 .and. & - index(Noah_struc(n)%tbot%source,"CONSTANT").eq.0) then - call LDT_readDomainConfigSpecs("Bottom temperature", & - tbot_proj, Noah_struc(n)%tbot_gridDesc) - if( tbot_proj == "latlon" ) then - call LDT_gridOptChecks( n, "Bottom temperature", Noah_struc(n)%tbot_gridtransform, & - tbot_proj, Noah_struc(n)%tbot_gridDesc(9) ) - endif - endif - call LDT_noahparmsOptChecks( n, "Bottom temperature", tbot_proj, & - Noah_struc(n)%tbot_gridtransform ) - enddo - - do n = 1, LDT_rc%nnest - - ! Read in Tbot File: - select case ( Noah_struc(n)%tbot%source ) - case( "NCEP_LIS" ) - call read_NCEP_tbot(& - n,Noah_struc(n)%tbot%value(:,:,1)) - case( "NCEP_GFS" ) - call read_NCEP_GFS_tbot(& - n,Noah_struc(n)%tbot%value(:,:,1)) - case( "ISLSCP1" ) - call read_ISLSCP1_tbot(& - n,Noah_struc(n)%tbot%value(:,:,1)) - case( "CONSTANT" ) - call read_CONSTANT_tbot(& - n,Noah_struc(n)%tbot%value(:,:,1)) - case default - write(LDT_logunit,*) "[WARN] Bottom temperature data source not selected." - write(LDT_logunit,*) " Your Noah LSM will not run without this parameter set." - write(LDT_logunit,*) " Please select one of the following: " - write(LDT_logunit,*) " -- NCEP_LIS, ISLSCP1, NCEP_GFS, CONSTANT " - write(LDT_logunit,*) "Program stopping ..." - call LDT_endrun - end select - - ! Fill where parameter values are missing compared to land/water mask: - if( tbot%filltype == "neighbor" .or. & - tbot%filltype == "average" ) then - write(LDT_logunit,*) "Checking/filling mask values for: ", & - trim(Noah_struc(n)%tbot%short_name) - write(fill_logunit,*) "Checking/filling mask values for: ", & - trim(Noah_struc(n)%tbot%short_name) - tbot%watervalue = LDT_rc%udef - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%tbot_gridtransform, & - Noah_struc(n)%tbot%num_bins, & - Noah_struc(n)%tbot%value, tbot%watervalue, & - LDT_LSMparam_struc(n)%landmask2%value, & - tbot%filltype, tbot%fillvalue, tbot%fillradius ) - endif - - !- Modify final Tbot output with elevation correction: - if( Noah_struc(n)%tbot_topocorr == "lapse-rate" ) then - if( LDT_LSMparam_struc(n)%elevation%selectOpt == 1 ) then - write(LDT_logunit,*) "Performing lapse-rate correction to Tbot output." - allocate(force_elev(LDT_rc%lnc(n),LDT_rc%lnr(n))) - force_elev = 0. - do r = 1, LDT_rc%lnr(n) - do c = 1, LDT_rc%lnc(n) - if( Noah_struc(n)%tbot%value(c,r,1)/=LDT_rc%udef ) & - Noah_struc(n)%tbot%value(c,r,1) = & - Noah_struc(n)%tbot%value(c,r,1) & - + (-0.0065)*(LDT_LSMparam_struc(n)%elevation%value(c,r,1) & - - force_elev(c,r)) - end do - end do - deallocate(force_elev) - elseif( LDT_LSMparam_struc(n)%elevation%selectOpt == 0 ) then - write(LDT_logunit,*) "Cannot perform lapse-rate correction to Tbot output," - write(LDT_logunit,*) " since no elevation/terrain map option was selected. " - write(LDT_logunit,*) " Stopping ... " - call LDT_endrun - endif - endif - - enddo - end if - - !== Other Noah LSM related parameters == - -! -- Noah-MP Planetary Boundary Layer Height: -- - - check_data = .false. - if ((LDT_rc%lsm.eq."Noah-MP.3.6").or.(LDT_rc%lsm.eq."Noah-MP.4.0.1")) then - -! if(check_data) &! then - write(LDT_logunit,*)" - - - - - - - - - Noah-MP Parameters - - - - - - - - - - - -" - - call ESMF_ConfigFindLabel(LDT_config,"Noah-MP PBL Height Value:",rc=rc) - do n=1,LDT_rc%nnest -! call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%pblh%source,rc=rc) - call ESMF_ConfigGetAttribute(LDT_config,Noah_struc(n)%pblh_value,rc=rc) - call LDT_verify(rc,"Noah-MP PBL Height Value: not defined") - - Noah_struc(n)%pblh%selectOpt = 1 - - allocate(Noah_struc(n)%pblh%value(& - LDT_rc%lnc(n),LDT_rc%lnr(n),& - Noah_struc(n)%pblh%num_bins)) - - Noah_struc(n)%pblh%value = Noah_struc(n)%pblh_value - - enddo endif + end subroutine NoahParms_init - end subroutine NoahParms_init_LISHydro - + ! -------------------------------------------------------------------- + subroutine NoahParms_writeHeader(n,ftn,dimID) integer :: n @@ -843,11 +546,17 @@ subroutine NoahParms_writeHeader(n,ftn,dimID) Noah_struc(n)%slopetype) if ((LDT_rc%lsm.eq."Noah-MP.3.6").or. & - (LDT_rc%lsm.eq."Noah-MP.4.0.1")) then - call LDT_writeNETCDFdataHeader(n,ftn,dimID,& - Noah_struc(n)%pblh) + (LDT_rc%lsm.eq."Noah-MP.4.0.1")) then + call LDT_writeNETCDFdataHeader(n,ftn,dimID,& + Noah_struc(n)%pblh) endif + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%fdepth ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%rechclim ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%riverbed ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%eqwtd ) + + end subroutine NoahParms_writeHeader subroutine NoahParms_writeData(n,ftn) @@ -864,6 +573,11 @@ subroutine NoahParms_writeData(n,ftn) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%pblh) endif + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%fdepth ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%rechclim ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%riverbed ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%eqwtd ) + end subroutine NoahParms_writeData diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 new file mode 100644 index 000000000..f8348dde5 --- /dev/null +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -0,0 +1,309 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !MODULE: MMF_groundwater +! \label{MMF_groundwater} +! +! !REVISION HISTORY: +! 27 Aug 2021: Sarith Mahanama +! with inputs from David Mocko, Zhuo Wang ; Initial Specification +! +! !INTERFACE: + +#include "LDT_misc.h" +module MMF_groundwater + + use LDT_logMod, only : LDT_logunit + use LDT_coreMod + use map_utils, only : ij_to_latlon + use LDT_gridmappingMod + use LDT_paramMaskCheckMod + + implicit none + private + + type, public :: MMF_BCsReader + + real, dimension(20) :: param_gridDesc, subparam_gridDesc + integer :: glpnc, glpnr, subpnc, subpnr + integer,allocatable,dimension (:,:) :: lat_line, lon_line, local_mask + + + contains + + procedure, public :: mi => mmf_init + procedure, public :: mr => mmf_data_reader + + end type MMF_BCsReader + + integer,parameter :: NY_MMF = 21600 + integer,parameter :: NX_MMF = 43200 + +contains + + SUBROUTINE mmf_init (MBR, nest, project) + + implicit none + + class (MMF_BCsReader), intent(inout) :: MBR + integer, intent (in) :: nest + character(*), intent (in) :: project + real :: IN_xres, IN_yres + integer :: c,r,gr,gc, glpnc, glpnr + real :: rlon(LDT_rc%lnc(nest),LDT_rc%lnr(nest)),rlat(LDT_rc%lnc(nest),LDT_rc%lnr(nest)) + real :: param_grid(20) + + IN_xres = 360./REAL(NX_MMF) + IN_yres = 180./REAL(NY_MMF) + MBR%param_gridDesc(1) = 0. ! Latlon + MBR%param_gridDesc(2) = real(NX_MMF) + MBR%param_gridDesc(3) = real(NY_MMF) + MBR%param_gridDesc(4) = -90.0 + (IN_yres/2) ! LL lat + MBR%param_gridDesc(5) = -180.0 + (IN_xres/2) ! LL lon + MBR%param_gridDesc(6) = 128 + MBR%param_gridDesc(7) = 90.0 - (IN_yres/2) ! UR lat + MBR%param_gridDesc(8) = 180.0 - (IN_xres/2) ! UR lon + MBR%param_gridDesc(9) = IN_yres + MBR%param_gridDesc(10) = IN_xres + MBR%param_gridDesc(20) = 64 + + param_grid(:) = LDT_rc%mask_gridDesc(nest,:) + glpnr = nint((param_grid(7)-param_grid(4))/param_grid(10)) + 1 + glpnc = nint((param_grid(8)-param_grid(5))/param_grid(9)) + 1 + allocate (MBR%local_mask (LDT_rc%lnc(nest),LDT_rc%lnr(nest))) + + MBR%local_mask = LDT_rc%udef + + do r = 1, LDT_rc%lnr(nest) + do c = 1, LDT_rc%lnc(nest) + call ij_to_latlon(LDT_domain(nest)%ldtproj,float(c),float(r),& + rlat(c,r),rlon(c,r)) + gr = nint((rlat(c,r)-param_grid(4))/param_grid(10)) + 1 + gc = nint((rlon(c,r)-param_grid(5))/param_grid( 9)) + 1 + if(LDT_rc%global_mask(gc,gr) > 0. ) MBR%local_mask(c,r) = 1 + end do + end do + + ! ------------------------------------------------------------ + ! PREPARE SUBSETTED PARAMETER GRID FOR READING IN BCS DATA + ! ------------------------------------------------------------ + + !- Map Parameter Grid Info to LIS Target Grid/Projection Info -- + + MBR%subparam_gridDesc = 0. + + call LDT_RunDomainPts( nest, project, MBR%param_gridDesc(:), & + MBR%glpnc, MBR%glpnr, MBR%subpnc, MBR%subpnr, MBR%subparam_gridDesc, & + MBR%lat_line, MBR%lon_line) + + END SUBROUTINE mmf_init + + ! ---------------------------------------------------------------- + + SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) + + implicit none + + class (MMF_BCsReader), intent(inout) :: MBR + character(*), intent (in) :: varname, datadir + real, dimension (:,:,:), intent (inout) :: lisout + integer, intent (in) :: nest + type(LDT_fillopts) :: MMF_fillopts + + ! Adapted from Zhuo Wang's + ! /discover/nobackup/projects/lis_aist17/zwang9/Geogrid/geogrid2netcdf.f90 + + integer, parameter :: iSigned = 1 + integer, parameter :: endian = 0 + integer, parameter :: wordsize = 2 + integer, parameter :: missing = -9999 + integer, parameter :: ntsteps =1 + integer, parameter :: nlat_tile = 1200 + integer, parameter :: nlon_tile = 1200 + character(len=1024):: geogridFile + character(len=80) :: tileName + integer :: num_tile_lon,num_tile_lat + integer :: rc,status,tx,ty,txs,txe,tys,tye + real,allocatable :: tarray(:,:,:), garray(:,:,:) + real :: SF + + ! c function from Michael G. Duda, NCAR/MMM + integer, external :: read_geogrid + + ! set scale factor + + SF = 1. + select case (trim(varname)) + + case ('T') + ! transmissivity + SF = 0.01 + + case ('R') + ! recharge + SF = 0.03 + + case ('E') + ! river bed elevation + SF = 0.3 + + case ('W') + ! water table depth + SF = -0.03 + + case default + write(LDT_logunit,*) '[ERROR] Unknown MMF data field : ', trim (varname) + VERIFY_(1) + + end select + + ! Reading GEOGRID data + ! -------------------- + + num_tile_lon = NX_MMF / nlon_tile + num_tile_lat = NY_MMF / nlat_tile + + allocate(tarray(nlon_tile,nlat_tile,ntsteps)) + allocate(garray(NX_MMF, NY_MMF, ntsteps)) + garray = LDT_rc%udef ! global array (43200,21600) is constructed by assebling 36x18 # of tarrays (1200,1200) + + TILE_COLS: do tx = 1, num_tile_lon + + txs = 1 + (tx-1)*nlon_tile + txe = tx * nlon_tile + + TILE_ROWS: do ty = 1, num_tile_lat + + tarray = missing ! GEOGRID tile array 1200,1200 + tys = 1 + (ty-1)*nlat_tile + tye = ty * nlat_tile + + write(tileName, fmt='(4(a1,i5.5))') '/',txs, '-', txe, '.', tys, '-', tye + geogridFile = trim(datadir)//trim(tileName) + + rc = read_geogrid(trim(geogridFile),len(trim(geogridFile)),tarray, & + nlon_tile,nlat_tile,ntsteps,isigned,endian,1.,wordsize,status) + + if (rc == 1 .or. status == 1) then + write(LDT_logunit,*) '[ERROR] reading GEOGRID file : ',trim(geogridFile) + VERIFY_(1) + end if + + where(tarray == missing) + tarray = LDT_rc%udef + elsewhere + tarray = SF * tarray + end where + + garray(txs:txe,tys:tye,1) = tarray (1:nlon_tile, 1:nlat_tile,1) + + end do TILE_ROWS + end do TILE_COLS + + ! regrid garray and construct lisout array on the LIS grid + + call regrid_to_lisgrid (nest, garray, lisout) + + ! NOTE : Use MMF_fillopts%filltype and MMF_fillopts%fillradius + ! to fill where lisout values are missing compared + ! to land/water mask: + + deallocate (tarray, garray) + + contains + + ! --------------------------------------------------------------------- + + SUBROUTINE regrid_to_lisgrid (nest, data_in, var_subset) + + ! adapted from params/irrigation/read_GRIPC_irrigfrac.F90 + + implicit none + integer, intent (in) :: nest + real, dimension(:,:,:), intent (in) :: data_in + real, dimension(:,:,:), intent(inout) :: var_subset + + ! arrays read from LL + integer,parameter :: k10 = selected_int_kind(10) + integer :: mi ! Total number of input param grid array points + integer :: mo ! Total number of output LIS grid array points + integer :: nc, nr, i, j + integer, allocatable :: n11(:) ! Array that maps the location of each input grid + ! point in the output grid. + real, allocatable :: gi(:) ! Input parameter 1d grid + logical*1,allocatable :: li(:) ! Input logical mask (to match gi) + real, allocatable, dimension (:,:) :: var_in + real, allocatable, dimension (:) :: go2 ! Output lis 1d grid + logical*1, allocatable, dimension (:) :: lo2 ! Output logical mask (to match go) + + !mi = INT(dble(MBR%NX)*dble(MBR%NY), 8) + mi = MBR%subpnc*MBR%subpnr + mo = LDT_rc%lnc(nest)*LDT_rc%lnr(nest) + + allocate (var_in(MBR%subpnc,MBR%subpnr)) + allocate ( li(mi), gi (mi), n11(mi)) + allocate (go2(mo), lo2(mo)) + + !- Create mapping between parameter domain and LIS grid domain: + call upscaleByAveraging_input( MBR%subparam_gridDesc, & + LDT_rc%gridDesc(nest,:), mi, mo, n11) + + Data_Fields: do j = 1, size (data_in, 3) + + var_in = LDT_rc%udef + do nr = 1, MBR%subpnr + do nc = 1, MBR%subpnc + var_in (nc,nr) = data_in (MBR%lon_line(nc,1),MBR%lat_line (1,nr),j) + end do + end do + + ! ------------------------------------------------------------------- + ! AGGREGATING FINE-SCALE GRIDS TO COARSER LIS OUTPUT GRID + ! ------------------------------------------------------------------- + + gi = LDT_rc%udef + li = .false. + + !- Assign 2-D array to 1-D for aggregation routines: + i = 0 + do nr = 1, MBR%subpnr + do nc = 1, MBR%subpnc + i = i + 1 + if( var_in(nc,nr) .NE. LDT_rc%udef) then + gi(i) = var_in(nc,nr) + li(i) = .true. + endif + end do + enddo + + !- Spatial average within each coarse gridcell: + call upscaleByAveraging ( mi, mo, LDT_rc%udef, n11, li, gi, & + lo2(:), go2 (:)) + i = 0 + do nr = 1, LDT_rc%lnr(nest) + do nc = 1, LDT_rc%lnc(nest) + i = i + 1 + var_subset (nc,nr,j) = go2(i) + enddo + enddo + + end do Data_Fields + deallocate (var_in, li, gi, n11, go2, lo2) + + END SUBROUTINE regrid_to_lisgrid + + END SUBROUTINE mmf_data_reader + + ! ---------------------------------------------------------------- + +end module MMF_groundwater + + diff --git a/ldt/params/Noah/read_geogrid.c b/ldt/params/Noah/read_geogrid.c new file mode 100644 index 000000000..9b6289713 --- /dev/null +++ b/ldt/params/Noah/read_geogrid.c @@ -0,0 +1,134 @@ +/* File: read_geogrid.c + + Sample subroutine to read an array from the geogrid binary format. + + Notes: Depending on the compiler and compiler flags, the name of + the read_geogrid() routine may need to be adjusted with respect + to the number of trailing underscores when calling from Fortran. + + Michael G. Duda, NCAR/MMM +*/ +#include +#include +#include +#include +/* +#define BIG_ENDIAN 0 +#define LITTLE_ENDIAN 1 +*/ +int read_geogrid_( + char * fname, /* The name of the file to read from */ + int * len, /* The length of the filename */ + float * rarray, /* The array to be filled */ + int * nx, /* x-dimension of the array */ + int * ny, /* y-dimension of the array */ + int * nz, /* z-dimension of the array */ + int * isigned, /* 0=unsigned data, 1=signed data */ + int * endian, /* 0=big endian, 1=little endian */ + float * scalefactor, /* value to multiply array elements by before truncation to integers */ + int * wordsize, /* number of bytes to use for each array element */ + int * status) +{ + int i, ival, cnt, narray; + int A2, B2; + int A3, B3, C3; + int A4, B4, C4, D4; + unsigned char * c; + char local_fname[1024]; + FILE * bfile; + + *status = 0; + + narray = (*nx) * (*ny) * (*nz); + + /* Make a null-terminated local copy of the filename */ + strncpy(local_fname,fname,*len); + local_fname[*len]='\0'; + + /* Attempt to open file for reading */ + if (!(bfile = fopen(local_fname,"rb"))) + { + printf("ERROR opening %s\n",local_fname); + *status = 1; + return 1; + } + + /* Allocate memory to hold bytes from file and read data */ + c = (unsigned char *)malloc(sizeof(unsigned char)*(*wordsize) * narray); + cnt = fread((void *)c, sizeof(unsigned char), narray*(*wordsize), bfile); + + fclose(bfile); + + if (cnt == 0) + { + printf("ERROR reading %s\n",local_fname); + *status = 1; + return 1; + } + + /* + Set up byte offsets for each wordsize depending on byte order. + A, B, C, D give the offsets of the LSB through MSB (i.e., for + word ABCD, A=MSB, D=LSB) in the array from the beginning of a word + */ + if (*endian == BIG_ENDIAN) { + A2 = 0; B2 = 1; + A3 = 0; B3 = 1; C3 = 2; + A4 = 0; B4 = 1; C4 = 2; D4 = 3; + } + else { + B2 = 0; A2 = 1; + C3 = 0; B3 = 1; A3 = 2; + D4 = 0; C4 = 1; B4 = 2; A4 = 3; + } + + /* Convert words from native byte order */ + switch(*wordsize) { + case 1: + for(i=0; i (1 << 7))) ival -= (1 << 8); + rarray[i] = (float)ival; + } + break; + + case 2: + for(i=0; i (1 << 15))) ival -= (1 << 16); + rarray[i] = (float)ival; + } + break; + + case 3: + for(i=0; i (1 << 23))) ival -= (1 << 24); + rarray[i] = (float)ival; + } + break; + + case 4: + for(i=0; i (1 << 31))) ival -= (1 << 32); + rarray[i] = (float)ival; + } + break; + } + + free(c); + + /* Scale real-valued array by scalefactor */ + if (*scalefactor != 1.0) + { + for (i=0; i.00001- is + created, where is the argument nx and is the argument ny, + both in i5.5 format. + + Notes: Depending on the compiler and compiler flags, the name of + the write_geogrid() routine may need to be adjusted with respect + to the number of trailing underscores when calling from Fortran. + + Michael G. Duda, NCAR/MMM +*/ + +#include +#include +#include + +#ifdef _UNDERSCORE +#define write_geogrid write_geogrid_ +#endif +#ifdef _DOUBLEUNDERSCORE +#define write_geogrid write_geogrid__ +#endif + +#define BIG_ENDIAN 0 +#define LITTLE_ENDIAN 1 + +int write_geogrid_( + float * rarray, /* The array to be written */ + int * nx, /* x-dimension of the array */ + int * ny, /* y-dimension of the array */ + int * nz, /* z-dimension of the array */ + int * isigned, /* 0=unsigned data, 1=signed data */ + int * endian, /* 0=big endian, 1=little endian */ + float * scalefactor, /* value to divide array elements by before truncation to integers */ + int * wordsize ) /* number of bytes to use for each array element */ +{ + int i, narray; + int A2, B2; + int A3, B3, C3; + int A4, B4, C4, D4; + unsigned int * iarray; + unsigned char * barray; + char fname[24]; + FILE * bfile; + + narray = (*nx) * (*ny) * (*nz); + + iarray = (unsigned int *)malloc(sizeof(int) * narray); + barray = (unsigned char *)malloc(sizeof(unsigned char) * narray * (*wordsize)); + + /* Scale real-valued array by scalefactor and convert to integers */ + for (i=0; i> 8) & 0xff); + barray[(*wordsize)*i+B2] = (unsigned char)( iarray[i] & 0xff); + } + break; + + case 3: + for(i=0; i> 16) & 0xff); + barray[(*wordsize)*i+B3] = (unsigned char)((iarray[i] >> 8) & 0xff); + barray[(*wordsize)*i+C3] = (unsigned char)( iarray[i] & 0xff); + } + break; + + case 4: + for(i=0; i> 24) & 0xff); + barray[(*wordsize)*i+B4] = (unsigned char)((iarray[i] >> 16) & 0xff); + barray[(*wordsize)*i+C4] = (unsigned char)((iarray[i] >> 8) & 0xff); + barray[(*wordsize)*i+D4] = (unsigned char)( iarray[i] & 0xff); + } + break; + } + + sprintf(fname,"%5.5i-%5.5i.%5.5i-%5.5i",1,*nx,1,*ny); + + /* Write array to file */ + bfile = fopen(fname,"wb"); + fwrite(barray,sizeof(unsigned char),narray*(*wordsize),bfile); + fclose(bfile); + + free(iarray); + free(barray); + + return 0; +} From 602514791dab4f6b2b076dfb4f60fcae2aa3e959 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 3 Sep 2021 17:17:58 -0400 Subject: [PATCH 002/328] fixed endian issue in read_geogrid.c --- ldt/params/Noah/read_geogrid.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/ldt/params/Noah/read_geogrid.c b/ldt/params/Noah/read_geogrid.c index 9b6289713..09ddc2048 100644 --- a/ldt/params/Noah/read_geogrid.c +++ b/ldt/params/Noah/read_geogrid.c @@ -12,10 +12,12 @@ #include #include #include + /* #define BIG_ENDIAN 0 #define LITTLE_ENDIAN 1 */ + int read_geogrid_( char * fname, /* The name of the file to read from */ int * len, /* The length of the filename */ @@ -71,7 +73,7 @@ int read_geogrid_( A, B, C, D give the offsets of the LSB through MSB (i.e., for word ABCD, A=MSB, D=LSB) in the array from the beginning of a word */ - if (*endian == BIG_ENDIAN) { + if (*endian == 0) { A2 = 0; B2 = 1; A3 = 0; B3 = 1; C3 = 2; A4 = 0; B4 = 1; C4 = 2; D4 = 3; From 70f1221240c198d83a8e247f9ef30a8e651b952a Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Tue, 7 Sep 2021 20:01:54 -0400 Subject: [PATCH 003/328] removed ASSERT_ and VERIFY_ --- ldt/arch/Config.pl | 3 +-- ldt/params/Noah/module_MMF_groundwater.F90 | 9 ++++----- 2 files changed, 5 insertions(+), 7 deletions(-) diff --git a/ldt/arch/Config.pl b/ldt/arch/Config.pl index 09f53bb8a..b7bf19c36 100755 --- a/ldt/arch/Config.pl +++ b/ldt/arch/Config.pl @@ -824,8 +824,7 @@ #printf misc_file "%s\n","#undef SPMD"; printf misc_file "%s\n","#define BILHEADER_FILE_READ_METHOD_1_"; printf misc_file "%s\n","#define BILREAD_ASSUME_BIG_ENDIAN_"; -printf misc_file "%s\n","#define VERIFY_(A) IF(A/=0)THEN;PRINT *,'ERROR AT LINE ', __LINE__;STOP;ENDIF"; -printf misc_file "%s\n","#define ASSERT_(A) if(.not.A)then;print *,'Error:',__FILE__,__LINE__;stop;endif"; + close(misc_file); open(netcdf_file,">LDT_NetCDF_inc.h"); diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index f8348dde5..b0117b774 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -21,7 +21,7 @@ #include "LDT_misc.h" module MMF_groundwater - use LDT_logMod, only : LDT_logunit + use LDT_logMod, only : LDT_logunit, LDT_endrun use LDT_coreMod use map_utils, only : ij_to_latlon use LDT_gridmappingMod @@ -161,8 +161,7 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) case default write(LDT_logunit,*) '[ERROR] Unknown MMF data field : ', trim (varname) - VERIFY_(1) - + call LDT_endrun end select ! Reading GEOGRID data @@ -194,8 +193,8 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) if (rc == 1 .or. status == 1) then write(LDT_logunit,*) '[ERROR] reading GEOGRID file : ',trim(geogridFile) - VERIFY_(1) - end if + call LDT_endrun + end if where(tarray == missing) tarray = LDT_rc%udef From 617c14802adfd9eef3431e4daea3b0318ce807b8 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Wed, 15 Sep 2021 14:21:40 -0400 Subject: [PATCH 004/328] removed few unused lines --- ldt/params/Noah/module_MMF_groundwater.F90 | 23 +--------------------- 1 file changed, 1 insertion(+), 22 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index b0117b774..d45dbd281 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -57,9 +57,6 @@ SUBROUTINE mmf_init (MBR, nest, project) integer, intent (in) :: nest character(*), intent (in) :: project real :: IN_xres, IN_yres - integer :: c,r,gr,gc, glpnc, glpnr - real :: rlon(LDT_rc%lnc(nest),LDT_rc%lnr(nest)),rlat(LDT_rc%lnc(nest),LDT_rc%lnr(nest)) - real :: param_grid(20) IN_xres = 360./REAL(NX_MMF) IN_yres = 180./REAL(NY_MMF) @@ -75,23 +72,6 @@ SUBROUTINE mmf_init (MBR, nest, project) MBR%param_gridDesc(10) = IN_xres MBR%param_gridDesc(20) = 64 - param_grid(:) = LDT_rc%mask_gridDesc(nest,:) - glpnr = nint((param_grid(7)-param_grid(4))/param_grid(10)) + 1 - glpnc = nint((param_grid(8)-param_grid(5))/param_grid(9)) + 1 - allocate (MBR%local_mask (LDT_rc%lnc(nest),LDT_rc%lnr(nest))) - - MBR%local_mask = LDT_rc%udef - - do r = 1, LDT_rc%lnr(nest) - do c = 1, LDT_rc%lnc(nest) - call ij_to_latlon(LDT_domain(nest)%ldtproj,float(c),float(r),& - rlat(c,r),rlon(c,r)) - gr = nint((rlat(c,r)-param_grid(4))/param_grid(10)) + 1 - gc = nint((rlon(c,r)-param_grid(5))/param_grid( 9)) + 1 - if(LDT_rc%global_mask(gc,gr) > 0. ) MBR%local_mask(c,r) = 1 - end do - end do - ! ------------------------------------------------------------ ! PREPARE SUBSETTED PARAMETER GRID FOR READING IN BCS DATA ! ------------------------------------------------------------ @@ -103,7 +83,7 @@ SUBROUTINE mmf_init (MBR, nest, project) call LDT_RunDomainPts( nest, project, MBR%param_gridDesc(:), & MBR%glpnc, MBR%glpnr, MBR%subpnc, MBR%subpnr, MBR%subparam_gridDesc, & MBR%lat_line, MBR%lon_line) - + END SUBROUTINE mmf_init ! ---------------------------------------------------------------- @@ -243,7 +223,6 @@ SUBROUTINE regrid_to_lisgrid (nest, data_in, var_subset) real, allocatable, dimension (:) :: go2 ! Output lis 1d grid logical*1, allocatable, dimension (:) :: lo2 ! Output logical mask (to match go) - !mi = INT(dble(MBR%NX)*dble(MBR%NY), 8) mi = MBR%subpnc*MBR%subpnr mo = LDT_rc%lnc(nest)*LDT_rc%lnr(nest) From a0a9ca2f5703112898e3352307141c15f9c1dc14 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Wed, 15 Sep 2021 20:10:20 -0400 Subject: [PATCH 005/328] added AREAXY calculation --- ldt/params/Noah/Noah_parmsMod.F90 | 12 ++++- ldt/params/Noah/module_MMF_groundwater.F90 | 55 +++++++++++++++++++++- 2 files changed, 65 insertions(+), 2 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index f72715392..59513ef8b 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -81,6 +81,7 @@ module Noah_parmsMod type(LDT_paramEntry) :: rechclim type(LDT_paramEntry) :: riverbed type(LDT_paramEntry) :: eqwtd + type(LDT_paramEntry) :: areaxy end type noah_type_dec @@ -167,7 +168,9 @@ subroutine NoahParms_init (flag) call set_param_attribs(Noah_struc(n)%eqwtd,"MMF_EQWTD",& units="m", & full_name="equilibrium water table depth") - + call set_param_attribs(Noah_struc(n)%areaxy,"AREAXY",& + units="km^2", & + full_name="area of the grid cell") endif enddo @@ -512,6 +515,7 @@ subroutine NoahParms_init (flag) allocate (Noah_struc(n)%rechclim%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%rechclim%num_bins)) allocate (Noah_struc(n)%riverbed%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%riverbed%num_bins)) allocate (Noah_struc(n)%eqwtd%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) + allocate (Noah_struc(n)%areaxy%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") @@ -524,6 +528,10 @@ subroutine NoahParms_init (flag) call MBR%mr (n, 'R', trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value,MMF_fillopts) call MBR%mr (n, 'E', trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value,MMF_fillopts) call MBR%mr (n, 'W', trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value, MMF_fillopts) + + ! write areaXY + + call MBR%cell_area (n,Noah_struc(n)%areaxy%value) end do @@ -555,6 +563,7 @@ subroutine NoahParms_writeHeader(n,ftn,dimID) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%rechclim ) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%riverbed ) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%eqwtd ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%areaxy ) end subroutine NoahParms_writeHeader @@ -577,6 +586,7 @@ subroutine NoahParms_writeData(n,ftn) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%rechclim ) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%riverbed ) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%eqwtd ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%areaxy ) end subroutine NoahParms_writeData diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index d45dbd281..0eb6a1008 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -23,7 +23,6 @@ module MMF_groundwater use LDT_logMod, only : LDT_logunit, LDT_endrun use LDT_coreMod - use map_utils, only : ij_to_latlon use LDT_gridmappingMod use LDT_paramMaskCheckMod @@ -41,6 +40,7 @@ module MMF_groundwater procedure, public :: mi => mmf_init procedure, public :: mr => mmf_data_reader + procedure, public :: cell_area end type MMF_BCsReader @@ -282,6 +282,59 @@ END SUBROUTINE mmf_data_reader ! ---------------------------------------------------------------- + SUBROUTINE cell_area (MBR, nest, area) + + use map_utils, only : ij_to_latlon + use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI + + implicit none + + class (MMF_BCsReader), intent(inout) :: MBR + integer, intent (in) :: nest + real, dimension (:,:,:), intent (inout) :: area + integer :: i,j, s + real, parameter :: nstrips = 100. + real :: lat_ll, lat_ur , lat_ul, lat_lr + real :: lon_ll, lon_ur , lon_ul, lon_lr + real :: c, r, d2r, dx, dyl, dyu, w_edge, e_edge, lat1, lat2 + + d2r = PI/180. + area = 0. + + do j = 1, LDT_rc%lnr(nest) + do i = 1, LDT_rc%lnc(nest) + + r = float (j) + c = float (i) + + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner + + w_edge = (lon_ll + lon_ul) / 2. + e_edge = (lon_ur + lon_lr) / 2. + + dyl= (lat_lr - lat_ll) / nstrips + dyu= (lat_ur - lat_ul) / nstrips + dx = (e_edge - w_edge) / nstrips + + do s = 1, nstrips + + lat1 = lat_ll + (s-1)*dyl + dyl/2. + lat2 = lat_ul + (s-1)*dyu + dyu/2. + area (i,j,1) = area (i,j,1) + (sin(d2r* lat2) - sin(d2r*lat1))*radius*radius*dx*d2r/1000./1000. ! [km2] + + end do + + end do + end do + + END SUBROUTINE cell_area + + ! ---------------------------------------------------------------- + + end module MMF_groundwater From 6aae52fc858772f7c0ce41c9a32ff43843faf801 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 17 Sep 2021 19:33:00 -0400 Subject: [PATCH 006/328] added gap filling --- ldt/params/Noah/Noah_parmsMod.F90 | 70 ++++++-- ldt/params/Noah/module_MMF_groundwater.F90 | 183 +++++++++++++++++++-- 2 files changed, 224 insertions(+), 29 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 59513ef8b..436311b23 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -127,7 +127,8 @@ subroutine NoahParms_init (flag) real, allocatable :: force_elev(:,:) character*50 :: tbot_proj character*50 :: slopetype_proj - type(LDT_fillopts) :: MMF_fillopts + type(LDT_fillopts) :: FDEPTH_fillopts, RECHCLIM_fillopts + type(LDT_fillopts) :: RIVERBED_fillopts, EQWTD_fillopts character*50 :: MMF_proj type(MMF_BCsReader):: MBR @@ -502,13 +503,25 @@ subroutine NoahParms_init (flag) if (check_data) then - call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) - call LDT_verify(rc,"MMF map projection is not defined in the config file.") - call ESMF_ConfigGetAttribute(LDT_config, MMF_fillopts%filltype, label='MMF fill option:', rc=rc) - call LDT_verify(rc,"MMF fill option is not defined in the config file.") - call ESMF_ConfigGetAttribute(LDT_config, MMF_fillopts%fillradius, label='MMF fill radius:', rc=rc) - call LDT_verify(rc,"MMF fill radius is not defined in the config file.") - + call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") + + call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + + do n = 1,LDT_rc%nnest allocate (Noah_struc(n)%fdepth%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%fdepth%num_bins )) @@ -524,11 +537,42 @@ subroutine NoahParms_init (flag) call MBR%mi (n, MMF_proj) - call MBR%mr (n, 'T', trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value, MMF_fillopts) - call MBR%mr (n, 'R', trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value,MMF_fillopts) - call MBR%mr (n, 'E', trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value,MMF_fillopts) - call MBR%mr (n, 'W', trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value, MMF_fillopts) - + call MBR%mr (n, 'T', trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value ) + call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & + Noah_struc(n)%mmf_transform, & + Noah_struc(n)%fdepth%num_bins, & + Noah_struc(n)%fdepth%value, LDT_rc%udef, & + LDT_LSMparam_struc(n)%landmask2%value, & + FDEPTH_fillopts%filltype, FDEPTH_fillopts%fillvalue, & + FDEPTH_fillopts%fillradius ) + + call MBR%mr (n, 'R', trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value) + call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & + Noah_struc(n)%mmf_transform, & + Noah_struc(n)%rechclim%num_bins, & + Noah_struc(n)%rechclim%value, LDT_rc%udef, & + LDT_LSMparam_struc(n)%landmask2%value, & + RECHCLIM_fillopts%filltype, RECHCLIM_fillopts%fillvalue,& + RECHCLIM_fillopts%fillradius ) + + call MBR%mr (n, 'E', trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value) + call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & + Noah_struc(n)%mmf_transform, & + Noah_struc(n)%riverbed%num_bins, & + Noah_struc(n)%riverbed%value, LDT_rc%udef, & + LDT_LSMparam_struc(n)%landmask2%value, & + RIVERBED_fillopts%filltype, RIVERBED_fillopts%fillvalue,& + RIVERBED_fillopts%fillradius ) + + call MBR%mr (n, 'W', trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value ) + call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & + Noah_struc(n)%mmf_transform, & + Noah_struc(n)%eqwtd%num_bins, & + Noah_struc(n)%eqwtd%value, LDT_rc%udef, & + LDT_LSMparam_struc(n)%landmask2%value, & + EQWTD_fillopts%filltype, EQWTD_fillopts%fillvalue, & + EQWTD_fillopts%fillradius ) + ! write areaXY call MBR%cell_area (n,Noah_struc(n)%areaxy%value) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 0eb6a1008..f93e4f5d3 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -21,11 +21,10 @@ #include "LDT_misc.h" module MMF_groundwater - use LDT_logMod, only : LDT_logunit, LDT_endrun - use LDT_coreMod - use LDT_gridmappingMod - use LDT_paramMaskCheckMod - + use LDT_logMod, only : LDT_logunit, LDT_endrun + use LDT_coreMod, only : LDT_rc, LDT_domain + use LDT_gridmappingMod, only : LDT_RunDomainPts + implicit none private @@ -40,7 +39,12 @@ module MMF_groundwater procedure, public :: mi => mmf_init procedure, public :: mr => mmf_data_reader - procedure, public :: cell_area + procedure, public :: cell_area => cell_area_curve + + procedure, private:: cell_area_line + procedure, private:: cell_area_curve + procedure, private:: cell_area_girard + end type MMF_BCsReader @@ -88,7 +92,7 @@ END SUBROUTINE mmf_init ! ---------------------------------------------------------------- - SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) + SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) implicit none @@ -96,7 +100,6 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) character(*), intent (in) :: varname, datadir real, dimension (:,:,:), intent (inout) :: lisout integer, intent (in) :: nest - type(LDT_fillopts) :: MMF_fillopts ! Adapted from Zhuo Wang's ! /discover/nobackup/projects/lis_aist17/zwang9/Geogrid/geogrid2netcdf.f90 @@ -190,10 +193,6 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout, MMF_fillopts) ! regrid garray and construct lisout array on the LIS grid call regrid_to_lisgrid (nest, garray, lisout) - - ! NOTE : Use MMF_fillopts%filltype and MMF_fillopts%fillradius - ! to fill where lisout values are missing compared - ! to land/water mask: deallocate (tarray, garray) @@ -282,13 +281,13 @@ END SUBROUTINE mmf_data_reader ! ---------------------------------------------------------------- - SUBROUTINE cell_area (MBR, nest, area) + SUBROUTINE cell_area_curve (MBR, nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI implicit none - + class (MMF_BCsReader), intent(inout) :: MBR integer, intent (in) :: nest real, dimension (:,:,:), intent (inout) :: area @@ -313,7 +312,7 @@ SUBROUTINE cell_area (MBR, nest, area) call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner w_edge = (lon_ll + lon_ul) / 2. - e_edge = (lon_ur + lon_lr) / 2. + e_edge = (lon_lr + lon_ur) / 2. dyl= (lat_lr - lat_ll) / nstrips dyu= (lat_ur - lat_ul) / nstrips @@ -330,10 +329,162 @@ SUBROUTINE cell_area (MBR, nest, area) end do end do - END SUBROUTINE cell_area + END SUBROUTINE cell_area_curve ! ---------------------------------------------------------------- + SUBROUTINE cell_area_line (MBR, nest, area) + + use map_utils, only : ij_to_latlon + use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI + + implicit none + + class (MMF_BCsReader), intent(inout) :: MBR + integer, intent (in) :: nest + real, dimension (:,:,:), intent (inout) :: area + integer :: i,j, s + real, parameter :: nstrips = 100. + real :: lat_ll, lat_ur , lat_ul, lat_lr + real :: lon_ll, lon_ur , lon_ul, lon_lr + real :: c, r, d2r, dx, dw, w_edge, e_edge, lat1, lat2 + + d2r = PI/180. + area = 0. + + do j = 1, LDT_rc%lnr(nest) + do i = 1, LDT_rc%lnc(nest) + + r = float (j) + c = float (i) + + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner + + w_edge = (lon_ll + lon_ul) / 2. + e_edge = (lon_lr + lon_ur) / 2. + + dx = (e_edge - w_edge) / nstrips + dw = 1./nstrips + do s = 1, nstrips + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5 + dw/2. + (s-1)*dw, r-0.5, lat1, lon_ll) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5 + dw/2. + (s-1)*dw, r+0.5, lat2, lon_ll) + area (i,j,1) = area (i,j,1) + (sin(d2r* lat2) - sin(d2r*lat1))*radius*radius*dx*d2r/1000./1000. ! [km2] + + end do + + end do + end do + + END SUBROUTINE cell_area_line + + ! ---------------------------------------------------------------- + + SUBROUTINE cell_area_girard (MBR, nest, area) + + use map_utils, only : ij_to_latlon + use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI + + implicit none + + class (MMF_BCsReader), intent(inout) :: MBR + integer, intent (in) :: nest + real, dimension (:,:,:), intent (inout) :: area + integer :: i,j + real :: lat_ll, lat_ur , lat_ul, lat_lr, c, r + real :: lon_ll, lon_ur , lon_ul, lon_lr + real :: ab, bc, cd, da, ac, bd ! side lengths + real :: DAB, ABC, BCD, CDA + + area = 0. + + do j = 1, LDT_rc%lnr(nest) + do i = 1, LDT_rc%lnc(nest) + + r = float (j) + c = float (i) + + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) + + ! side lengths + ab = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ul), d2r(lon_ul)) + bc = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_ur), d2r(lon_ur)) + cd = haversine(d2r(lat_ur), d2r(lon_ur), d2r(lat_lr), d2r(lon_lr)) + da = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_lr), d2r(lon_lr)) + ac = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ur), d2r(lon_ur)) + bd = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_lr), d2r(lon_lr)) + + ! area = ABC area + ACD area + ! = radius * radius * (^DAB + ^ABC + ^BCD + ^CDA - 2 * pi) + + DAB = angle (bd, da, ab) + ABC = angle (ac, ab, bc) + BCD = angle (bd, bc, cd) + CDA = angle (ac, cd, da) + + area (i,j,1) = radius * radius * & + (DAB + ABC + BCD + CDA - 2. * pi)/1000./1000. ! [km2] + + end do + end do + + contains + + ! ***************************************************************************** + + real function haversine(deglat1,deglon1,deglat2,deglon2) + ! great circle distance + real,intent(in) :: deglat1,deglon1,deglat2,deglon2 + real :: a,c, dlat,dlon,lat1,lat2 + + dlat = deglat2-deglat1 + dlon = deglon2-deglon1 + lat1 = deglat1 + lat2 = deglat2 + a = (sin(dlat/2))**2 + cos(lat1)*cos(lat2)*(sin(dlon/2))**2 + if(a>=0. .and. a<=1.) then + c = 2*atan2(sqrt(a),sqrt(1-a)) + haversine = radius*c ! [m] + else + haversine = 1.e20 + endif + end function haversine + + ! ***************************************************************************** + + function angle (c, a, b) result(ACB) + + ! degrees to radians + real,intent(in) :: c, a, b + real :: ACB, r + + r = radius + + ACB = acos ((cos(c/r) - cos(a/r) * cos(b/r)) / sin(a/r) / sin (b/r)) + print *, c/1000.,a/1000.,b/1000., ACB*180./pi + + end function angle + + ! ***************************************************************************** + + function d2r (degree) result(rad) + + ! degrees to radians + real,intent(in) :: degree + real :: rad + + rad = degree*PI/180. + + end function d2r + + END SUBROUTINE cell_area_girard + + ! ---------------------------------------------------------------- end module MMF_groundwater From f817b370d3d7927b7e8588309cb9535807250bbc Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Mon, 20 Sep 2021 14:09:24 -0400 Subject: [PATCH 007/328] tried spherical trignometry --- ldt/params/Noah/module_MMF_groundwater.F90 | 39 ++++++++++------------ 1 file changed, 17 insertions(+), 22 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index f93e4f5d3..dc665ba61 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -39,7 +39,7 @@ module MMF_groundwater procedure, public :: mi => mmf_init procedure, public :: mr => mmf_data_reader - procedure, public :: cell_area => cell_area_curve + procedure, public :: cell_area => cell_area_girard procedure, private:: cell_area_line procedure, private:: cell_area_curve @@ -395,11 +395,10 @@ SUBROUTINE cell_area_girard (MBR, nest, area) integer :: i,j real :: lat_ll, lat_ur , lat_ul, lat_lr, c, r real :: lon_ll, lon_ur , lon_ul, lon_lr - real :: ab, bc, cd, da, ac, bd ! side lengths - real :: DAB, ABC, BCD, CDA + real :: ab, bc, cd, da, ac ! side lengths area = 0. - + do j = 1, LDT_rc%lnr(nest) do i = 1, LDT_rc%lnc(nest) @@ -417,18 +416,11 @@ SUBROUTINE cell_area_girard (MBR, nest, area) cd = haversine(d2r(lat_ur), d2r(lon_ur), d2r(lat_lr), d2r(lon_lr)) da = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_lr), d2r(lon_lr)) ac = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ur), d2r(lon_ur)) - bd = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_lr), d2r(lon_lr)) - + ! area = ABC area + ACD area - ! = radius * radius * (^DAB + ^ABC + ^BCD + ^CDA - 2 * pi) - - DAB = angle (bd, da, ab) - ABC = angle (ac, ab, bc) - BCD = angle (bd, bc, cd) - CDA = angle (ac, cd, da) area (i,j,1) = radius * radius * & - (DAB + ABC + BCD + CDA - 2. * pi)/1000./1000. ! [km2] + (triangle_area (ac, ab, bc) + triangle_area(ac, cd, da))/1000./1000. ! [km2] end do end do @@ -449,26 +441,29 @@ real function haversine(deglat1,deglon1,deglat2,deglon2) a = (sin(dlat/2))**2 + cos(lat1)*cos(lat2)*(sin(dlon/2))**2 if(a>=0. .and. a<=1.) then c = 2*atan2(sqrt(a),sqrt(1-a)) - haversine = radius*c ! [m] + haversine = c ! [per unit radius] else haversine = 1.e20 endif end function haversine + ! ***************************************************************************** - function angle (c, a, b) result(ACB) + function triangle_area (c, a, b) result(ABC_area) ! degrees to radians real,intent(in) :: c, a, b - real :: ACB, r + real :: ACB, ABC_area - r = radius - - ACB = acos ((cos(c/r) - cos(a/r) * cos(b/r)) / sin(a/r) / sin (b/r)) - print *, c/1000.,a/1000.,b/1000., ACB*180./pi - - end function angle + ! The spherical law of cosines per unit radius + ACB = acos ((cos(c) - cos(a) * cos(b)) / sin(a) / sin (b)) + + ! Area = spherical excess per unit radius + ABC_area = ABS(2.* atan( tan(a/2.)*tan(b/2.)*sin(ACB) / & + (1. + tan(a/2.)*tan(b/2.)*cos(ACB)))) + + end function triangle_area ! ***************************************************************************** From 708aa23fb6b256991a85577e07e25ee5207cebe0 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Tue, 21 Sep 2021 14:10:27 -0400 Subject: [PATCH 008/328] latlon projection uses the widely used formula for AREAXY calculation --- ldt/params/Noah/module_MMF_groundwater.F90 | 48 ++++++++++++++-------- 1 file changed, 30 insertions(+), 18 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index dc665ba61..2c271d5d0 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -394,7 +394,7 @@ SUBROUTINE cell_area_girard (MBR, nest, area) real, dimension (:,:,:), intent (inout) :: area integer :: i,j real :: lat_ll, lat_ur , lat_ul, lat_lr, c, r - real :: lon_ll, lon_ur , lon_ul, lon_lr + real :: lon_ll, lon_ur , lon_ul, lon_lr, lat, lon real :: ab, bc, cd, da, ac ! side lengths area = 0. @@ -404,24 +404,36 @@ SUBROUTINE cell_area_girard (MBR, nest, area) r = float (j) c = float (i) - - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) - - ! side lengths - ab = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ul), d2r(lon_ul)) - bc = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_ur), d2r(lon_ur)) - cd = haversine(d2r(lat_ur), d2r(lon_ur), d2r(lat_lr), d2r(lon_lr)) - da = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_lr), d2r(lon_lr)) - ac = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ur), d2r(lon_ur)) - - ! area = ABC area + ACD area + + if(trim(LDT_rc%lis_map_proj(nest)) == 'latlon') then + + call ij_to_latlon(LDT_domain(nest)%ldtproj,c , r, lat, lon) ! center + area (i,j,1) = radius * radius * & + (sin(d2r(lat + 0.5*LDT_rc%gridDesc(nest,10))) - & + sin(d2r(lat - 0.5*LDT_rc%gridDesc(nest,10))))* & + (d2r(LDT_rc%gridDesc(nest,9)))/1000./1000. ! [km2] + + else - area (i,j,1) = radius * radius * & - (triangle_area (ac, ab, bc) + triangle_area(ac, cd, da))/1000./1000. ! [km2] - + + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) + + ! side lengths + ab = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ul), d2r(lon_ul)) + bc = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_ur), d2r(lon_ur)) + cd = haversine(d2r(lat_ur), d2r(lon_ur), d2r(lat_lr), d2r(lon_lr)) + da = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_lr), d2r(lon_lr)) + ac = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ur), d2r(lon_ur)) + + ! area = ABC area + ACD area + + area (i,j,1) = radius * radius * & + (triangle_area (ac, ab, bc) + triangle_area(ac, cd, da))/1000./1000. ! [km2] + endif + end do end do From 947976ea3467509c6ec04f1128938d3d085b45a4 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 24 Sep 2021 07:53:39 -0400 Subject: [PATCH 009/328] Added WPS's elevation data HGT for consistency --- ldt/params/Noah/Noah_parmsMod.F90 | 26 +++++++++++++-- ldt/params/Noah/module_MMF_groundwater.F90 | 38 +++++++++++++++++----- 2 files changed, 52 insertions(+), 12 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 436311b23..e63727812 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -69,6 +69,7 @@ module Noah_parmsMod character*140 :: mmf_rechclim_dir character*140 :: mmf_riverbed_dir character*140 :: mmf_eqwtd_dir + character*140 :: mmf_hgtm_dir character*50 :: mmf_transform real :: pblh_value @@ -82,6 +83,7 @@ module Noah_parmsMod type(LDT_paramEntry) :: riverbed type(LDT_paramEntry) :: eqwtd type(LDT_paramEntry) :: areaxy + type(LDT_paramEntry) :: hgtm end type noah_type_dec @@ -128,7 +130,7 @@ subroutine NoahParms_init (flag) character*50 :: tbot_proj character*50 :: slopetype_proj type(LDT_fillopts) :: FDEPTH_fillopts, RECHCLIM_fillopts - type(LDT_fillopts) :: RIVERBED_fillopts, EQWTD_fillopts + type(LDT_fillopts) :: RIVERBED_fillopts, EQWTD_fillopts, HGTM_fillopts character*50 :: MMF_proj type(MMF_BCsReader):: MBR @@ -171,7 +173,10 @@ subroutine NoahParms_init (flag) full_name="equilibrium water table depth") call set_param_attribs(Noah_struc(n)%areaxy,"AREAXY",& units="km^2", & - full_name="area of the grid cell") + full_name="area of the grid cell") + call set_param_attribs(Noah_struc(n)%hgtm,"MMF_HGTM",& + units="m MSL", & + full_name="GMTED2010 30-arc-second topography height") endif enddo @@ -498,6 +503,7 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_rechclim_dir, label='MMF climatological recharge dir:', RC=RC) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_riverbed_dir, label='MMF riverbed elevation dir:', RC=RC) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_eqwtd_dir , label='MMF equilibrium water table depth dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_hgtm_dir , label='MMF HGT_M dir:', RC=RC) end do @@ -521,6 +527,9 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) do n = 1,LDT_rc%nnest @@ -529,6 +538,7 @@ subroutine NoahParms_init (flag) allocate (Noah_struc(n)%riverbed%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%riverbed%num_bins)) allocate (Noah_struc(n)%eqwtd%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) allocate (Noah_struc(n)%areaxy%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) + allocate (Noah_struc(n)%hgtm%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%hgtm%num_bins )) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") @@ -572,6 +582,15 @@ subroutine NoahParms_init (flag) LDT_LSMparam_struc(n)%landmask2%value, & EQWTD_fillopts%filltype, EQWTD_fillopts%fillvalue, & EQWTD_fillopts%fillradius ) + + call MBR%mr (n, 'H', trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value ) + call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & + Noah_struc(n)%mmf_transform, & + Noah_struc(n)%hgtm%num_bins, & + Noah_struc(n)%hgtm%value, LDT_rc%udef, & + LDT_LSMparam_struc(n)%landmask2%value, & + HGTM_fillopts%filltype, HGTM_fillopts%fillvalue, & + HGTM_fillopts%fillradius ) ! write areaXY @@ -608,7 +627,7 @@ subroutine NoahParms_writeHeader(n,ftn,dimID) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%riverbed ) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%eqwtd ) call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%areaxy ) - + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%hgtm ) end subroutine NoahParms_writeHeader @@ -631,6 +650,7 @@ subroutine NoahParms_writeData(n,ftn) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%riverbed ) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%eqwtd ) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%areaxy ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%hgtm ) end subroutine NoahParms_writeData diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 2c271d5d0..13c5a0868 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -114,7 +114,8 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) character(len=1024):: geogridFile character(len=80) :: tileName integer :: num_tile_lon,num_tile_lat - integer :: rc,status,tx,ty,txs,txe,tys,tye + integer :: rc,status,tx,ty,txs,txe,tys,tye, bdr + integer :: nlat_tile_bdr, nlon_tile_bdr real,allocatable :: tarray(:,:,:), garray(:,:,:) real :: SF @@ -124,6 +125,7 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) ! set scale factor SF = 1. + bdr = 0 select case (trim(varname)) case ('T') @@ -141,7 +143,12 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) case ('W') ! water table depth SF = -0.03 - + + case ('H') + ! HGT_M + SF = 1. + bdr= 3 + case default write(LDT_logunit,*) '[ERROR] Unknown MMF data field : ', trim (varname) call LDT_endrun @@ -153,7 +160,10 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) num_tile_lon = NX_MMF / nlon_tile num_tile_lat = NY_MMF / nlat_tile - allocate(tarray(nlon_tile,nlat_tile,ntsteps)) + nlon_tile_bdr = nlon_tile + 2*bdr + nlat_tile_bdr = nlat_tile + 2*bdr + + allocate(tarray(nlon_tile_bdr,nlat_tile_bdr,ntsteps)) allocate(garray(NX_MMF, NY_MMF, ntsteps)) garray = LDT_rc%udef ! global array (43200,21600) is constructed by assebling 36x18 # of tarrays (1200,1200) @@ -168,7 +178,17 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) tys = 1 + (ty-1)*nlat_tile tye = ty * nlat_tile - write(tileName, fmt='(4(a1,i5.5))') '/',txs, '-', txe, '.', tys, '-', tye + if(trim(varname) == 'H') then + ! Elevation data x-axis start from the Greenwich line + if(txe <= 21600) then + write(tileName, fmt='(4(a1,i5.5))') '/',txs+21600, '-', txe+21600, '.', tys, '-', tye + else + write(tileName, fmt='(4(a1,i5.5))') '/',txs-21600, '-', txe-21600, '.', tys, '-', tye + endif + else + write(tileName, fmt='(4(a1,i5.5))') '/',txs, '-', txe, '.', tys, '-', tye + endif + geogridFile = trim(datadir)//trim(tileName) rc = read_geogrid(trim(geogridFile),len(trim(geogridFile)),tarray, & @@ -185,7 +205,7 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) tarray = SF * tarray end where - garray(txs:txe,tys:tye,1) = tarray (1:nlon_tile, 1:nlat_tile,1) + garray(txs:txe,tys:tye,1) = tarray (1 + bdr : bdr + nlon_tile, 1 + bdr: bdr + nlat_tile,1) end do TILE_ROWS end do TILE_COLS @@ -281,7 +301,7 @@ END SUBROUTINE mmf_data_reader ! ---------------------------------------------------------------- - SUBROUTINE cell_area_curve (MBR, nest, area) + SUBROUTINE cell_area_line (MBR, nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI @@ -329,11 +349,11 @@ SUBROUTINE cell_area_curve (MBR, nest, area) end do end do - END SUBROUTINE cell_area_curve + END SUBROUTINE cell_area_line ! ---------------------------------------------------------------- - SUBROUTINE cell_area_line (MBR, nest, area) + SUBROUTINE cell_area_curve (MBR, nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI @@ -378,7 +398,7 @@ SUBROUTINE cell_area_line (MBR, nest, area) end do end do - END SUBROUTINE cell_area_line + END SUBROUTINE cell_area_curve ! ---------------------------------------------------------------- From 201f85026110fd6f5163cd3b0ce4e1dde270532d Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 24 Sep 2021 15:41:15 -0400 Subject: [PATCH 010/328] modified to read GEOGRID conversion parameters from the index file in the data directory --- ldt/params/Noah/Noah_parmsMod.F90 | 99 +++---- ldt/params/Noah/module_MMF_groundwater.F90 | 308 +++++++++++++-------- 2 files changed, 218 insertions(+), 189 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index e63727812..b5855180d 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -34,7 +34,7 @@ module Noah_parmsMod use LDT_paramDataMod use LDT_logMod use LDT_paramMaskCheckMod - use MMF_groundwater, ONLY : MMF_BCsReader + use MMF_groundwater, ONLY : MMF_BCsReader, cell_area implicit none @@ -129,10 +129,8 @@ subroutine NoahParms_init (flag) real, allocatable :: force_elev(:,:) character*50 :: tbot_proj character*50 :: slopetype_proj - type(LDT_fillopts) :: FDEPTH_fillopts, RECHCLIM_fillopts - type(LDT_fillopts) :: RIVERBED_fillopts, EQWTD_fillopts, HGTM_fillopts character*50 :: MMF_proj - type(MMF_BCsReader):: MBR + type(MMF_BCsReader):: MBR_FDEPTH, MBR_RECH, MBR_RIVERBED, MBR_WTD, MBR_HGT ! _____________________________________________________________________ @@ -511,25 +509,25 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") - call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, FDEPTH_fillopts%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, RECHCLIM_fillopts%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, RIVERBED_fillopts%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, EQWTD_fillopts%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, HGTM_fillopts%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) do n = 1,LDT_rc%nnest @@ -543,58 +541,25 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") - ! Read in MMF parameters + ! Read in index files in GEOGRID directories and create mapping - call MBR%mi (n, MMF_proj) - - call MBR%mr (n, 'T', trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value ) - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%mmf_transform, & - Noah_struc(n)%fdepth%num_bins, & - Noah_struc(n)%fdepth%value, LDT_rc%udef, & - LDT_LSMparam_struc(n)%landmask2%value, & - FDEPTH_fillopts%filltype, FDEPTH_fillopts%fillvalue, & - FDEPTH_fillopts%fillradius ) - - call MBR%mr (n, 'R', trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value) - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%mmf_transform, & - Noah_struc(n)%rechclim%num_bins, & - Noah_struc(n)%rechclim%value, LDT_rc%udef, & - LDT_LSMparam_struc(n)%landmask2%value, & - RECHCLIM_fillopts%filltype, RECHCLIM_fillopts%fillvalue,& - RECHCLIM_fillopts%fillradius ) - - call MBR%mr (n, 'E', trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value) - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%mmf_transform, & - Noah_struc(n)%riverbed%num_bins, & - Noah_struc(n)%riverbed%value, LDT_rc%udef, & - LDT_LSMparam_struc(n)%landmask2%value, & - RIVERBED_fillopts%filltype, RIVERBED_fillopts%fillvalue,& - RIVERBED_fillopts%fillradius ) - - call MBR%mr (n, 'W', trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value ) - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%mmf_transform, & - Noah_struc(n)%eqwtd%num_bins, & - Noah_struc(n)%eqwtd%value, LDT_rc%udef, & - LDT_LSMparam_struc(n)%landmask2%value, & - EQWTD_fillopts%filltype, EQWTD_fillopts%fillvalue, & - EQWTD_fillopts%fillradius ) - - call MBR%mr (n, 'H', trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value ) - call LDT_contIndivParam_Fill( n, LDT_rc%lnc(n), LDT_rc%lnr(n), & - Noah_struc(n)%mmf_transform, & - Noah_struc(n)%hgtm%num_bins, & - Noah_struc(n)%hgtm%value, LDT_rc%udef, & - LDT_LSMparam_struc(n)%landmask2%value, & - HGTM_fillopts%filltype, HGTM_fillopts%fillvalue, & - HGTM_fillopts%fillradius ) + call MBR_FDEPTH%mi (n, MMF_proj, Noah_struc(n)%mmf_fdepth_dir) + call MBR_RECH%mi (n, MMF_proj, Noah_struc(n)%mmf_rechclim_dir, MBR_FDEPTH%MMF_mapping) + call MBR_RIVERBED%mi (n, MMF_proj, Noah_struc(n)%mmf_riverbed_dir, MBR_FDEPTH%MMF_mapping) + call MBR_WTD%mi (n, MMF_proj, Noah_struc(n)%mmf_eqwtd_dir , MBR_FDEPTH%MMF_mapping) + call MBR_HGT%mi (n, MMF_proj, Noah_struc(n)%mmf_hgtm_dir , MBR_FDEPTH%MMF_mapping) + + ! Read in variables fields + call MBR_FDEPTH%mr (n, trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value , Noah_struc(n)%mmf_transform) + call MBR_RECH%mr (n, trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value, Noah_struc(n)%mmf_transform) + call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform) + call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform) + call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform) + ! write areaXY - call MBR%cell_area (n,Noah_struc(n)%areaxy%value) + call cell_area (n,Noah_struc(n)%areaxy%value) end do diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 13c5a0868..d78ff254b 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -20,192 +20,247 @@ #include "LDT_misc.h" module MMF_groundwater - - use LDT_logMod, only : LDT_logunit, LDT_endrun - use LDT_coreMod, only : LDT_rc, LDT_domain - use LDT_gridmappingMod, only : LDT_RunDomainPts - + + use ESMF + use LDT_logMod, only : LDT_logunit, LDT_endrun, LDT_verify + use LDT_coreMod, only : LDT_rc, LDT_domain + use LDT_gridmappingMod, only : LDT_RunDomainPts + use LDT_paramMaskCheckMod,only : LDT_fillopts, LDT_contIndivParam_Fill + use LDT_paramDataMod, only : LDT_LSMparam_struc implicit none + private - type, public :: MMF_BCsReader - - real, dimension(20) :: param_gridDesc, subparam_gridDesc - integer :: glpnc, glpnr, subpnc, subpnr - integer,allocatable,dimension (:,:) :: lat_line, lon_line, local_mask + integer,parameter :: NX_MMF=43200, NY_MMF = 21600 + + type :: geogrid + + ! defaults + real :: sf = 1. + real :: undef = -9999. + logical:: DE = .true. + integer:: wordsize = 2 + integer:: tile_x = 1200 + integer:: tile_y = 1200 + integer:: tile_z = 1 + integer:: tile_bdr = 0 + integer:: endian = 0 + integer:: iSigned = 1 + end type geogrid + + type, public :: MMF_mapping - contains + real, dimension(20) :: param_gridDesc, subparam_gridDesc + integer :: glpnc, glpnr, subpnc, subpnr + integer, pointer, dimension (:,:):: lat_line, lon_line + + end type MMF_mapping + - procedure, public :: mi => mmf_init - procedure, public :: mr => mmf_data_reader - procedure, public :: cell_area => cell_area_girard + type, public, extends (MMF_mapping) :: MMF_BCsReader + + type(LDT_fillopts), public :: gap_fill + type(geogrid), public :: gp - procedure, private:: cell_area_line - procedure, private:: cell_area_curve - procedure, private:: cell_area_girard + contains + procedure, public :: mi => mmf_init + procedure, public :: mr => mmf_data_reader end type MMF_BCsReader - - integer,parameter :: NY_MMF = 21600 - integer,parameter :: NX_MMF = 43200 -contains + public :: cell_area + + interface cell_area + module procedure cell_area_girard + end interface cell_area - SUBROUTINE mmf_init (MBR, nest, project) +contains + + SUBROUTINE mmf_init (MBR, nest, project, DATADIR, map) implicit none class (MMF_BCsReader), intent(inout) :: MBR + type(MMF_mapping),intent(in),optional:: map integer, intent (in) :: nest character(*), intent (in) :: project + CHARACTER(*), INTENT(IN) :: DATADIR real :: IN_xres, IN_yres - - IN_xres = 360./REAL(NX_MMF) - IN_yres = 180./REAL(NY_MMF) - MBR%param_gridDesc(1) = 0. ! Latlon - MBR%param_gridDesc(2) = real(NX_MMF) - MBR%param_gridDesc(3) = real(NY_MMF) - MBR%param_gridDesc(4) = -90.0 + (IN_yres/2) ! LL lat - MBR%param_gridDesc(5) = -180.0 + (IN_xres/2) ! LL lon - MBR%param_gridDesc(6) = 128 - MBR%param_gridDesc(7) = 90.0 - (IN_yres/2) ! UR lat - MBR%param_gridDesc(8) = 180.0 - (IN_xres/2) ! UR lon - MBR%param_gridDesc(9) = IN_yres - MBR%param_gridDesc(10) = IN_xres - MBR%param_gridDesc(20) = 64 - - ! ------------------------------------------------------------ - ! PREPARE SUBSETTED PARAMETER GRID FOR READING IN BCS DATA - ! ------------------------------------------------------------ - - !- Map Parameter Grid Info to LIS Target Grid/Projection Info -- + real :: dx, dy, known_lon + type(geogrid) :: GG + type(ESMF_Config) :: GCF + integer :: RC + character*3 :: signed + integer, save, allocatable, target, dimension (:,:):: tlat_line, tlon_line + + ! Reads index file for from the GEOGRID data directory for GEOGRID tile information and data conversion + + GCF = ESMF_ConfigCreate(RC=RC) ; call LDT_verify(rc,"mmf_init: create failed." ) + CALL ESMF_ConfigLoadFile (GCF,trim(DATADIR)//'index',rc=rc) ; call LDT_verify(rc,"mmf_init: load index failed.") + CALL ESMF_ConfigGetAttribute (GCF, label='dx:' , VALUE=dx , RC=RC ); call LDT_verify(rc,"mmf_init: dx not defined.") + CALL ESMF_ConfigGetAttribute (GCF, label='dy:' , VALUE=dy , RC=RC ); call LDT_verify(rc,"mmf_init: dy not defined.") + CALL ESMF_ConfigGetAttribute (GCF, label='scale_factor:' , VALUE=MBR%gp%sf ,DEFAULT=GG%sf , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='missing_value:', VALUE=MBR%gp%undef ,DEFAULT=GG%undef , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='wordsize:' , VALUE=MBR%gp%wordsize ,DEFAULT=GG%wordsize , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='tile_x:' , VALUE=MBR%gp%tile_x ,DEFAULT=GG%tile_x , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='tile_y:' , VALUE=MBR%gp%tile_y ,DEFAULT=GG%tile_y , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='tile_z:' , VALUE=MBR%gp%tile_z ,DEFAULT=GG%tile_z , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='tile_bdr:' , VALUE=MBR%gp%tile_bdr ,DEFAULT=GG%tile_bdr , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='signed:' , VALUE=signed ,DEFAULT= 'yes' , RC=RC ) + CALL ESMF_ConfigGetAttribute (GCF, label='known_lon:' , VALUE=known_lon ,DEFAULT= -180. , RC=RC ) + CALL ESMF_ConfigDestroy (GCF, RC=RC) + + if(trim(signed) == 'yes') then + MBR%gp%isigned = 1 + else + MBR%gp%isigned = 0 + endif + + ! the western edge + if(known_lon < -179.) then + MBR%gp%DE = .true. + else + MBR%gp%DE = .false. + endif + + ! Verify NX_MMF, MY_MMF match with dx, dy + if ((NINT (360./dx) /= NX_MMF) .OR. (NINT (180./dy) /= NY_MMF)) then + write(LDT_logunit,*) "[ERR] MMF_INIT: DX, DY are NOT consistent with NX_MMF and NY_MMF" + write(LDT_logunit,*) dx, dy, nx_mmf, ny_mmf + write(LDT_logunit,*) " Programming stopping ..." + call LDT_endrun + endif - MBR%subparam_gridDesc = 0. + if(.not. present (map)) then - call LDT_RunDomainPts( nest, project, MBR%param_gridDesc(:), & - MBR%glpnc, MBR%glpnr, MBR%subpnc, MBR%subpnr, MBR%subparam_gridDesc, & - MBR%lat_line, MBR%lon_line) - + ! NOTE: Since source data array dimensions are the same for all MMF parameters, + ! we run this block once with the first parameter and copy mapping arrays to other parameters. + + ! ------------------------------------------------------------ + ! PREPARE SUBSETTED PARAMETER GRID FOR READING IN BCS DATA + ! ------------------------------------------------------------ + !- Map Parameter Grid Info to LIS Target Grid/Projection Info -- + + IN_xres = 360./REAL(NX_MMF) + IN_yres = 180./REAL(NY_MMF) + MBR%param_gridDesc(1) = 0. ! Latlon + MBR%param_gridDesc(2) = real(NX_MMF) + MBR%param_gridDesc(3) = real(NY_MMF) + MBR%param_gridDesc(4) = -90.0 + (IN_yres/2) ! LL lat + MBR%param_gridDesc(5) = -180.0 + (IN_xres/2) ! LL lon + MBR%param_gridDesc(6) = 128 + MBR%param_gridDesc(7) = 90.0 - (IN_yres/2) ! UR lat + MBR%param_gridDesc(8) = 180.0 - (IN_xres/2) ! UR lon + MBR%param_gridDesc(9) = IN_yres + MBR%param_gridDesc(10) = IN_xres + MBR%param_gridDesc(20) = 64 + + MBR%subparam_gridDesc = 0. + + if(allocated (tlat_line)) deallocate (tlat_line) + if(allocated (tlon_line)) deallocate (tlon_line) + + call LDT_RunDomainPts( nest, project, MBR%param_gridDesc(:), & + MBR%glpnc, MBR%glpnr, MBR%subpnc, MBR%subpnr, MBR%subparam_gridDesc, & + tlat_line, tlon_line) + MBR%lat_line => tlat_line + MBR%lon_line => tlon_line + else + + MBR%param_gridDesc = map%param_gridDesc + MBR%glpnc = map%glpnc + MBR%glpnr = map%glpnr + MBR%subpnc = map%subpnc + MBR%subpnr = map%subpnr + MBR%subparam_gridDesc= map%subparam_gridDesc + MBR%lat_line => map%lat_line + MBR%lon_line => map%lon_line + + endif + END SUBROUTINE mmf_init ! ---------------------------------------------------------------- - SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) + SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) implicit none class (MMF_BCsReader), intent(inout) :: MBR - character(*), intent (in) :: varname, datadir + character(*), intent (in) :: datadir, mmf_transform real, dimension (:,:,:), intent (inout) :: lisout - integer, intent (in) :: nest - - ! Adapted from Zhuo Wang's - ! /discover/nobackup/projects/lis_aist17/zwang9/Geogrid/geogrid2netcdf.f90 - - integer, parameter :: iSigned = 1 - integer, parameter :: endian = 0 - integer, parameter :: wordsize = 2 - integer, parameter :: missing = -9999 - integer, parameter :: ntsteps =1 - integer, parameter :: nlat_tile = 1200 - integer, parameter :: nlon_tile = 1200 + integer, intent (in) :: nest character(len=1024):: geogridFile character(len=80) :: tileName integer :: num_tile_lon,num_tile_lat - integer :: rc,status,tx,ty,txs,txe,tys,tye, bdr - integer :: nlat_tile_bdr, nlon_tile_bdr + integer :: rc,status,tx,ty,txs,txe,tys,tye + integer :: nlat_tile_bdr, nlon_tile_bdr, nbins real,allocatable :: tarray(:,:,:), garray(:,:,:) - real :: SF - + ! c function from Michael G. Duda, NCAR/MMM integer, external :: read_geogrid + ! Adapted from Zhuo Wang's + ! /discover/nobackup/projects/lis_aist17/zwang9/Geogrid/geogrid2netcdf.f90 - ! set scale factor - - SF = 1. - bdr = 0 - select case (trim(varname)) - - case ('T') - ! transmissivity - SF = 0.01 - - case ('R') - ! recharge - SF = 0.03 - - case ('E') - ! river bed elevation - SF = 0.3 - - case ('W') - ! water table depth - SF = -0.03 - - case ('H') - ! HGT_M - SF = 1. - bdr= 3 - - case default - write(LDT_logunit,*) '[ERROR] Unknown MMF data field : ', trim (varname) - call LDT_endrun - end select ! Reading GEOGRID data ! -------------------- - - num_tile_lon = NX_MMF / nlon_tile - num_tile_lat = NY_MMF / nlat_tile - nlon_tile_bdr = nlon_tile + 2*bdr - nlat_tile_bdr = nlat_tile + 2*bdr + num_tile_lon = NX_MMF / MBR%gp%tile_x + num_tile_lat = NY_MMF / MBR%gp%tile_y + + nlon_tile_bdr = MBR%gp%tile_x + 2*MBR%gp%tile_bdr + nlat_tile_bdr = MBR%gp%tile_y + 2*MBR%gp%tile_bdr - allocate(tarray(nlon_tile_bdr,nlat_tile_bdr,ntsteps)) - allocate(garray(NX_MMF, NY_MMF, ntsteps)) + allocate(tarray(nlon_tile_bdr,nlat_tile_bdr,MBR%gp%tile_z)) + allocate(garray(NX_MMF, NY_MMF, MBR%gp%tile_z)) + garray = LDT_rc%udef ! global array (43200,21600) is constructed by assebling 36x18 # of tarrays (1200,1200) TILE_COLS: do tx = 1, num_tile_lon - txs = 1 + (tx-1)*nlon_tile - txe = tx * nlon_tile + txs = 1 + (tx-1)*MBR%gp%tile_x + txe = tx * MBR%gp%tile_x TILE_ROWS: do ty = 1, num_tile_lat - tarray = missing ! GEOGRID tile array 1200,1200 - tys = 1 + (ty-1)*nlat_tile - tye = ty * nlat_tile + tarray = MBR%gp%undef + tys = 1 + (ty-1)*MBR%gp%tile_y + tye = ty * MBR%gp%tile_y - if(trim(varname) == 'H') then + if(MBR%gp%DE) then + ! The western edge is on the dateline + write(tileName, fmt='(4(a1,i5.5))') '/',txs, '-', txe, '.', tys, '-', tye + + else ! Elevation data x-axis start from the Greenwich line if(txe <= 21600) then write(tileName, fmt='(4(a1,i5.5))') '/',txs+21600, '-', txe+21600, '.', tys, '-', tye else write(tileName, fmt='(4(a1,i5.5))') '/',txs-21600, '-', txe-21600, '.', tys, '-', tye endif - else - write(tileName, fmt='(4(a1,i5.5))') '/',txs, '-', txe, '.', tys, '-', tye + endif geogridFile = trim(datadir)//trim(tileName) rc = read_geogrid(trim(geogridFile),len(trim(geogridFile)),tarray, & - nlon_tile,nlat_tile,ntsteps,isigned,endian,1.,wordsize,status) + MBR%gp%tile_x,MBR%gp%tile_y,MBR%gp%tile_z,MBR%gp%isigned,MBR%gp%endian,1.,MBR%gp%wordsize,status) if (rc == 1 .or. status == 1) then write(LDT_logunit,*) '[ERROR] reading GEOGRID file : ',trim(geogridFile) call LDT_endrun end if - where(tarray == missing) + where(tarray == MBR%gp%undef) tarray = LDT_rc%udef elsewhere - tarray = SF * tarray + tarray = MBR%gp%SF * tarray end where - garray(txs:txe,tys:tye,1) = tarray (1 + bdr : bdr + nlon_tile, 1 + bdr: bdr + nlat_tile,1) + garray(txs:txe,tys:tye,1) = tarray (1 + MBR%gp%tile_bdr : MBR%gp%tile_bdr + MBR%gp%tile_x, 1 + MBR%gp%tile_bdr: MBR%gp%tile_bdr + MBR%gp%tile_y,1) end do TILE_ROWS end do TILE_COLS @@ -213,7 +268,19 @@ SUBROUTINE mmf_data_reader (MBR, nest, varname, datadir, lisout) ! regrid garray and construct lisout array on the LIS grid call regrid_to_lisgrid (nest, garray, lisout) - + + ! fill gaps + + nbins = size (lisout, 3) + + call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & + mmf_transform, & + nbins, & + lisout, LDT_rc%udef, & + LDT_LSMparam_struc(nest)%landmask2%value, & + MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & + MBR%gap_fill%fillradius ) + deallocate (tarray, garray) contains @@ -301,14 +368,13 @@ END SUBROUTINE mmf_data_reader ! ---------------------------------------------------------------- - SUBROUTINE cell_area_line (MBR, nest, area) + SUBROUTINE cell_area_line (nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI implicit none - class (MMF_BCsReader), intent(inout) :: MBR integer, intent (in) :: nest real, dimension (:,:,:), intent (inout) :: area integer :: i,j, s @@ -353,14 +419,13 @@ END SUBROUTINE cell_area_line ! ---------------------------------------------------------------- - SUBROUTINE cell_area_curve (MBR, nest, area) + SUBROUTINE cell_area_curve (nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI implicit none - class (MMF_BCsReader), intent(inout) :: MBR integer, intent (in) :: nest real, dimension (:,:,:), intent (inout) :: area integer :: i,j, s @@ -402,14 +467,13 @@ END SUBROUTINE cell_area_curve ! ---------------------------------------------------------------- - SUBROUTINE cell_area_girard (MBR, nest, area) + SUBROUTINE cell_area_girard (nest, area) use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI implicit none - class (MMF_BCsReader), intent(inout) :: MBR integer, intent (in) :: nest real, dimension (:,:,:), intent (inout) :: area integer :: i,j From c47e9f820aef0dcc0a406c6173b3e4c4efc7647e Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Wed, 29 Sep 2021 15:44:14 -0400 Subject: [PATCH 011/328] (1) Matlab's areaint calculation, (2) attempted to follow WPS's two-step gap filling procedure --- ldt/params/Noah/Noah_parmsMod.F90 | 5 + ldt/params/Noah/module_MMF_groundwater.F90 | 317 +++++++++------------ 2 files changed, 132 insertions(+), 190 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index b5855180d..42e98346d 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -509,22 +509,27 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc); call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc); call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc); call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc); call LDT_verify(rc,"EQWTD neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc); call LDT_verify(rc,"HGT_M neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index d78ff254b..4a6ab183d 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -32,10 +32,11 @@ module MMF_groundwater private integer,parameter :: NX_MMF=43200, NY_MMF = 21600 - + + ! defaults parameters for GEOGRID tiles based on the FDEPTH data set + ! ------------------------------------------------------------------ type :: geogrid - ! defaults real :: sf = 1. real :: undef = -9999. logical:: DE = .true. @@ -48,19 +49,23 @@ module MMF_groundwater integer:: iSigned = 1 end type geogrid - + + ! MMF grid to LIS grid mapping + ! ---------------------------- type, public :: MMF_mapping - + real, dimension(20) :: param_gridDesc, subparam_gridDesc integer :: glpnc, glpnr, subpnc, subpnr integer, pointer, dimension (:,:):: lat_line, lon_line end type MMF_mapping - + ! MMF data reader Fortran object + ! ------------------------------ type, public, extends (MMF_mapping) :: MMF_BCsReader type(LDT_fillopts), public :: gap_fill + type(LDT_fillopts), public :: neighbor type(geogrid), public :: gp contains @@ -70,12 +75,10 @@ module MMF_groundwater end type MMF_BCsReader + ! Grid cell area + ! -------------- public :: cell_area - - interface cell_area - module procedure cell_area_girard - end interface cell_area - + contains SUBROUTINE mmf_init (MBR, nest, project, DATADIR, map) @@ -124,6 +127,10 @@ SUBROUTINE mmf_init (MBR, nest, project, DATADIR, map) else MBR%gp%DE = .false. endif + + ! For WPS's two-step gap filling, first we attempt fill using averaged value from the immedeate neighborhood. + MBR%neighbor%filltype = 'average' + MBR%neighbor%fillvalue = LDT_rc%udef ! Verify NX_MMF, MY_MMF match with dx, dy if ((NINT (360./dx) /= NX_MMF) .OR. (NINT (180./dy) /= NY_MMF)) then @@ -273,14 +280,29 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) nbins = size (lisout, 3) - call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & + ! WPS's STEP1 : average from the nerighborhood + ! -------------------------------------------- + call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & mmf_transform, & nbins, & lisout, LDT_rc%udef, & LDT_LSMparam_struc(nest)%landmask2%value, & - MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & - MBR%gap_fill%fillradius ) - + MBR%neighbor%filltype, MBR%neighbor%fillvalue, & + MBR%neighbor%fillradius ) + + + ! WPS's STEP2 : Search and fill + ! ----------------------------- + + if (trim (MBR%gap_fill%filltype) /= 'none') then + call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & + mmf_transform, & + nbins, & + lisout, LDT_rc%udef, & + LDT_LSMparam_struc(nest)%landmask2%value, & + MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & + MBR%gap_fill%fillradius ) + endif deallocate (tarray, garray) contains @@ -368,107 +390,8 @@ END SUBROUTINE mmf_data_reader ! ---------------------------------------------------------------- - SUBROUTINE cell_area_line (nest, area) - - use map_utils, only : ij_to_latlon - use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI - - implicit none - - integer, intent (in) :: nest - real, dimension (:,:,:), intent (inout) :: area - integer :: i,j, s - real, parameter :: nstrips = 100. - real :: lat_ll, lat_ur , lat_ul, lat_lr - real :: lon_ll, lon_ur , lon_ul, lon_lr - real :: c, r, d2r, dx, dyl, dyu, w_edge, e_edge, lat1, lat2 - - d2r = PI/180. - area = 0. - - do j = 1, LDT_rc%lnr(nest) - do i = 1, LDT_rc%lnc(nest) - - r = float (j) - c = float (i) - - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner - - w_edge = (lon_ll + lon_ul) / 2. - e_edge = (lon_lr + lon_ur) / 2. - - dyl= (lat_lr - lat_ll) / nstrips - dyu= (lat_ur - lat_ul) / nstrips - dx = (e_edge - w_edge) / nstrips - - do s = 1, nstrips - - lat1 = lat_ll + (s-1)*dyl + dyl/2. - lat2 = lat_ul + (s-1)*dyu + dyu/2. - area (i,j,1) = area (i,j,1) + (sin(d2r* lat2) - sin(d2r*lat1))*radius*radius*dx*d2r/1000./1000. ! [km2] - - end do - - end do - end do - - END SUBROUTINE cell_area_line - - ! ---------------------------------------------------------------- - - SUBROUTINE cell_area_curve (nest, area) - - use map_utils, only : ij_to_latlon - use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI - - implicit none - - integer, intent (in) :: nest - real, dimension (:,:,:), intent (inout) :: area - integer :: i,j, s - real, parameter :: nstrips = 100. - real :: lat_ll, lat_ur , lat_ul, lat_lr - real :: lon_ll, lon_ur , lon_ul, lon_lr - real :: c, r, d2r, dx, dw, w_edge, e_edge, lat1, lat2 - - d2r = PI/180. - area = 0. - - do j = 1, LDT_rc%lnr(nest) - do i = 1, LDT_rc%lnc(nest) - - r = float (j) - c = float (i) - - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner - - w_edge = (lon_ll + lon_ul) / 2. - e_edge = (lon_lr + lon_ur) / 2. - - dx = (e_edge - w_edge) / nstrips - dw = 1./nstrips - do s = 1, nstrips - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5 + dw/2. + (s-1)*dw, r-0.5, lat1, lon_ll) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5 + dw/2. + (s-1)*dw, r+0.5, lat2, lon_ll) - area (i,j,1) = area (i,j,1) + (sin(d2r* lat2) - sin(d2r*lat1))*radius*radius*dx*d2r/1000./1000. ! [km2] - - end do - - end do - end do - - END SUBROUTINE cell_area_curve - - ! ---------------------------------------------------------------- + SUBROUTINE cell_area (nest, area) - SUBROUTINE cell_area_girard (nest, area) - use map_utils, only : ij_to_latlon use LDT_constantsMod, ONLY : radius => LDT_CONST_REARTH, pi => LDT_CONST_PI @@ -478,9 +401,8 @@ SUBROUTINE cell_area_girard (nest, area) real, dimension (:,:,:), intent (inout) :: area integer :: i,j real :: lat_ll, lat_ur , lat_ul, lat_lr, c, r - real :: lon_ll, lon_ur , lon_ul, lon_lr, lat, lon - real :: ab, bc, cd, da, ac ! side lengths - + real :: lon_ll, lon_ur , lon_ul, lon_lr + area = 0. do j = 1, LDT_rc%lnr(nest) @@ -488,95 +410,110 @@ SUBROUTINE cell_area_girard (nest, area) r = float (j) c = float (i) - - if(trim(LDT_rc%lis_map_proj(nest)) == 'latlon') then - - call ij_to_latlon(LDT_domain(nest)%ldtproj,c , r, lat, lon) ! center - area (i,j,1) = radius * radius * & - (sin(d2r(lat + 0.5*LDT_rc%gridDesc(nest,10))) - & - sin(d2r(lat - 0.5*LDT_rc%gridDesc(nest,10))))* & - (d2r(LDT_rc%gridDesc(nest,9)))/1000./1000. ! [km2] - - else - - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) - - ! side lengths - ab = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ul), d2r(lon_ul)) - bc = haversine(d2r(lat_ul), d2r(lon_ul), d2r(lat_ur), d2r(lon_ur)) - cd = haversine(d2r(lat_ur), d2r(lon_ur), d2r(lat_lr), d2r(lon_lr)) - da = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_lr), d2r(lon_lr)) - ac = haversine(d2r(lat_ll), d2r(lon_ll), d2r(lat_ur), d2r(lon_ur)) - - ! area = ABC area + ACD area - - area (i,j,1) = radius * radius * & - (triangle_area (ac, ab, bc) + triangle_area(ac, cd, da))/1000./1000. ! [km2] - endif + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) + area (i,j,1) = 4.*pi*radius*radius* areaint((/lat_ll, lat_ul, lat_ur, lat_lr/), (/lon_ll, lon_ul, lon_ur, lon_lr/))/1000./1000. end do end do - + contains - ! ***************************************************************************** - - real function haversine(deglat1,deglon1,deglat2,deglon2) - ! great circle distance - real,intent(in) :: deglat1,deglon1,deglat2,deglon2 - real :: a,c, dlat,dlon,lat1,lat2 - - dlat = deglat2-deglat1 - dlon = deglon2-deglon1 - lat1 = deglat1 - lat2 = deglat2 - a = (sin(dlat/2))**2 + cos(lat1)*cos(lat2)*(sin(dlon/2))**2 - if(a>=0. .and. a<=1.) then - c = 2*atan2(sqrt(a),sqrt(1-a)) - haversine = c ! [per unit radius] - else - haversine = 1.e20 - endif - end function haversine - - - ! ***************************************************************************** + ! ---------------------------------------------------------------- - function triangle_area (c, a, b) result(ABC_area) + real FUNCTION areaint (lat, lon) + + + ! simplified from Matlab's areaint.m to compute area of a single polygon + ! AREAINT Surface area of polygon on sphere + ! A = AREAINT(LAT,LON) calculates the spherical surface area of the + ! polygon specified by the input vectors LAT, LON. LAT and LON are in + ! degrees. The calculation uses a line integral approach. The output, + ! A, is the surface area fraction covered by the polygon on a unit + ! sphere. + + implicit none + real, intent(in), dimension(:) :: lat, lon + real, allocatable , dimension (:) :: latc, lonc, colat, az, integrands + real :: lat0,lon0,dlat,dlon,a,deltas,daz,colat2 + integer :: n, i + + n = size (lat) + 1 + allocate (latc (1:n)) + allocate (lonc (1:n)) + allocate (colat(1:n)) + allocate (az (1:n)) + + latc(1:n-1) = lat + lonc(1:n-1) = lon + latc(n) = lat(1) + lonc(n) = lon(1) + lat0 = 0. + lon0 = 0. + + ! greatcircle distance, and greatcircle azimuth wrt 0.,0 (Matlab's distance.m) + ! ---------------------------------------------------------------------------- + + do i = 1,n + + latc(i) = d2r(latc(i)) + lonc(i) = d2r(lonc(i)) + dlat = latc(i) - lat0 + dlon = lonc(i) - lon0 - ! degrees to radians - real,intent(in) :: c, a, b - real :: ACB, ABC_area - - ! The spherical law of cosines per unit radius - ACB = acos ((cos(c) - cos(a) * cos(b)) / sin(a) / sin (b)) - - ! Area = spherical excess per unit radius - ABC_area = ABS(2.* atan( tan(a/2.)*tan(b/2.)*sin(ACB) / & - (1. + tan(a/2.)*tan(b/2.)*cos(ACB)))) - - end function triangle_area + ! haversine + a = (sin(dlat/2.))**2 + cos(lat0)*cos(latc(i))*(sin(dlon/2.))**2 + if(a < 0.) a =0. + if(a > 1.) a =1. + + colat(i) = 2.*atan2(sqrt(a),sqrt(1.-a)) + az(i) = atan2(cos(latc(i)) * sin(lonc(i)-lon0), & + cos(lat0) * sin(latc(i)) - sin(lat0) * cos(latc(i))* cos(lonc(i)-lon0)) + ! wrap az to the range 0-2pi + az(i) = az(i) - 2.*pi*floor(az(i)/2./pi) + + end do + + n = n -1 + allocate (integrands (1:n)) + + do i = 1, n + + ! Calculate step sizes + daz = az(i+1) - az(i) + ! wrap to -pi <= daz <=pi + daz = daz - 2.*pi*floor((daz+pi)/2./pi) + + ! Determine average surface distance for each step + deltas = (colat (i+1) - colat (i))/2. + colat2 = colat(i) + deltas + + ! Integral over azimuth is 1-cos(colatitudes) + integrands (i) = (1. - cos(colat2)) * daz + end do + + areaint = abs (sum (integrands))/4./pi + areaint = MIN (areaint, 1. - areaint) + deallocate (integrands, latc, lonc, colat, az) + + end FUNCTION areaint - ! ***************************************************************************** + ! ---------------------------------------------------------------- function d2r (degree) result(rad) - + ! degrees to radians real,intent(in) :: degree real :: rad - + rad = degree*PI/180. - - end function d2r - END SUBROUTINE cell_area_girard - - ! ---------------------------------------------------------------- - + end function d2r + end SUBROUTINE cell_area + end module MMF_groundwater From 7f6df33b6b89d5432c4e8d574617fcc2ac1cbc9f Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Thu, 14 Oct 2021 12:30:11 -0400 Subject: [PATCH 012/328] further modified AREAXY calculation tmatch WPS --- ldt/params/Noah/module_MMF_groundwater.F90 | 73 +++++++++++++++++++--- 1 file changed, 63 insertions(+), 10 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 4a6ab183d..f4959b4dd 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -14,7 +14,7 @@ ! ! !REVISION HISTORY: ! 27 Aug 2021: Sarith Mahanama -! with inputs from David Mocko, Zhuo Wang ; Initial Specification +! with inputs from David Mocko, Shugong Wang, Timothy Lahmers, Kristi Arsenault, and Zhuo Wang ; Initial Specification ! ! !INTERFACE: @@ -23,7 +23,7 @@ module MMF_groundwater use ESMF use LDT_logMod, only : LDT_logunit, LDT_endrun, LDT_verify - use LDT_coreMod, only : LDT_rc, LDT_domain + use LDT_coreMod, only : LDT_rc, LDT_domain, LDT_config use LDT_gridmappingMod, only : LDT_RunDomainPts use LDT_paramMaskCheckMod,only : LDT_fillopts, LDT_contIndivParam_Fill use LDT_paramDataMod, only : LDT_LSMparam_struc @@ -397,12 +397,18 @@ SUBROUTINE cell_area (nest, area) implicit none + ! interface grid_cell_area + ! module procedure area_latlon + ! module procedure areaint + ! module procedure area_wps + ! end interface grid_cell_area + integer, intent (in) :: nest real, dimension (:,:,:), intent (inout) :: area integer :: i,j real :: lat_ll, lat_ur , lat_ul, lat_lr, c, r real :: lon_ll, lon_ur , lon_ul, lon_lr - + area = 0. do j = 1, LDT_rc%lnr(nest) @@ -411,17 +417,62 @@ SUBROUTINE cell_area (nest, area) r = float (j) c = float (i) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) - call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) - area (i,j,1) = 4.*pi*radius*radius* areaint((/lat_ll, lat_ul, lat_ur, lat_lr/), (/lon_ll, lon_ul, lon_ur, lon_lr/))/1000./1000. - + select case (LDT_domain(nest)%ldtproj%code) + case (0) + ! lat/lon + call ij_to_latlon(LDT_domain(nest)%ldtproj,c, r, lat_ll, lon_ll) + area (i,j,1) = area_latlon (nest, lat_ll) + + case (3) + ! Lambert conical follows WPS + area (i,j,1) = area_wps () + + case DEFAULT + ! Area of a polygon areaint.m from Matlab + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r-0.5, lat_ll, lon_ll) ! SW corner (A) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c-0.5, r+0.5, lat_ul, lon_ul) ! NW corner (B) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r+0.5, lat_ur, lon_ur) ! NE corner (C) + call ij_to_latlon(LDT_domain(nest)%ldtproj,c+0.5, r-0.5, lat_lr, lon_lr) ! SE corner (D) + area (i,j,1) = areaint((/lat_ll, lat_ul, lat_ur, lat_lr/), (/lon_ll, lon_ul, lon_ur, lon_lr/)) + + END select end do end do contains + ! ---------------------------------------------------------------- + + real function area_latlon (nest, lat) + + implicit none + + real, intent (in) :: lat + integer, intent (in) :: nest + + area_latlon = radius * radius * & + (sin(d2r(lat + 0.5*LDT_rc%gridDesc(nest,10))) - & + sin(d2r(lat - 0.5*LDT_rc%gridDesc(nest,10))))* & + d2r(LDT_rc%gridDesc(nest,9))/1000./1000. ! [km2] + + end function area_latlon + + ! ---------------------------------------------------------------- + + real function area_wps () + + implicit none + integer :: rc + real :: DXY, MSFTX, MSFTY + + MSFTY = 1. + MSFTX = 1. + + call ESMF_ConfigGetAttribute(LDT_config, DXY,label='Run domain resolution:', rc=rc); call LDT_verify(rc,"Run domain resolution of the Lambert grid is not defined.") + area_wps = DXY*DXY/MSFTX/MSFTY + + end function area_wps + ! ---------------------------------------------------------------- real FUNCTION areaint (lat, lon) @@ -496,7 +547,8 @@ real FUNCTION areaint (lat, lon) end do areaint = abs (sum (integrands))/4./pi - areaint = MIN (areaint, 1. - areaint) + areaint = 4.*pi*radius*radius * MIN (areaint, 1. - areaint) /1000./1000. + deallocate (integrands, latc, lonc, colat, az) end FUNCTION areaint @@ -512,6 +564,7 @@ function d2r (degree) result(rad) rad = degree*PI/180. end function d2r + end SUBROUTINE cell_area end module MMF_groundwater From 469e69fbd7b3100e36fa4bd600077036ab0a0f57 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 29 Oct 2021 08:28:56 -0400 Subject: [PATCH 013/328] gridDesc(nest,9) and gridDesc(nest,10) were swapped. It was fixed. --- ldt/params/Noah/module_MMF_groundwater.F90 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index f4959b4dd..6f2df2460 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -451,9 +451,9 @@ real function area_latlon (nest, lat) integer, intent (in) :: nest area_latlon = radius * radius * & - (sin(d2r(lat + 0.5*LDT_rc%gridDesc(nest,10))) - & - sin(d2r(lat - 0.5*LDT_rc%gridDesc(nest,10))))* & - d2r(LDT_rc%gridDesc(nest,9))/1000./1000. ! [km2] + (sin(d2r(lat + 0.5*LDT_rc%gridDesc(nest,9))) - & + sin(d2r(lat - 0.5*LDT_rc%gridDesc(nest,9))))* & + d2r(LDT_rc%gridDesc(nest,10))/1000./1000. ! [km2] end function area_latlon From f7ebdda01066518960fc54628eeb34c612943e88 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 30 Nov 2021 18:29:34 -0500 Subject: [PATCH 014/328] Added support to compute mean, sigma, Drange, and CDF for precipitation output --- .../LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 | 340 ++++++++++ .../LISlsmPrecipobs/readLISlsmPrecipobs.F90 | 591 ++++++++++++++++++ ldt/core/LDT_DAmetricsMod.F90 | 3 + ldt/core/LDT_DAobsDataMod.F90 | 9 +- ldt/core/LDT_DAobservationsMod.F90 | 1 + ldt/make/Filepath | 2 +- ldt/plugins/LDT_DAobs_pluginMod.F90 | 7 +- ldt/plugins/LDT_pluginIndices.F90 | 3 + 8 files changed, 952 insertions(+), 4 deletions(-) create mode 100644 ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 create mode 100644 ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 diff --git a/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 new file mode 100644 index 000000000..8a647f7bf --- /dev/null +++ b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 @@ -0,0 +1,340 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +module LISlsmPrecip_obsMod +!BOP +! +! !MODULE: LISlsmPrecip_obsMod +! +! !DESCRIPTION: +! This module handles the use of a LIS model simulation +! output as "observations" for data assimilation. This +! plugin is typically used to handle the computations of +! scaling factors such as cumulative distribution function +! (CDF) for use in DA +! +! !REVISION HISTORY: +! 16 Nov 2021 Mahdi Navari Initial Specification +! + + PRIVATE +!----------------------------------------------------------------------------- +! !PUBLIC MEMBER FUNCTIONS: +!----------------------------------------------------------------------------- + PUBLIC :: LISlsmPrecip_obsInit +!----------------------------------------------------------------------------- +! !PUBLIC TYPES: +!----------------------------------------------------------------------------- + PUBLIC :: lsmprecipobs +! +!EOP + + type, public :: lsmprecipobsdec + integer :: nvars + integer :: nest + integer :: nc,nr + real :: datares + real :: run_dd(8) + character*50 :: map_proj + character*50 :: format + character*50 :: wstyle + character*50 :: wopt + character*100 :: odir + character*20 :: security_class + character*20 :: distribution_class + character*20 :: data_category + character*20 :: area_of_data + character*20 :: write_interval +!-------------------------------------------------------- +! interpolation/upscaling weights +!-------------------------------------------------------- + integer, allocatable :: n11(:) + integer, allocatable :: n12(:) + integer, allocatable :: n21(:) + integer, allocatable :: n22(:) + real, allocatable :: w11(:) + real, allocatable :: w12(:) + real, allocatable :: w21(:) + real, allocatable :: w22(:) + + end type lsmprecipobsdec + + type(lsmprecipobsdec) :: lsmprecipobs + +contains + +!BOP +! !ROUTINE: LISlsmPrecip_obsInit +! \label{LISlsmPrecip_obsInit} +! +! !INTERFACE: + subroutine LISlsmPrecip_obsInit() +! !USES: + use ESMF + use LDT_coreMod + use LDT_DAobsDataMod + use LDT_logMod + + implicit none +! +! !DESCRIPTION: +! This routine initializes the structures required for the handling of a +! land surface model output (from a LIS simulation) as observations. +! +!EOP + integer :: n + integer :: rc + real :: gridDesci(20) + + n = 1 + + lsmprecipobs%run_dd = LDT_rc%udef + + lsmprecipobs%security_class = '' + lsmprecipobs%distribution_class = '' + lsmprecipobs%data_category = '' + lsmprecipobs%area_of_data = '' + lsmprecipobs%write_interval = '' + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%format, & + label="LIS precipitation output format:",rc=rc) + call LDT_verify(rc,'LIS precipitation output format: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%wopt, & + label="LIS precipitation output methodology:",rc=rc) + call LDT_verify(rc,'LIS precipitation output methodology: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%wstyle, & + label="LIS precipitation output naming style:",rc=rc) + call LDT_verify(rc,'LIS precipitation output naming style: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%map_proj, & + label="LIS precipitation output map projection:",rc=rc) + call LDT_verify(rc,'LIS precipitation output map projection: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%nest, & + label="LIS precipitation output nest index:",rc=rc) + call LDT_verify(rc,'LIS precipitation output nest index: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%odir, & + label="LIS precipitation output directory:",rc=rc) + call LDT_verify(rc,'LIS precipitation output directory: not defined') + + ! WMO-convention specific identifiers + if ( lsmprecipobs%wstyle == "WMO convention") then + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%security_class, & + label="LIS precipitation security class:",rc=rc) + call LDT_verify(rc,'LIS precipitation security class: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%distribution_class, & + label="LIS precipitation distribution class:",rc=rc) + call LDT_verify(rc,'LIS precipitation distribution class: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%data_category, & + label="LIS precipitation data category:",rc=rc) + call LDT_verify(rc,'LIS precipitation data category: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%area_of_data, & + label="LIS precipitation area of data:",rc=rc) + call LDT_verify(rc,'LIS precipitation area of data: not defined') + + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%write_interval, & + label="LIS precipitation write interval:",rc=rc) + call LDT_verify(rc,'LIS precipitation write interval: not defined') + endif + + if(lsmprecipobs%map_proj.eq."latlon") then + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lat:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(1),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(2),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain upper right lat:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(3),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain upper right lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(4),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain resolution (dx):",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(5),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain resolution (dy):",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(6),rc=rc) + + lsmprecipobs%datares = min(lsmprecipobs%run_dd(5),lsmprecipobs%run_dd(6)) + + lsmprecipobs%nc = (nint((lsmprecipobs%run_dd(4)-lsmprecipobs%run_dd(2))/& + lsmprecipobs%run_dd(5))) + 1 + lsmprecipobs%nr = (nint((lsmprecipobs%run_dd(3)-lsmprecipobs%run_dd(1))/& + lsmprecipobs%run_dd(6))) + 1 + + gridDesci = 0 + gridDesci(1) = 0 + gridDesci(2) = lsmprecipobs%nc + gridDesci(3) = lsmprecipobs%nr + gridDesci(4) = lsmprecipobs%run_dd(1) + gridDesci(5) = lsmprecipobs%run_dd(2) + gridDesci(6) = 128 + gridDesci(7) = lsmprecipobs%run_dd(3) + gridDesci(8) = lsmprecipobs%run_dd(4) + gridDesci(9) = lsmprecipobs%run_dd(5) + gridDesci(10) = lsmprecipobs%run_dd(6) + gridDesci(20) = 64 + + elseif(lsmprecipobs%map_proj.eq."lambert") then + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lat:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(1),rc=rc) + call LDT_verify(rc,'LIS precipitation domain lower left lat: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(2),rc=rc) + call LDT_verify(rc,'LIS precipitation domain lower left lon: not defined') + + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain true lat1:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(3),rc=rc) + call LDT_verify(rc,'LIS precipitation domain true lat1: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain true lat2:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(4),rc=rc) + call LDT_verify(rc,'LIS precipitation domain true lat2: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain standard lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(5),rc=rc) + call LDT_verify(rc,'LIS precipitation domain standard lon: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain resolution:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(6),rc=rc) + call LDT_verify(rc,'LIS precipitation domain resolution: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain x-dimension size:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(7),rc=rc) + call LDT_verify(rc,'LIS precipitation domain x-dimension size: not defined') + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain y-dimension size:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(8),rc=rc) + call LDT_verify(rc,'LIS precipitation domain y-dimension size: not defined') + + lsmprecipobs%datares = lsmprecipobs%run_dd(6)/100.0 + + lsmprecipobs%nc = lsmprecipobs%run_dd(7) + lsmprecipobs%nr = lsmprecipobs%run_dd(8) + + gridDesci = 0 + gridDesci(1) = 3 + gridDesci(2) = lsmprecipobs%nc + gridDesci(3) = lsmprecipobs%nr + gridDesci(4) = lsmprecipobs%run_dd(1) + gridDesci(5) = lsmprecipobs%run_dd(2) + gridDesci(6) = 8 + gridDesci(7) = lsmprecipobs%run_dd(4) + gridDesci(8) = lsmprecipobs%run_dd(6) + gridDesci(9) = lsmprecipobs%run_dd(6) + gridDesci(10) = lsmprecipobs%run_dd(3) + gridDesci(11) = lsmprecipobs%run_dd(5) + gridDesci(20) = 64 + + elseif(lsmprecipobs%map_proj.eq."polar") then + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lat:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(1),rc=rc) + + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain lower left lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(2),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain true lat1:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(3),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain true lat2:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(4),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain standard lon:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(5),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain resolution:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(6),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain x-dimension size:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(7),rc=rc) + + call ESMF_ConfigFindLabel(LDT_config,& + "LIS precipitation domain y-dimension size:",rc=rc) + call ESMF_ConfigGetAttribute(LDT_config,lsmprecipobs%run_dd(8),rc=rc) + + endif + +!------------------------------------------------------------------- +! if the LIS output (obs) is at a coarser resolution than the +! LDT grid, then setup the weights for interpolation. Else +! setup the weights for upscaling. +!------------------------------------------------------------------- + if(LDT_isLDTatAfinerResolution(n,lsmprecipobs%datares)) then + + allocate(lsmprecipobs%n11(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%n12(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%n21(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%n22(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + + allocate(lsmprecipobs%w11(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%w12(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%w21(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + allocate(lsmprecipobs%w22(LDT_rc%lnc(n)*LDT_rc%lnr(n))) + + call bilinear_interp_input(n, gridDesci, & + lsmprecipobs%n11, & + lsmprecipobs%n12, lsmprecipobs%n21, & + lsmprecipobs%n22, lsmprecipobs%w11, & + lsmprecipobs%w12, lsmprecipobs%w21, & + lsmprecipobs%w22) + + else + + allocate(lsmprecipobs%n11(& + lsmprecipobs%nc*& + lsmprecipobs%nr)) + + call upscaleByAveraging_input(& + gridDesci,& + LDT_rc%gridDesc(n,:),& + lsmprecipobs%nc*lsmprecipobs%nr,& + LDT_rc%lnc(n)*LDT_rc%lnr(n),& + lsmprecipobs%n11) + + endif + +! which variable we want in the DA obs computations. + call LDT_initializeDAobsEntry(LDT_DAobsData(1)%totalprecip_obs, "kg m-2",1,1) + LDT_DAobsData(1)%totalprecip_obs%selectStats = 1 + + end subroutine LISlsmPrecip_obsInit + +end module LISlsmPrecip_obsMod diff --git a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 new file mode 100644 index 000000000..40e462191 --- /dev/null +++ b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 @@ -0,0 +1,591 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LDT_misc.h" +!BOP +! +! !ROUTINE: readLISlsmPrecipobs +! \label{readLISlsmPrecipobs} +! +! !INTERFACE: +subroutine readLISlsmPrecipobs(n) +! !USES: +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif +#if (defined USE_GRIBAPI) + use grib_api +#endif + use LDT_coreMod + use LDT_DAobsDataMod + use LDT_historyMod + use LDT_logMod + use LISlsmPrecip_obsMod, only : lsmprecipobs +! +! !DESCRIPTION: +! This routine reads the total precipitation fields from a LIS model +! simulation. +! +!EOP + implicit none + + integer, intent(in) :: n + + character*200 :: fname + logical :: file_exists + real :: precip_data(LDT_rc%lnc(n),LDT_rc%lnr(n)) + + integer :: t, index + integer :: ftn + integer :: iret + real :: topLev,botLev,param_num,trange + integer :: igrib,nvars + real :: precipvalue1d(lsmprecipobs%nc*lsmprecipobs%nr) + real :: precipvalue2d(lsmprecipobs%nc, lsmprecipobs%nr) + integer :: c,r + character*20 :: vname + integer :: varid + + interface + subroutine create_lsm_output_fname(n, form, fname, odir, wstyle, wopt, & + run_dd, map_proj, security_class, & + distribution_class, data_category, & + area_of_data, write_interval) + integer, intent(IN) :: n + character(len=*) :: fname + character(len=*) :: form + character(len=*) :: odir + character(len=*) :: wstyle + character(len=*) :: wopt + real, dimension(8), optional :: run_dd + character(len=*), optional :: map_proj + character(len=*), optional :: security_class + character(len=*), optional :: distribution_class + character(len=*), optional :: data_category + character(len=*), optional :: area_of_data + character(len=*), optional :: write_interval + end subroutine create_lsm_output_fname + end interface + + +#if (defined USE_GRIBAPI) + precip_data = LDT_rc%udef + + call create_lsm_output_fname(lsmprecipobs%nest, & + lsmprecipobs%format, & + fname, & + lsmprecipobs%odir, & + lsmprecipobs%wstyle, & + lsmprecipobs%wopt, & + lsmprecipobs%run_dd, & + lsmprecipobs%map_proj, & + lsmprecipobs%security_class, & + lsmprecipobs%distribution_class, & + lsmprecipobs%data_category, & + lsmprecipobs%area_of_data, & + lsmprecipobs%write_interval) + + inquire(file=trim(fname),exist=file_exists) + + if(file_exists) then + write(LDT_logunit,*) '[INFO] reading LSM output ',trim(fname) + if(lsmprecipobs%format.eq."binary") then + write(LDT_logunit,*) '[ERR] DA preprocessing on the binary format is not ' + write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' + call LDT_endrun() + +#if 0 + ftn = LDT_getNextUnitNumber() + open(ftn,file=trim(fname), form='unformatted') + if(file_exists) then + do index=1,LDT_MOC_COUNT + call LDT_readLISSingleBinaryVar(n,ftn,LDT_DAobsDataPtr(n,index)%dataEntryPtr) + enddo + else + print*, 'LSM file ',trim(fname),' does not exist' + print*, 'Program stopping.. ' + stop + endif + call LDT_releaseUnitNumber(ftn) +#endif + elseif(lsmprecipobs%format.eq."grib1") then + if(lsmprecipobs%wstyle.ne."WMO convention") then + write(LDT_logunit,*) '[ERR] LDT currently does not support this style of grib output' + call LDT_endrun + endif + + call grib_open_file(ftn,trim(fname),'r',iret) + if(iret.ne.0) then + write(LDT_logunit,*) '[ERR] Could not open file: ',trim(fname) + call LDT_endrun() + endif + call grib_multi_support_on + + do + call grib_new_from_file(ftn,igrib,iret) + if(iret==GRIB_END_OF_FILE) then + exit + endif + + call grib_get(igrib, 'indicatorOfParameter',param_num, iret) + call LDT_verify(iret, & + 'grib_get: indicatorOfParameter failed in readLISlsmPrecipObs') + + call grib_get(igrib, 'topLevel',topLev, iret) + call LDT_verify(iret, & + 'grib_get: topLevel failed in readLISlsmPrecipObs') + + call grib_get(igrib, 'bottomLevel',botLev, iret) + call LDT_verify(iret, & + 'grib_get: bottomLevel failed in readLISlsmPrecipObs') + + call grib_get(igrib, 'timeRangeIndicator',trange, iret) + call LDT_verify(iret, & + 'grib_get: timeRangeIndicator failed in readLISlsmPrecipObs') + +!right now specifically geared for AFWA outputs. + if(param_num.eq.201.and.topLev.eq.0.and.botlev.eq.10.and.& + trange.eq.1) then + + call grib_get(igrib,'values',precipvalue1d,iret) + call LDT_verify(iret,& + 'grib_get: values failed in readLISlsmSMobs') + + call transformPrecipDataToLDTgrid(n,precipvalue1d,precip_data) + + endif + + call grib_release(igrib,iret) + call LDT_verify(iret, 'error in grib_release in readLISlsmSMObs') + enddo + + call grib_close_file(ftn) + + elseif(lsmprecipobs%format.eq."netcdf") then +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + + iret = nf90_open(path=trim(fname),mode=nf90_nowrite, ncid=ftn) + call LDT_verify(iret, 'Error opening file '//trim(fname)) + +! The code looks for instantaneous variables. If it doesn't exist, +! the time averaged data fields will be read in. + + iret = nf90_inq_varid(ftn, 'TotalPrecip_inst', varid) + vname = 'TotalPrecip_inst' + if(iret.ne.0) then + vname = 'TotalPrecip_tavg' + endif + + if(lsmprecipobs%datares.eq.LDT_rc%gridDesc(n,10)) then + call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + 1,lsmprecipobs%nc, lsmprecipobs%nr, precipvalue2d) + else + call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + 1,lsmprecipobs%nc, lsmprecipobs%nr, precipvalue2d) + endif + + iret = nf90_close(ftn) + call LDT_verify(iret,'Error in nf90_close') + + do r=1,lsmprecipobs%nr + do c=1, lsmprecipobs%nc + precipvalue1d(c+(r-1)*lsmprecipobs%nc) = precipvalue2d(c,r) + enddo + enddo + + call transformPrecipDataToLDTgrid(n,precipvalue1d,precip_data) + +#endif + endif + else + write(LDT_logunit,*) '[WARN] LIS file '//trim(fname) + write(LDT_logunit,*) '[WARN] not found ...' + precip_data = LDT_rc%udef + endif + + call LDT_logSingleDAobs(n,LDT_DAobsData(1)%totalprecip_obs,& + precip_data,vlevel=1) + +#endif +end subroutine readLISlsmPrecipobs + + +!BOP +! +! !ROUTINE: create_lsm_output_fname +! \label{create_lsm_output_fname} +! +! !INTERFACE: +subroutine create_lsm_output_fname(n, form, fname, odir, wstyle, wopt, & + run_dd, map_proj, security_class, & + distribution_class, data_category, & + area_of_data, write_interval) +! !USES: + use LDT_coreMod, only : LDT_rc + use LDT_logMod + + implicit none +! !ARGUMENTS: + integer, intent(IN) :: n + character(len=*) :: fname + character(len=*) :: form + character(len=*) :: odir + character(len=*) :: wstyle + character(len=*) :: wopt + real, dimension(8), optional :: run_dd + character(len=*), optional :: map_proj + character(len=*), optional :: security_class + character(len=*), optional :: distribution_class + character(len=*), optional :: data_category + character(len=*), optional :: area_of_data + character(len=*), optional :: write_interval +! +! !DESCRIPTION: +! Create the file name for the output data files. It creates both the GSWP +! style of output filenames and the standard LIS style. The convention used +! in LIS creates a filename in a hierarchical style (output directory, +! model name, date, file extention) +! +! 2 level hierarchy +! \begin{verbatim} +! //LIS_HIST_. +! \end{verbatim} +! 3 level hierarchy +! \begin{verbatim} +! ///LIS_HIST_. +! \end{verbatim} +! 4 level hierarchy +! \begin{verbatim} +! ////LIS_HIST_. +! \end{verbatim} +! WMO convention +! \begin{verbatim} +! / +! \end{verbatim} +! A filename in the convention of weather products (such as): \newline +! {\small +! PS.AFWA\_SC.U\_DI.C\_DC.ANLYS\_GP.LIS\_GR.C0P25DEG\_AR.GLOBAL\_PA.03-HR-SUM\_DD.YYYYMMDD\_DT.HH00\_DF.GR1 \newline +! } +! where \newline +! PS = Product source \newline +! SC = security classification \newline +! DI = distribution classification \newline +! DC = data category \newline +! GP = generating process \newline +! GR = grid \newline +! AR = area of data \newline +! PA = parameter \newline +! DD = date \newline +! DT = data time \newline +! DF = data format \newline +! +! The arguments are: +! \begin{description} +! \item [n] +! index of the domain or nest +! \item [fname] +! the created file name. +! \item [model\_name] +! string describing the name of the model +! \item [writeint] +! output writing interval of the model +! \item [style] +! style option as described above +! \end{description} +!EOP + character(len=8) :: date + character(len=10) :: time + character(len=5) :: zone + integer, dimension(8) :: values + character(len=20) :: mname + character(len=10) :: cdate + character(len=14) :: cdate1 + character(len=2) :: fint + character(len=10) :: fres + character(len=10) :: fres2 + character(len=10) :: fres3 + character*1 :: fres1(10) + character(len=1) :: fproj + integer :: curr_mo = 0 + character(len=200) :: dname + character(len=200), save :: out_fname + integer :: i, c + + mname = 'SURFACEMODEL' + if(wstyle.eq."4 level hierarchy") then + write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & + LDT_rc%yr, LDT_rc%mo, & + LDT_rc%da, LDT_rc%hr,LDT_rc%mn + + dname = trim(odir)//'/' + dname = trim(dname)//trim(mname)//'/' + + write(unit=cdate, fmt='(i4.4)') LDT_rc%yr + dname = trim(dname)//trim(cdate)//'/' + + write(unit=cdate, fmt='(i4.4, i2.2, i2.2)') LDT_rc%yr, LDT_rc%mo, LDT_rc%da + dname = trim(dname)//trim(cdate) + + out_fname = trim(dname)//'/LIS_HIST_'//trim(cdate1) + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n + out_fname = trim(out_fname)//trim(cdate) + + select case ( form ) + case ( "binary" ) + if(wopt.eq."1d tilespace") then + out_fname = trim(out_fname)//'.ts4r' + elseif(wopt.eq."2d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + elseif(wopt.eq."1d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + endif + case ("grib1") + out_fname = trim(out_fname)//'.grb' + case ("netcdf") + out_fname = trim(out_fname)//'.nc' + case ("grib2") + out_fname = trim(out_fname)//'.gr2' + case default + call ldt_log_msg('ERR: create_lsm_output_fname -- '// & + 'Unrecognized output format') + call LDT_endrun + endselect + elseif(wstyle.eq."3 level hierarchy") then + write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & + LDT_rc%yr, LDT_rc%mo, & + LDT_rc%da, LDT_rc%hr,LDT_rc%mn + + dname = trim(odir)//'/' + dname = trim(dname)//trim(mname)//'/' + + write(unit=cdate, fmt='(i4.4, i2.2)') LDT_rc%yr, LDT_rc%mo + dname = trim(dname)//trim(cdate)//'/' + + out_fname = trim(dname)//'LIS_HIST_'//trim(cdate1) + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n + out_fname = trim(out_fname)//trim(cdate) + + select case ( form ) + case ("binary") + if(wopt.eq."1d tilespace") then + out_fname = trim(out_fname)//'.ts4r' + elseif(wopt.eq."2d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + elseif(wopt.eq."1d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + endif + case ("grib1") + out_fname = trim(out_fname)//'.grb' + case ("netcdf") + out_fname = trim(out_fname)//'.nc' + case ("grib2") + out_fname = trim(out_fname)//'.gr2' + case default + call ldt_log_msg('ERR: create_lsm_output_fname -- '// & + 'Unrecognized form value') + call LDT_endrun + endselect + elseif(wstyle.eq."2 level hierarchy") then + write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & + LDT_rc%yr, LDT_rc%mo, & + LDT_rc%da, LDT_rc%hr,LDT_rc%mn + + dname = trim(odir)//'/' + dname = trim(dname)//trim(mname)//'/' + + out_fname = trim(dname)//'LIS_HIST_'//trim(cdate1) + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n + out_fname = trim(out_fname)//trim(cdate) + + select case ( form ) + case ("binary") + if(wopt.eq."1d tilespace") then + out_fname = trim(out_fname)//'.ts4r' + elseif(wopt.eq."2d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + elseif(wopt.eq."1d gridspace") then + out_fname = trim(out_fname)//'.gs4r' + endif + case ("grib1") + out_fname = trim(out_fname)//'.grb' + case ("netcdf") + out_fname = trim(out_fname)//'.nc' + case ("grib2") + out_fname = trim(out_fname)//'.gr2' + case default + call ldt_log_msg('ERR: create_lsm_output_fname -- '// & + 'Unrecognized form value') + call LDT_endrun + endselect + elseif(wstyle.eq."WMO convention") then + if ( .not. present(run_dd) .or. & + .not. present(security_class) .or. & + .not. present(distribution_class) .or. & + .not. present(data_category) .or. & + .not. present(area_of_data) .or. & + .not. present(write_interval) ) then + call ldt_log_msg('ERR: create_lsm_output_fname -- '// & + 'missing WMO convention identifiers') + call LDT_endrun + endif + + write(unit=cdate1, fmt='(i4.4, i2.2, i2.2)') & + LDT_rc%yr, LDT_rc%mo, LDT_rc%da + + write(unit=cdate, fmt='(i2.2, i2.2)') LDT_rc%hr, LDT_rc%mn + + if(map_proj.eq."polar") then + fproj = 'P' + print *,"fres ",run_dd(6) + if (run_dd(6) .ge. 10.) then + write(unit=fres, fmt='(i2)') nint(run_dd(6)) + else + write(unit=fres, fmt='(i1)') nint(run_dd(6)) + endif + fres2 = trim(fres)//'KM' + elseif(map_proj.eq."lambert") then + fproj = 'L' + print *,"fres ",run_dd(6) +! write(unit=fres, fmt='(f2.0)') run_dd(6) + write(unit=fres, fmt='(f3.0)') run_dd(6) + if (run_dd(6) .ge. 10.) then + write(unit=fres, fmt='(i2)') nint(run_dd(6)) + else + write(unit=fres, fmt='(i1)') nint(run_dd(6)) + endif + fres2 = trim(fres)//'KM' + elseif(map_proj.eq."mercator") then + fproj = 'M' + write(unit=fres, fmt='(i2.2)') run_dd(6) + fres = trim(fres)//'KM' + elseif(map_proj.eq."gaussian") then + fproj = 'G' + write(unit=fres, fmt='(i2.2)') run_dd(5)*100 + fres2 = '0P'//trim(fres)//'DEG' + else + fproj = 'C' + write(unit=fres, fmt='(i10)') nint(run_dd(6)*100) + read(unit=fres,fmt='(10a1)') (fres1(i),i=1,10) + c = 0 + do i=1,10 + if(fres1(i).ne.' '.and.c==0) c = i + enddo + if (run_dd(6) .lt. 0.1) then + fres3 = '0P0' + else + fres3 = '0P' + end if + fres2 = fres3 + do i=c,10 + fres2 = trim(fres2)//trim(fres1(i)) + enddo + fres2 = trim(fres2)//'DEG' + endif + + out_fname = trim(odir)//'/'//& + '/PS.AFWA_SC.'//trim(security_class)//& + '_DI.'//trim(distribution_class)//& + '_DC.'//trim(data_category)//& + '_GP.LIS_GR.'//& + trim(fproj)//trim(fres2)//& + '_AR.'//trim(area_of_data)//& + '_PA.'//trim(write_interval)//'-HR-SUM_DD.'//& + trim(cdate1)//'_DT.'//trim(cdate)//'_DF.GR1' + endif + fname = out_fname + end subroutine create_lsm_output_fname + +!BOP +! +! !ROUTINE: transformPrecipDataToLDTgrid +! \label{trasnformDataToLDTgrid} +! +! !INTERFACE: + subroutine transformPrecipDataToLDTgrid(n, precip_inp, precip_out) +! !USES: + use LDT_coreMod + use LISlsmPrecip_obsMod + + implicit none +! !ARGUMENTS: + integer :: n + real :: precip_inp(lsmprecipobs%nc*lsmprecipobs%nr) + real :: precip_out(LDT_rc%lnc(n),LDT_rc%lnr(n)) +! +! !DESCRIPTION: +! This routine interpolates or upscales the input data to +! the LDT grid. If the input data is finer than the LDT +! grid, the input data is upscaled. If the input data is +! coarser, then it is interpolated to the LDT grid. +! +!EOP + integer :: ios + integer :: c,r + logical*1 :: precip_data_b(lsmprecipobs%nc*lsmprecipobs%nr) + real :: precipobs_ip(LDT_rc%lnc(n)*LDT_rc%lnr(n)) + logical*1 :: precipobs_b_ip(lsmprecipobs%nc*lsmprecipobs%nr) + + do r=1,lsmprecipobs%nr + do c=1, lsmprecipobs%nc + if(precip_inp(c+(r-1)*lsmprecipobs%nc).ne.LDT_rc%udef) then + precip_data_b(c+(r-1)*lsmprecipobs%nc) = .true. + else + precip_data_b(c+(r-1)*lsmprecipobs%nc) = .false. + endif + if(precip_inp(c+(r-1)*lsmprecipobs%nc).gt.1) then + precip_inp(c+(r-1)*lsmprecipobs%nc) = LDT_rc%udef + precip_data_b(c+(r-1)*lsmprecipobs%nc) = .false. + endif + enddo + enddo + + if(LDT_isLDTatAfinerResolution(n,lsmprecipobs%datares)) then + +!-------------------------------------------------------------------------- +! Interpolate to the LDT running domain +!-------------------------------------------------------------------------- + call bilinear_interp(LDT_rc%gridDesc(n,:),& + precip_data_b, precip_inp, precipobs_b_ip, precipobs_ip, & + lsmprecipobs%nc*lsmprecipobs%nr, & + LDT_rc%lnc(n)*LDT_rc%lnr(n), & + LDT_domain(n)%lat, LDT_domain(n)%lon,& + lsmprecipobs%w11, lsmprecipobs%w12, & + lsmprecipobs%w21, lsmprecipobs%w22, & + lsmprecipobs%n11, lsmprecipobs%n12, & + lsmprecipobs%n21, lsmprecipobs%n22, & + LDT_rc%udef, ios) + + call neighbor_interp(LDT_rc%gridDesc(n,:),& + precip_data_b, precip_inp, precipobs_b_ip, precipobs_ip, & + lsmprecipobs%nc*lsmprecipobs%nr, & + LDT_rc%lnc(n)*LDT_rc%lnr(n), & + LDT_domain(n)%lat, LDT_domain(n)%lon,& + lsmprecipobs%n11, LDT_rc%udef, ios) + else + call upscaleByAveraging(& + lsmprecipobs%nc*lsmprecipobs%nr,& + LDT_rc%lnc(n)*LDT_rc%lnr(n),LDT_rc%udef, & + lsmprecipobs%n11,precip_data_b, precip_inp, precipobs_b_ip,precipobs_ip) + + endif + + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + if(precipobs_b_ip(c+(r-1)*LDT_rc%lnc(n))) then + precip_out(c,r) = precipobs_ip(c+(r-1)*LDT_rc%lnc(n)) + else + precip_out(c,r) = LDT_rc%udef + endif + enddo + enddo + + end subroutine transformPrecipDataToLDTgrid diff --git a/ldt/core/LDT_DAmetricsMod.F90 b/ldt/core/LDT_DAmetricsMod.F90 index 5a7d0f76e..ee5409254 100644 --- a/ldt/core/LDT_DAmetricsMod.F90 +++ b/ldt/core/LDT_DAmetricsMod.F90 @@ -96,6 +96,9 @@ subroutine LDT_DAmetricsInit LDT_DAobsData(n)%vod_obs,LDT_DAmetrics%vod) call registerMetricsEntry(LDT_DA_MOC_LAI,nsize,& LDT_DAobsData(n)%lai_obs,LDT_DAmetrics%lai) + call registerMetricsEntry(LDT_DA_MOC_TOTALPRECIP,nsize,& + LDT_DAobsData(n)%totalprecip_obs,LDT_DAmetrics%totalprecip) + !------------------------------------------------------------------------ ! the generation of the obsgrid only doesn't require a pass through the ! data diff --git a/ldt/core/LDT_DAobsDataMod.F90 b/ldt/core/LDT_DAobsDataMod.F90 index f9ff1cb85..39ccca86f 100644 --- a/ldt/core/LDT_DAobsDataMod.F90 +++ b/ldt/core/LDT_DAobsDataMod.F90 @@ -47,6 +47,7 @@ module LDT_DAobsDataMod public :: LDT_DA_MOC_VOD public :: LDT_DA_MOC_LAI public :: LDT_DA_MOC_COUNT + public :: LDT_DA_MOC_TOTALPRECIP ! public :: LDT_MOC_GRIB_COUNT ! ALMA ENERGY BALANCE COMPONENTS @@ -57,7 +58,8 @@ module LDT_DAobsDataMod integer, parameter :: LDT_DA_MOC_VOD = 5 integer, parameter :: LDT_DA_MOC_LAI = 6 ! READ ABOVE NOTE ABOUT SPECIAL CASE INDICES - integer, parameter :: LDT_DA_MOC_COUNT = 6 + integer, parameter :: LDT_DA_MOC_TOTALPRECIP= 7 + integer, parameter :: LDT_DA_MOC_COUNT = 7 ! Add the special cases. LDT_MOC_GRIB_COUNT should be used only in ! LDT_gribMod.F90. ! integer, parameter :: LDT_MOC_GRIB_COUNT = 100 @@ -98,7 +100,7 @@ module LDT_DAobsDataMod type(LDT_DAmetadataEntry) :: soilmoist type(LDT_DAmetadataEntry) :: vod type(LDT_DAmetadataEntry) :: lai - + type(LDT_DAmetadataEntry) :: totalprecip end type output_meta type, public :: dep @@ -112,6 +114,7 @@ module LDT_DAobsDataMod type(LDT_DAmetadataEntry) :: tws_obs type(LDT_DAmetadataEntry) :: vod_obs type(LDT_DAmetadataEntry) :: lai_obs + type(LDT_DAmetadataEntry) :: totalprecip_obs end type obs_list_dec type, public :: obsdep @@ -199,6 +202,8 @@ subroutine LDT_DAobsEntryInit(i, nsize) LDT_DAobsData(i)%vod_obs,1,nsize,(/"-"/)) call register_obsDataEntry(i,LDT_DA_MOC_LAI ,& LDT_DAobsData(i)%lai_obs,1,nsize,(/"-"/)) + call register_obsDataEntry(i,LDT_DA_MOC_TOTALPRECIP ,& + LDT_DAobsData(i)%totalprecip_obs,1,nsize,(/"kg/m2"/)) end subroutine LDT_DAobsEntryInit !BOP diff --git a/ldt/core/LDT_DAobservationsMod.F90 b/ldt/core/LDT_DAobservationsMod.F90 index 274a664a8..c7440a660 100644 --- a/ldt/core/LDT_DAobservationsMod.F90 +++ b/ldt/core/LDT_DAobservationsMod.F90 @@ -69,6 +69,7 @@ subroutine LDT_DAobsDataInit call default_init_obsEntry(LDT_DAobsData(i)%tws_obs, "TWS") call default_init_obsEntry(LDT_DAobsData(i)%vod_obs, "VOD") call default_init_obsEntry(LDT_DAobsData(i)%lai_obs, "LAI") + call default_init_obsEntry(LDT_DAobsData(i)%totalprecip_obs, "TotalPrecip") enddo call daobservationsetup(trim(LDT_rc%obs_src)//char(0)) diff --git a/ldt/make/Filepath b/ldt/make/Filepath index 182375bc9..2ef814915 100644 --- a/ldt/make/Filepath +++ b/ldt/make/Filepath @@ -1 +1 @@ -dirs := . ../main ../core ../interp ../plugins ../lib/bil ../lib/xmrg ../params/mask ../params/landcover ../params/soils ../params/topo ../params/albedo ../params/gfrac ../params/LAISAI ../params/slopetype ../params/tbot ../params/pet ../params/climateparms ../params/crop_parms ../params/irrigation ../params/catchment ../params/CLM2 ../params/GeoWRSI ../params/FLAKE ../params/HYMAP ../params/JULES ../params/Mosaic ../params/Noah ../params/RDHM ../params/RUC ../params/SACHTET ../params/Snow17 ../params/SiB2 ../params/VIC ../params/glacier ../runmodes/ANNproc ../runmodes/DApreproc ../runmodes/LSMparamproc ../runmodes/EnsRstpreproc ../runmodes/NUWRFpreproc ../runmodes/Metforcproc ../runmodes/MetTimeDScale ../runmodes/climoRstproc ../runmodes/rstTransformProc ../runmodes/StatDscaleMetForc ../runmodes/OPTUEproc/ ../domains/latlon ../domains/gaussian ../domains/hrap ../domains/lambert ../domains/polar ../domains/merc ../domains/easev2 ../DAobs/MCD15A2H_LAI ../DAobs/LISlsmSMobs ../DAobs/synthetic_sm ../DAobs/NASA_AMSRE_sm ../DAobs/LPRM_AMSREsm ../DAobs/LPRMvod ../DAobs/ESACCI_sm ../DAobs/WindSat_sm ../DAobs/GRACE_tws ../DAobs/GRACEQL_tws ../DAobs/SMOPS ../DAobs/ASCAT_TUW ../DAobs/SMOS_L2sm ../DAobs/SMOS_NESDIS ../DAobs/GCOMW_AMSR2L3snd ../DAobs/GCOMW_AMSR2L3sm ../DAobs/Aquarius_L2sm ../DAobs/simGRACE_JPL ../DAobs/SMMR_SNWD ../DAobs/SSMI_SNWD ../DAobs/ANSA_SNWD ../DAobs/NASA_SMAPsm ../DAobs/SMOS_NRTNN_L2sm ../DAobs/NASA_SMAPvod ../DAobs/GLASSlai ../DAobs/THySM ../RESTRICTED/usaf/usaf ../metforcing/agrradps ../metforcing/cmap ../metforcing/cmorph ../metforcing/ecmwf ../metforcing/gdas ../metforcing/geos5fcst ../metforcing/gfs ../metforcing/gldas ../metforcing/gswp1 ../metforcing/gswp2 ../metforcing/merra2 ../metforcing/era5 ../metforcing/nam242 ../metforcing/narr ../metforcing/princeton ../metforcing/nldas2 ../metforcing/WRFoutv2 ../metforcing/WRFAKdom ../metforcing/stg2 ../metforcing/stg4 ../metforcing/3B42RTV7 ../metforcing/3B42V6 ../metforcing/3B42V7 ../metforcing/RFE2Daily ../metforcing/RFE2gdas ../metforcing/chirps2 ../MetforcScale ../ANNdata/LISlsmSM ../ANNdata/synthetic_sm ../ANNdata/LPRM_AMSREsm ../ANNdata/MODIS_LST ../ANNdata/MOD10A1 ../ANNdata/GHCNsnwd ../ANNdata/GCOMW_AMSR2_TB ../statDscale/BayesianMerging ../statDscale/Climo ../params/CLM45 ../USAFSI ../runmodes/USAFSI ../runmodes/LISHydropreproc ../params/Crocus ../runmodes/obsSim ../obsSim/NatureRun/LISout/ ../obsSim/OSSEmask/LISout/ ../obsSim/OSSEmask/AMSR2/ ../obsSim/OSSEmask/TSMM/ ../obsSim/OSSEmask/MODIS/ ../obsSim/OSSEmask/Sentinel1A/ +dirs := . ../main ../core ../interp ../plugins ../lib/bil ../lib/xmrg ../params/mask ../params/landcover ../params/soils ../params/topo ../params/albedo ../params/gfrac ../params/LAISAI ../params/slopetype ../params/tbot ../params/pet ../params/climateparms ../params/crop_parms ../params/irrigation ../params/catchment ../params/CLM2 ../params/GeoWRSI ../params/FLAKE ../params/HYMAP ../params/JULES ../params/Mosaic ../params/Noah ../params/RDHM ../params/RUC ../params/SACHTET ../params/Snow17 ../params/SiB2 ../params/VIC ../params/glacier ../runmodes/ANNproc ../runmodes/DApreproc ../runmodes/LSMparamproc ../runmodes/EnsRstpreproc ../runmodes/NUWRFpreproc ../runmodes/Metforcproc ../runmodes/MetTimeDScale ../runmodes/climoRstproc ../runmodes/rstTransformProc ../runmodes/StatDscaleMetForc ../runmodes/OPTUEproc/ ../domains/latlon ../domains/gaussian ../domains/hrap ../domains/lambert ../domains/polar ../domains/merc ../domains/easev2 ../DAobs/MCD15A2H_LAI ../DAobs/LISlsmSMobs ../DAobs/LISlsmPrecipobs ../DAobs/synthetic_sm ../DAobs/NASA_AMSRE_sm ../DAobs/LPRM_AMSREsm ../DAobs/LPRMvod ../DAobs/ESACCI_sm ../DAobs/WindSat_sm ../DAobs/GRACE_tws ../DAobs/GRACEQL_tws ../DAobs/SMOPS ../DAobs/ASCAT_TUW ../DAobs/SMOS_L2sm ../DAobs/SMOS_NESDIS ../DAobs/GCOMW_AMSR2L3snd ../DAobs/GCOMW_AMSR2L3sm ../DAobs/Aquarius_L2sm ../DAobs/simGRACE_JPL ../DAobs/SMMR_SNWD ../DAobs/SSMI_SNWD ../DAobs/ANSA_SNWD ../DAobs/NASA_SMAPsm ../DAobs/SMOS_NRTNN_L2sm ../DAobs/NASA_SMAPvod ../DAobs/GLASSlai ../DAobs/THySM ../RESTRICTED/usaf/usaf ../metforcing/agrradps ../metforcing/cmap ../metforcing/cmorph ../metforcing/ecmwf ../metforcing/gdas ../metforcing/geos5fcst ../metforcing/gfs ../metforcing/gldas ../metforcing/gswp1 ../metforcing/gswp2 ../metforcing/merra2 ../metforcing/era5 ../metforcing/nam242 ../metforcing/narr ../metforcing/princeton ../metforcing/nldas2 ../metforcing/WRFoutv2 ../metforcing/WRFAKdom ../metforcing/stg2 ../metforcing/stg4 ../metforcing/3B42RTV7 ../metforcing/3B42V6 ../metforcing/3B42V7 ../metforcing/RFE2Daily ../metforcing/RFE2gdas ../metforcing/chirps2 ../MetforcScale ../ANNdata/LISlsmSM ../ANNdata/synthetic_sm ../ANNdata/LPRM_AMSREsm ../ANNdata/MODIS_LST ../ANNdata/MOD10A1 ../ANNdata/GHCNsnwd ../ANNdata/GCOMW_AMSR2_TB ../statDscale/BayesianMerging ../statDscale/Climo ../params/CLM45 ../USAFSI ../runmodes/USAFSI ../runmodes/LISHydropreproc ../params/Crocus ../runmodes/obsSim ../obsSim/NatureRun/LISout/ ../obsSim/OSSEmask/LISout/ ../obsSim/OSSEmask/AMSR2/ ../obsSim/OSSEmask/TSMM/ ../obsSim/OSSEmask/MODIS/ ../obsSim/OSSEmask/Sentinel1A/ diff --git a/ldt/plugins/LDT_DAobs_pluginMod.F90 b/ldt/plugins/LDT_DAobs_pluginMod.F90 index d8a06f20f..7c5c238c7 100644 --- a/ldt/plugins/LDT_DAobs_pluginMod.F90 +++ b/ldt/plugins/LDT_DAobs_pluginMod.F90 @@ -71,7 +71,8 @@ subroutine LDT_DAobs_plugin use LPRMvod_obsMod, only : LPRMvod_obsinit use MCD15A2Hlai_obsMod, only : MCD15A2Hlai_obsinit use THySM_obsMod, only : THySM_obsinit - + use LISlsmPrecip_obsMod, only : LISlsmPrecip_obsInit + external readLISlsmSMObs external readsyntheticsmobs external readNASA_AMSREsmObs @@ -98,10 +99,14 @@ subroutine LDT_DAobs_plugin external readLPRMvodObs external readMCD15A2HlaiObs external readTHySMobs + external readLISlsmPrecipObs call registerdaobssetup(trim(LDT_LISlsmSMobsId)//char(0), LISlsmSM_obsInit) call registerdaobsread(trim(LDT_LISlsmSMobsId)//char(0), readLISlsmSMObs) + call registerdaobssetup(trim(LDT_LISlsmPrecipobsId)//char(0), LISlsmPrecip_obsInit) + call registerdaobsread(trim(LDT_LISlsmPrecipobsId)//char(0), readLISlsmPrecipObs) + call registerdaobssetup(trim(LDT_syntheticSMobsId)//char(0), & syntheticSM_obsinit) call registerdaobsread(trim(LDT_syntheticSMobsId)//char(0),& diff --git a/ldt/plugins/LDT_pluginIndices.F90 b/ldt/plugins/LDT_pluginIndices.F90 index 0b3b700bd..3bc9350ec 100644 --- a/ldt/plugins/LDT_pluginIndices.F90 +++ b/ldt/plugins/LDT_pluginIndices.F90 @@ -117,6 +117,9 @@ module LDT_pluginIndices character*50, public, parameter :: LDT_MCD15A2HlaiobsId & = "MCD15A2H LAI" + character*50, public, parameter :: LDT_LISlsmPrecipobsId & + = "LIS LSM total precipitation" + !------------------------------------------------------------------------- ! Meteorological forcings !------------------------------------------------------------------------- From 273f5b01576f2fc6807e7fc29842a24f6da99e18 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 7 Dec 2021 12:20:45 -0500 Subject: [PATCH 015/328] Added support to read the stratification data file (precipitation CDF file) and stratify the satellite and LSM based soil moisture using precipitation data. --- ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 | 152 ++++++++++++++++++++++ ldt/core/LDT_CDFMod.F90 | 89 ++++++++++++- ldt/core/LDT_DApreprocMod.F90 | 55 +++++++- ldt/core/LDT_PRIV_rcMod.F90 | 10 ++ 4 files changed, 303 insertions(+), 3 deletions(-) create mode 100644 ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 new file mode 100644 index 000000000..bb97f1c6f --- /dev/null +++ b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 @@ -0,0 +1,152 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LDT_misc.h" +#include "LDT_NetCDF_inc.h" +!BOP +! !ROUTINE: read_Drange +! \label{read_Drange} + +! !REVISION HISTORY: +! 2Dec2021: Mahdi Navari ; Initial Specification +! +! !INTERFACE: +subroutine read_Drange(ngrid, filename, varname, xrange) + + use LDT_coreMod + use LDT_logMod + use LDT_historyMod +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: +! integer, intent(in) :: n +! integer, intent(in) :: k +! integer, intent(in) :: nbins +! integer, intent(in) :: ntimes + integer, intent(in) :: ngrid + character(len=*) :: filename + character(len=*) :: varname + real :: xrange(ngrid,2) + !real :: cdf(ngrid,ntimes, nbins) + +! +! !DESCRIPTION: +! This routine reads the input CDF file (generated by LDT in NETCDF format) +! The xrange values and the corresponding CDFs are read for each grid point. +! Both these fields are expected to be in the 1-d grid vector dimension. +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[nbins] number of bins used to compute the model and obs CDFs +! \item[filename] name of the CDF file +! \item[varname] name of the variable being extracted. +! \item[xrange] x-axis values corresponding to the CDF +! \item[cdf] y-axis (CDF) values corresponding to the CDF +! \end{description} +!EOP + integer :: j,kk + integer :: ngridId, nbinsId, nlevsId,ntimesId + integer :: ngrid_file, nbins_file, nlevs_file, ntimes_file + integer :: xid, cdfid + real, allocatable :: xrange_file(:,:,:) + !real, allocatable :: cdf_file(:,:,:) + integer :: nid + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + write(LDT_logunit,*) '[INFO] Reading Drange form CDF file ',trim(filename) + !if(ngrid.gt.0) then + call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & + 'nf90_inq_dimid failed for ngrid') + call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & + 'nf90_inq_dimid failed for nbins') + call LDT_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & + 'nf90_inq_dimid failed for '//trim(varname)//"_levels") + call LDT_verify(nf90_inq_dimid(nid,"ntimes",ntimesId), & + 'nf90_inq_dimid failed for ntimes') + + + call LDT_verify(nf90_inquire_dimension(nid,ngridId, len=ngrid_file),& + 'nf90_inquire_dimension failed for ngrid') + call LDT_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& + 'nf90_inquire_dimension failed for ntimes') + + !if(nbins.ne.nbins_file) then + ! write(LDT_logunit,*) '[ERR] The number of bins specified in the file '//& + ! trim(filename) + ! write(LDT_logunit,*) '[ERR] (',nbins_file, & + ! ') is different from the number of bins specified' + ! write(LDT_logunit,*) '[ERR] in the lis.config file (',nbins,')' + ! call LDT_endrun() + !endif + + if (ntimes_file .gt. 1) then + write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& + trim(filename) + write(LDT_logunit,*) '[ERR] (',ntimes_file, & + ') should be 1 set the Temporal resolution of precipitation CDFs to "yearly" ' + call LDT_endrun() + endif + + !allocate(xrange(ngrid_file,2)) + allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) + !allocate(cdf_file(ngrid_file,nlevs_file, nbins)) + + do j=1,ntimes_file + call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& + 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') + !call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_CDF',cdfid),& + ! 'nf90_inq_varid failed for '//trim(varname)//'_CDF') + + call LDT_verify(nf90_get_var(nid,xid,xrange_file, & + start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& + 'nf90_get_var failed for '//trim(varname)//'_xrange') + !call LDT_verify(nf90_get_var(nid,cdfid,cdf_file,& + ! start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins/)),& + ! 'nf90_get_var failed for '//trim(varname)//'_CDF') + +! Note: CDF is generated by LDT --> therefore data is in the LDT domain +#if 0 + if(ngrid.gt.0) then + do kk=1,nbins + call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & + xrange(:,j,kk)) + call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & + cdf(:,j,kk)) + enddo + endif +#endif + enddo + + xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell + xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell +! xrange = xrange_file +! cdf = cdf_file + + deallocate(xrange_file) + !deallocate(cdf_file) + + call LDT_verify(nf90_close(nid),& + 'failed to close file '//trim(filename)) + write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) + !endif +#endif + +end subroutine read_Drange + diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index 2999179a6..4b26b569a 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -221,7 +221,7 @@ subroutine computeSingleCDF(n,obs, metrics) if(LDT_rc%endtime.eq.1) then if(obs%selectOpt.eq.1.and.metrics%selectOpt.eq.1) then - if(LDT_rc%group_cdfs.eq.0) then + if(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.0) then do t=1,LDT_rc%ngrid(n) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels @@ -237,7 +237,7 @@ subroutine computeSingleCDF(n,obs, metrics) enddo enddo enddo - elseif(LDT_rc%group_cdfs.eq.1) then + elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.0) then allocate(strat_bincounts(LDT_rc%group_cdfs_nbins, & LDT_rc%cdf_ntimes, & @@ -298,6 +298,91 @@ subroutine computeSingleCDF(n,obs, metrics) deallocate(strat_bincounts) deallocate(strat_cdf) +!MN: Startification based on total precipitation +! min and max of total precipitation for each pixel are stored in LDT_rc%stratification_data + + elseif(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.1 ) then + + !allocate(cdf_strat_precip_data(LDT_rc%lnc(n),LDT_rc%lnr(n))) + !allocate(LDT_rc%cdf_strat_precip_data(LDT_rc%ngrid(n))) + + !LDT_rc%strat_cdfs_min = 0 ! MINVAL(LDT_DAobsDataPtr(n,LDT_rc%DA_MOC_index_number)%dataEntryPtr) + !metrics_precip = LDT_DAmetricsPtr(LDT_rc%DA_MOC_index_number)%dataEntryPtr + !LDT_rc%strat_cdfs_max = MAXVAL(metrics_precip%maxval) ! metrics%maxval(t,j,k) --> (grid,cdf_ntimes(1,12), obs%vlevels) + !cdf_strat_precip_data = MAXVAL(metrics_precip%maxval,1) + !delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& + ! LDT_rc%strat_cdfs_nbins + + !do r=1,LDT_rc%lnr(n) + ! do c=1,LDT_rc%lnc(n) + ! if(LDT_domain(n)%gindex(c,r).ne.-1) then + + ! LDT_rc%cdf_strat_precip_data(LDT_domain(n)%gindex(c,r)) = & + ! nint((cdf_strat_precip_data(LDT_domain(n)%gindex(c,r),1) - LDT_rc%strat_cdfs_min)/& + ! delta)+1 + ! endif + ! enddo + !enddo + + allocate(strat_bincounts(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels,& + LDT_rc%cdf_nbins)) + allocate(strat_cdf(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels,& + LDT_rc%cdf_nbins)) + + strat_bincounts = 0 + strat_cdf = 0 + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + do i=1,LDT_rc%cdf_nbins + sindex = LDT_rc%stratification_data(t) + strat_bincounts(sindex,j,k,i) = & + strat_bincounts(sindex,j,k,i) + & + metrics%cdf_bincounts(t,j,k,i) + + enddo + enddo + enddo + enddo + + do t=1,LDT_rc%strat_cdfs_nbins + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + if(sum(strat_bincounts(t,j,k,:)).ne.0) then + strat_cdf(t,j,k,1) = & + strat_bincounts(t,j,k,1)/& ! strat_cdf(t,j,k,1)/& + float(sum(strat_bincounts(t,j,k,:))) + do i=2,LDT_rc%cdf_nbins + strat_cdf(t,j,k,i) = strat_cdf(t,j,k,i-1) + & + strat_bincounts(t,j,k,i)/& + float(sum(strat_bincounts(t,j,k,:))) + enddo + endif + enddo + enddo + enddo + + do t=1,LDT_rc%ngrid(n) +! if(datamask(t).gt.0) then + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + do i=1,LDT_rc%cdf_nbins + sindex = LDT_rc%stratification_data(t) + metrics%cdf(t,j,k,i) = strat_cdf(sindex,j,k,i) + enddo + enddo + enddo +! endif + enddo + + deallocate(strat_bincounts) + deallocate(strat_cdf) + endif endif endif diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index ef313c2d9..e8663b3d0 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -59,7 +59,7 @@ subroutine LDT_DApreprocInit() character*50 :: preprocMethod real :: delta real, allocatable :: cdf_strat_data(:,:) - + real, allocatable :: stratification_data(:,:) n = 1 call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%obs_src,& label="DA observation source:",rc=rc) @@ -166,6 +166,59 @@ subroutine LDT_DApreprocInit() write(LDT_logunit,*) '[INFO] Finished reading ',& trim(LDT_rc%group_cdfs_strat_file) endif + +!This part reads the dynamic range of precipitation and generates +! stratification input data based on total precipitation. + + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_cdfs,& + label="Stratify CDFs by external data:",default=0, rc=rc) + call LDT_verify(rc,"Stratify CDFs by external data: not defined") + if(LDT_rc%strat_cdfs.gt.0) then + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_src,& + label="Stratification data source:", rc=rc) + call LDT_verify(rc,"Stratification data source: not defined") + + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_cdfs_nbins,& + label="Number of bins to use for stratification:",rc=rc) + call LDT_verify(rc,"Number of bins to use for stratification: not defined") + + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_file,& + label="External stratification file:",rc=rc) + call LDT_verify(rc,"External stratification file: not defined") + + !if(LDT_rc%strat_cdfs.gt.0) then + allocate(LDT_rc%stratification_data(LDT_rc%ngrid(n))) + allocate(stratification_data(LDT_rc%ngrid(n),2)) + + call read_Drange(LDT_rc%ngrid(n), LDT_rc%strat_file, "TotalPrecip", stratification_data) !LDT_rc%strat_cdfs_nbins, LDT_rc%ngrid(n), & + + LDT_rc%strat_cdfs_min = minval(stratification_data(:,1)) ! min value over the entire domain + LDT_rc%strat_cdfs_max = maxval(stratification_data(:,2)) ! max value over the entire domain + delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& + LDT_rc%strat_cdfs_nbins + print*, 'min,man,delta', LDT_rc%strat_cdfs_min, LDT_rc%strat_cdfs_max, delta + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + if(LDT_domain(n)%gindex(c,r).ne.-1) then + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r)) = & + nint((stratification_data(LDT_domain(n)%gindex(c,r),2) - LDT_rc%strat_cdfs_min)/& + delta)+1 + endif + enddo + enddo + + !if(LDT_rc%strat_cdfs.gt.0) then + ! call ESMF_ConfigGetAttribute(LDT_config,& + ! LDT_rc%strat_cdfs_attrib_file,& + ! label="CDF Stratification attributes file:",rc=rc) + ! call LDT_verify(rc,'CDF Stratification attributes file: not defined') + + ! ftn = LDT_getNextUnitNumber() + ! open(ftn,file=LDT_rc%strat_cdfs_attrib_file, status='old') + ! read(ftn,*) + ! read(ftn,*) LDT_rc%strat_cdfs_nbins + ! call LDT_releaseUnitNumber(ftn) + endif endif if(LDT_rc%comp_obsgrid.eq.1) then diff --git a/ldt/core/LDT_PRIV_rcMod.F90 b/ldt/core/LDT_PRIV_rcMod.F90 index 9b5088334..ab840c9cf 100644 --- a/ldt/core/LDT_PRIV_rcMod.F90 +++ b/ldt/core/LDT_PRIV_rcMod.F90 @@ -359,6 +359,16 @@ module LDT_PRIV_rcMod real :: group_cdfs_max integer :: group_cdfs_nbins + integer :: strat_cdfs + character*50 :: strat_src + character*50 :: strat_file + !character*50 :: strat_cdfs_attrib_file + integer :: strat_cdfs_nbins + real :: strat_cdfs_min + real :: strat_cdfs_max + integer, allocatable :: stratification_data(:) + + integer :: sp_sampl_cdfs integer :: sp_sample_cdf_rad From a0246eda5f4435ac864b5ec379efb8ae6708a17d Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Wed, 8 Dec 2021 14:08:43 -0500 Subject: [PATCH 016/328] Code cleaning and adding revision history --- .../LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 | 2 +- .../LISlsmPrecipobs/readLISlsmPrecipobs.F90 | 2 ++ ldt/core/LDT_CDFMod.F90 | 22 +------------------ ldt/core/LDT_DAmetricsMod.F90 | 1 + ldt/core/LDT_DAobsDataMod.F90 | 1 + ldt/core/LDT_DAobservationsMod.F90 | 1 + ldt/core/LDT_DApreprocMod.F90 | 1 + 7 files changed, 8 insertions(+), 22 deletions(-) diff --git a/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 index 8a647f7bf..649bb2443 100644 --- a/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 @@ -20,7 +20,7 @@ module LISlsmPrecip_obsMod ! (CDF) for use in DA ! ! !REVISION HISTORY: -! 16 Nov 2021 Mahdi Navari Initial Specification +! 16 Nov 2021 Mahdi Navari Initial Specification (based on LISlsmSM_obsMod) ! PRIVATE diff --git a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 index 40e462191..7d6f416e7 100644 --- a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 @@ -14,6 +14,8 @@ ! \label{readLISlsmPrecipobs} ! ! !INTERFACE: +! !REVISION HISTORY: +! 2Dec2021: Mahdi Navari ; Initial Specification (based on readLISlsmSM) subroutine readLISlsmPrecipobs(n) ! !USES: #if(defined USE_NETCDF3 || defined USE_NETCDF4) diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index 4b26b569a..ec7586751 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -17,6 +17,7 @@ module LDT_CDFMod ! ! !REVISION HISTORY: ! 2 Oct 2008 Sujay Kumar Initial Specification +! 2 Dec 2021: Mahdi Navari; modified to stratify CDF based on precipitation ! !EOP use LDT_DAobsDataMod @@ -303,27 +304,6 @@ subroutine computeSingleCDF(n,obs, metrics) elseif(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.1 ) then - !allocate(cdf_strat_precip_data(LDT_rc%lnc(n),LDT_rc%lnr(n))) - !allocate(LDT_rc%cdf_strat_precip_data(LDT_rc%ngrid(n))) - - !LDT_rc%strat_cdfs_min = 0 ! MINVAL(LDT_DAobsDataPtr(n,LDT_rc%DA_MOC_index_number)%dataEntryPtr) - !metrics_precip = LDT_DAmetricsPtr(LDT_rc%DA_MOC_index_number)%dataEntryPtr - !LDT_rc%strat_cdfs_max = MAXVAL(metrics_precip%maxval) ! metrics%maxval(t,j,k) --> (grid,cdf_ntimes(1,12), obs%vlevels) - !cdf_strat_precip_data = MAXVAL(metrics_precip%maxval,1) - !delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& - ! LDT_rc%strat_cdfs_nbins - - !do r=1,LDT_rc%lnr(n) - ! do c=1,LDT_rc%lnc(n) - ! if(LDT_domain(n)%gindex(c,r).ne.-1) then - - ! LDT_rc%cdf_strat_precip_data(LDT_domain(n)%gindex(c,r)) = & - ! nint((cdf_strat_precip_data(LDT_domain(n)%gindex(c,r),1) - LDT_rc%strat_cdfs_min)/& - ! delta)+1 - ! endif - ! enddo - !enddo - allocate(strat_bincounts(LDT_rc%strat_cdfs_nbins, & LDT_rc%cdf_ntimes, & obs%vlevels,& diff --git a/ldt/core/LDT_DAmetricsMod.F90 b/ldt/core/LDT_DAmetricsMod.F90 index ee5409254..d6bd38666 100644 --- a/ldt/core/LDT_DAmetricsMod.F90 +++ b/ldt/core/LDT_DAmetricsMod.F90 @@ -18,6 +18,7 @@ module LDT_DAmetricsMod ! ! !REVISION HISTORY: ! 02 Oct 2008: Sujay Kumar; Initial version +! 2 Dec 2021: Mahdi Navari; modified to compute CDF for precipitation ! use ESMF use LDT_DAmetricsDataMod diff --git a/ldt/core/LDT_DAobsDataMod.F90 b/ldt/core/LDT_DAobsDataMod.F90 index 39ccca86f..b307abb0c 100644 --- a/ldt/core/LDT_DAobsDataMod.F90 +++ b/ldt/core/LDT_DAobsDataMod.F90 @@ -21,6 +21,7 @@ module LDT_DAobsDataMod ! ! !REVISION HISTORY: ! 2 Oct 2008 Sujay Kumar Initial Specification +! 2 Dec 2021: Mahdi Navari; modified to compute CDF for precipitation ! !USES: PRIVATE diff --git a/ldt/core/LDT_DAobservationsMod.F90 b/ldt/core/LDT_DAobservationsMod.F90 index c7440a660..ff830f2f7 100644 --- a/ldt/core/LDT_DAobservationsMod.F90 +++ b/ldt/core/LDT_DAobservationsMod.F90 @@ -18,6 +18,7 @@ module LDT_DAobservationsMod ! ! !REVISION HISTORY: ! 02 Oct 2008 Sujay Kumar Initial Specification +! 2 Dec 2021: Mahdi Navari; modified to compute CDF for precipitation ! ! !USES: diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index e8663b3d0..3304edb6a 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -16,6 +16,7 @@ module LDT_DApreprocMod ! ! !REVISION HISTORY: ! 24 Nov 2008 Sujay Kumar Initial Specification +! 2 Dec 2021: Mahdi Navari; modified to stratify CDF based on precipitation ! use ESMF From 67bb2bf4ad314d364f4ad04be7d54d2afdddb44d Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Thu, 16 Dec 2021 11:51:22 -0500 Subject: [PATCH 017/328] Added support to stratify CDF using both landcover and precipitation --- ldt/core/LDT_CDFMod.F90 | 67 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 66 insertions(+), 1 deletion(-) diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index ec7586751..ad45e9490 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -215,7 +215,7 @@ subroutine computeSingleCDF(n,obs, metrics) integer :: t,i,j,k integer :: c,r - integer :: sindex + integer :: sindex,sindex0,sindex1 integer, allocatable :: strat_bincounts(:,:,:,:) real, allocatable :: strat_cdf(:,:,:,:) ! real :: datamask(LDT_rc%ngrid(n)) @@ -363,6 +363,71 @@ subroutine computeSingleCDF(n,obs, metrics) deallocate(strat_bincounts) deallocate(strat_cdf) + elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.1 ) then + + allocate(strat_bincounts(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels,& + LDT_rc%cdf_nbins)) + allocate(strat_cdf(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels,& + LDT_rc%cdf_nbins)) + + strat_bincounts = 0 + strat_cdf = 0 + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + do i=1,LDT_rc%cdf_nbins + sindex0 = LDT_rc%stratification_data(t) + sindex1 = LDT_rc%cdf_strat_data(t) + sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins + strat_bincounts(sindex,j,k,i) = & + strat_bincounts(sindex,j,k,i) + & + metrics%cdf_bincounts(t,j,k,i) + + enddo + enddo + enddo + enddo + + do t=1,LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + if(sum(strat_bincounts(t,j,k,:)).ne.0) then + strat_cdf(t,j,k,1) = & + strat_bincounts(t,j,k,1)/& ! strat_cdf(t,j,k,1)/& + float(sum(strat_bincounts(t,j,k,:))) + do i=2,LDT_rc%cdf_nbins + strat_cdf(t,j,k,i) = strat_cdf(t,j,k,i-1) + & + strat_bincounts(t,j,k,i)/& + float(sum(strat_bincounts(t,j,k,:))) + enddo + endif + enddo + enddo + enddo + + do t=1,LDT_rc%ngrid(n) +! if(datamask(t).gt.0) then + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + do i=1,LDT_rc%cdf_nbins + sindex0 = LDT_rc%stratification_data(t) + sindex1 = LDT_rc%cdf_strat_data(t) + sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins + metrics%cdf(t,j,k,i) = strat_cdf(sindex,j,k,i) + enddo + enddo + enddo +! endif + enddo + + deallocate(strat_bincounts) + deallocate(strat_cdf) + endif endif endif From cc8823659b62895db1cdb9f782250779c3575f14 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Thu, 6 Jan 2022 18:13:51 -0500 Subject: [PATCH 018/328] filled water bodies --- ldt/params/Noah/Noah_parmsMod.F90 | 18 +++++++++++--- ldt/params/Noah/module_MMF_groundwater.F90 | 29 +++++++++++----------- 2 files changed, 28 insertions(+), 19 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 42e98346d..529088d0a 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -513,26 +513,36 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) - + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%watervalue,label='FDEPTH water value:', DEFAULT= 100., rc=rc) + call LDT_verify(rc,"FDEPTH water value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc); call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%watervalue,label='RECHCLIM water value:',DEFAULT=0., rc=rc) + call LDT_verify(rc,"RECHCLIM water value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc); call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%watervalue,label='RIVERBED water value:',DEFAULT=-100., rc=rc) + call LDT_verify(rc,"RIVERBED water value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc); call LDT_verify(rc,"EQWTD neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%watervalue,label='EQWTD water value:',DEFAULT = 0., rc=rc) + call LDT_verify(rc,"EQWTD fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc); call LDT_verify(rc,"HGT_M neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%watervalue,label='HGT_M water value:',DEFAULT=-100.,rc=rc) + call LDT_verify(rc,"HGT_M fill value not defined." ) do n = 1,LDT_rc%nnest diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 6f2df2460..c6d5f8a42 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -280,29 +280,28 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) nbins = size (lisout, 3) - ! WPS's STEP1 : average from the nerighborhood - ! -------------------------------------------- + !Average from the nerighborhood + ! ----------------------------- call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & mmf_transform, & nbins, & - lisout, LDT_rc%udef, & + lisout, LDT_rc%udef, & LDT_LSMparam_struc(nest)%landmask2%value, & MBR%neighbor%filltype, MBR%neighbor%fillvalue, & MBR%neighbor%fillradius ) - ! WPS's STEP2 : Search and fill - ! ----------------------------- - - if (trim (MBR%gap_fill%filltype) /= 'none') then - call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & - mmf_transform, & - nbins, & - lisout, LDT_rc%udef, & - LDT_LSMparam_struc(nest)%landmask2%value, & - MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & - MBR%gap_fill%fillradius ) - endif + ! Search and fill -also fill lakes + ! -------------------------------- + + call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & + mmf_transform, & + nbins, & + lisout, MBR%gap_fill%watervalue, & + LDT_LSMparam_struc(nest)%landmask2%value, & + MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & + MBR%gap_fill%fillradius ) + deallocate (tarray, garray) contains From 0d99ca1e4d858f65a01068325ef4ad325609a982 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Mon, 24 Jan 2022 14:37:38 -0500 Subject: [PATCH 019/328] Added support for soil moisture CDF stratification using monthly precipitation climatology. The original CDF stratification based on max daily precipitation was in the following branches feature/cdf_stratification_precip_landcover feature/cdf_strat_write_precip_stat_into_file --- .../LISlsmPrecipobs/read_Precip_climo.F90 | 208 ++++++++++++++++++ ldt/core/LDT_CDFMod.F90 | 12 +- ldt/core/LDT_DApreprocMod.F90 | 55 ++++- ldt/core/LDT_PRIV_rcMod.F90 | 2 +- 4 files changed, 263 insertions(+), 14 deletions(-) create mode 100644 ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 new file mode 100644 index 000000000..3edff6fa5 --- /dev/null +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -0,0 +1,208 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LDT_misc.h" +#include "LDT_NetCDF_inc.h" +!BOP +! !ROUTINE: read_Precip_climo +! \label{read_Precip_climo} + +! !REVISION HISTORY: +! 19Jan2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: +subroutine read_Precip_climo(ncol, nrow, filename, precip) + + use LDT_coreMod + use LDT_logMod + use LDT_historyMod +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: +! integer, intent(in) :: n +! integer, intent(in) :: k +! integer, intent(in) :: nbins +! integer, intent(in) :: ntimes + integer, intent(in) :: ncol, nrow + character(len=*), intent(in) :: filename +! character(len=*) :: varname + real :: precip(ncol,nrow,12) + !real :: cdf(ngrid,ntimes, nbins) + logical :: file_exists +! +! !DESCRIPTION: +! This routine reads the input CDF file (generated by LDT in NETCDF format) +! The xrange values and the corresponding CDFs are read for each grid point. +! Both these fields are expected to be in the 1-d grid vector dimension. +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[nbins] number of bins used to compute the model and obs CDFs +! \item[filename] name of the CDF file +! \item[varname] name of the variable being extracted. +! \item[xrange] x-axis values corresponding to the CDF +! \item[cdf] y-axis (CDF) values corresponding to the CDF +! \end{description} +!EOP + ! integer :: j,kk + ! integer :: ngridId, nbinsId, nlevsId, ntimesId + ! integer :: ngrid_file, nbins_file, nlevs_file, ntimes_file + ! integer :: xid, cdfid + real, allocatable :: precip_climo(:,:,:) + !real, allocatable :: P_month(:,:) + !integer :: nid + integer :: ios,nid,ncId,nrId,varId + integer :: nc,nr,i,c,r + character*3 :: month_name(12) + + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) + + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + inquire(file=trim(filename), exist=file_exists) + if(file_exists) then + + write(LDT_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) + !if(ngrid.gt.0) then + call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + ios = nf90_inq_dimid(nid,"east_west",ncId) + call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + + ios = nf90_inq_dimid(nid,"north_south",nrId) + call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + + ios = nf90_inquire_dimension(nid,ncId, len=nc) + call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + + ios = nf90_inquire_dimension(nid,nrId, len=nr) + call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + + if (ncol .ne. nc .or. nrow .ne.nr) then + write(LDT_logunit,*) & + '[ERR] The number of columns or rows specified in the file '//& + trim(filename) + write(LDT_logunit,*) '[ERR] (', nc, nr, & + ') is different from the number of columns and rows specified' + write(LDT_logunit,*) '[ERR] in the ldt.config file (', ncol, nrow, ')' + call LDT_endrun() + endif + + ! allocate(P_month(nc,nr)) + allocate(precip_climo(nc,nr,12)) + + do i=1,12 + ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) + call LDT_verify(ios,'Precipitation climo field not found in the file') + + ios = nf90_get_var(nid,varId,precip_climo(:,:,i)) + call LDT_verify(ios,'Error in nf90_get_var in LDT_procDataForREAL') + enddo + + ios = nf90_close(nid) + call LDT_verify(ios,'Error in nf90_close in readldtparam_real_2d') + write(LDT_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) + endif + + precip = precip_climo + deallocate(precip_climo) + + +#IF 0 + call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & + 'nf90_inq_dimid failed for ngrid') + call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & + 'nf90_inq_dimid failed for nbins') + call LDT_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & + 'nf90_inq_dimid failed for '//trim(varname)//"_levels") + call LDT_verify(nf90_inq_dimid(nid,"ntimes",ntimesId), & + 'nf90_inq_dimid failed for ntimes') + + + call LDT_verify(nf90_inquire_dimension(nid,ngridId, len=ngrid_file),& + 'nf90_inquire_dimension failed for ngrid') + call LDT_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& + 'nf90_inquire_dimension failed for ntimes') + + !if(nbins.ne.nbins_file) then + ! write(LDT_logunit,*) '[ERR] The number of bins specified in the file '//& + ! trim(filename) + ! write(LDT_logunit,*) '[ERR] (',nbins_file, & + ! ') is different from the number of bins specified' + ! write(LDT_logunit,*) '[ERR] in the lis.config file (',nbins,')' + ! call LDT_endrun() + !endif + + if (ntimes_file .gt. 1) then + write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& + trim(filename) + write(LDT_logunit,*) '[ERR] (',ntimes_file, & + ') should be 1 set the Temporal resolution of precipitation CDFs to "yearly" ' + call LDT_endrun() + endif + + !allocate(xrange(ngrid_file,2)) + allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) + !allocate(cdf_file(ngrid_file,nlevs_file, nbins)) + + do j=1,ntimes_file + call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& + 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') + !call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_CDF',cdfid),& + ! 'nf90_inq_varid failed for '//trim(varname)//'_CDF') + + call LDT_verify(nf90_get_var(nid,xid,xrange_file, & + start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& + 'nf90_get_var failed for '//trim(varname)//'_xrange') + !call LDT_verify(nf90_get_var(nid,cdfid,cdf_file,& + ! start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins/)),& + ! 'nf90_get_var failed for '//trim(varname)//'_CDF') + +! Note: CDF is generated by LDT --> therefore data is in the LDT domain +#IF 0 + if(ngrid.gt.0) then + do kk=1,nbins + call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & + xrange(:,j,kk)) + call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & + cdf(:,j,kk)) + enddo + endif +#ENDIF + enddo + + xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell + xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell +! xrange = xrange_file +! cdf = cdf_file + + deallocate(xrange_file) + !deallocate(cdf_file) + + call LDT_verify(nf90_close(nid),& + 'failed to close file '//trim(filename)) + write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) + !endif +#ENDIF + +! end USE_NETCDF4 +#endif + +end subroutine read_Precip_climo + diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index ad45e9490..b44eb386d 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -299,8 +299,8 @@ subroutine computeSingleCDF(n,obs, metrics) deallocate(strat_bincounts) deallocate(strat_cdf) -!MN: Startification based on total precipitation -! min and max of total precipitation for each pixel are stored in LDT_rc%stratification_data +!MN: Startification based on monthly precipitation climatology +! monthly total precipitation climatology for each pixel are stored in LDT_rc%stratification_data elseif(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.1 ) then @@ -320,7 +320,7 @@ subroutine computeSingleCDF(n,obs, metrics) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins - sindex = LDT_rc%stratification_data(t) + sindex = LDT_rc%stratification_data(t,j) strat_bincounts(sindex,j,k,i) = & strat_bincounts(sindex,j,k,i) + & metrics%cdf_bincounts(t,j,k,i) @@ -352,7 +352,7 @@ subroutine computeSingleCDF(n,obs, metrics) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins - sindex = LDT_rc%stratification_data(t) + sindex = LDT_rc%stratification_data(t,j) metrics%cdf(t,j,k,i) = strat_cdf(sindex,j,k,i) enddo enddo @@ -381,7 +381,7 @@ subroutine computeSingleCDF(n,obs, metrics) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins - sindex0 = LDT_rc%stratification_data(t) + sindex0 = LDT_rc%stratification_data(t,j) sindex1 = LDT_rc%cdf_strat_data(t) sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins strat_bincounts(sindex,j,k,i) = & @@ -415,7 +415,7 @@ subroutine computeSingleCDF(n,obs, metrics) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins - sindex0 = LDT_rc%stratification_data(t) + sindex0 = LDT_rc%stratification_data(t,j) sindex1 = LDT_rc%cdf_strat_data(t) sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins metrics%cdf(t,j,k,i) = strat_cdf(sindex,j,k,i) diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index 3304edb6a..ba940d670 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -54,13 +54,13 @@ subroutine LDT_DApreprocInit() character*20 :: tres integer :: rc integer :: n - integer :: c,r + integer :: c,r,j integer :: ios1 integer :: ftn character*50 :: preprocMethod real :: delta real, allocatable :: cdf_strat_data(:,:) - real, allocatable :: stratification_data(:,:) + real, allocatable :: stratification_data(:,:,:) n = 1 call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%obs_src,& label="DA observation source:",rc=rc) @@ -156,9 +156,15 @@ subroutine LDT_DApreprocInit() do c=1,LDT_rc%lnc(n) if(LDT_domain(n)%gindex(c,r).ne.-1) then - LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = & + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = & nint((cdf_strat_data(c,r) - LDT_rc%group_cdfs_min)/& delta)+1 + if (LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) .gt. LDT_rc%group_cdfs_nbins) then + write(LDT_logunit,*) '[INFO] Group bins is larger then Max Group bins',& + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)), 'vs.', LDT_rc%group_cdfs_nbins ,& + 'Value adjusted the Max Group bins' + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = LDT_rc%group_cdfs_nbins + endif endif enddo enddo @@ -168,8 +174,8 @@ subroutine LDT_DApreprocInit() trim(LDT_rc%group_cdfs_strat_file) endif -!This part reads the dynamic range of precipitation and generates -! stratification input data based on total precipitation. +!This part reads the monthly total precipitation climatology and generates +! stratification input data LDT_rc%stratification_data(LDT_rc%ngrid(n),LDT_rc%cdf_ntimes). call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_cdfs,& label="Stratify CDFs by external data:",default=0, rc=rc) @@ -186,7 +192,38 @@ subroutine LDT_DApreprocInit() call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_file,& label="External stratification file:",rc=rc) call LDT_verify(rc,"External stratification file: not defined") - + + allocate(LDT_rc%stratification_data(LDT_rc%ngrid(n),LDT_rc%cdf_ntimes)) + allocate(stratification_data(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%cdf_ntimes)) + + call read_Precip_climo (LDT_rc%lnc(n), LDT_rc%lnr(n), LDT_rc%strat_file, stratification_data) ! + + do j=1,LDT_rc%cdf_ntimes + LDT_rc%strat_cdfs_min = 0. !minval returns -9999. minval(stratification_data(:,:,j)) ! min value over the entire domain + LDT_rc%strat_cdfs_max = maxval(stratification_data(:,:,j)) ! max value over the entire domain + delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& + LDT_rc%strat_cdfs_nbins + print*, 'month,min,man,delta', j,LDT_rc%strat_cdfs_min, LDT_rc%strat_cdfs_max, delta + + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + if(LDT_domain(n)%gindex(c,r).ne.-1) then + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = & + nint((stratification_data(c,r,j) - LDT_rc%strat_cdfs_min)/& + delta)+1 + if (LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) .gt. LDT_rc%strat_cdfs_nbins) then + write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& + 'Value adjusted the Max Startification bins' + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins + endif + endif + enddo + enddo + enddo + + +#IF 0 !if(LDT_rc%strat_cdfs.gt.0) then allocate(LDT_rc%stratification_data(LDT_rc%ngrid(n))) allocate(stratification_data(LDT_rc%ngrid(n),2)) @@ -219,9 +256,13 @@ subroutine LDT_DApreprocInit() ! read(ftn,*) ! read(ftn,*) LDT_rc%strat_cdfs_nbins ! call LDT_releaseUnitNumber(ftn) +#ENDIF endif endif - + + + + if(LDT_rc%comp_obsgrid.eq.1) then LDT_rc%pass = 0 else diff --git a/ldt/core/LDT_PRIV_rcMod.F90 b/ldt/core/LDT_PRIV_rcMod.F90 index ab840c9cf..558f241e5 100644 --- a/ldt/core/LDT_PRIV_rcMod.F90 +++ b/ldt/core/LDT_PRIV_rcMod.F90 @@ -366,7 +366,7 @@ module LDT_PRIV_rcMod integer :: strat_cdfs_nbins real :: strat_cdfs_min real :: strat_cdfs_max - integer, allocatable :: stratification_data(:) + integer, allocatable :: stratification_data(:,:) integer :: sp_sampl_cdfs From 87460a9a278606a75fc88f17e0d4ae2d25efb8dc Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Thu, 3 Feb 2022 13:03:27 -0500 Subject: [PATCH 020/328] a bug fix call read_geogrid, revised the array dimension to match the GEOGRID tile border --- ldt/params/Noah/module_MMF_groundwater.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index c6d5f8a42..7f1c4ae6a 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -254,7 +254,7 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) geogridFile = trim(datadir)//trim(tileName) rc = read_geogrid(trim(geogridFile),len(trim(geogridFile)),tarray, & - MBR%gp%tile_x,MBR%gp%tile_y,MBR%gp%tile_z,MBR%gp%isigned,MBR%gp%endian,1.,MBR%gp%wordsize,status) + nlon_tile_bdr,nlat_tile_bdr,MBR%gp%tile_z,MBR%gp%isigned,MBR%gp%endian,1.,MBR%gp%wordsize,status) if (rc == 1 .or. status == 1) then write(LDT_logunit,*) '[ERROR] reading GEOGRID file : ',trim(geogridFile) From a8a6d247b74baea4ae75dfde97fc851c7d92e708 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Thu, 17 Feb 2022 12:47:05 -0500 Subject: [PATCH 021/328] Bugfix: Apply the stratification to the X-range --- ldt/core/LDT_DApreprocMod.F90 | 2 +- ldt/core/LDT_DrangeMod.F90 | 208 +++++++++++++++++++++++++++++++++- 2 files changed, 206 insertions(+), 4 deletions(-) diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index ba940d670..e355cfaa5 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -214,7 +214,7 @@ subroutine LDT_DApreprocInit() if (LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) .gt. LDT_rc%strat_cdfs_nbins) then write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& - 'Value adjusted the Max Startification bins' + 'Value adjusted to the Max Startification bins' LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins endif endif diff --git a/ldt/core/LDT_DrangeMod.F90 b/ldt/core/LDT_DrangeMod.F90 index 2a81484da..342baffe9 100644 --- a/ldt/core/LDT_DrangeMod.F90 +++ b/ldt/core/LDT_DrangeMod.F90 @@ -17,6 +17,7 @@ module LDT_DrangeMod ! ! !REVISION HISTORY: ! 2 Oct 2008 Sujay Kumar Initial Specification +! 16 Feb 2022 Mahdi Navari; modified to stratify CDF based on precipitation ! !EOP use LDT_DAobsDataMod @@ -209,7 +210,7 @@ subroutine computeSingleDrange(n,obs, metrics) type(DAmetricsEntry) :: metrics integer :: t,i,j,k,c,r - integer :: sindex + integer :: sindex,sindex0,sindex1 real, allocatable :: strat_xrange(:,:,:,:) real, allocatable :: strat_delta(:,:,:) real, allocatable :: strat_mask(:,:,:) @@ -221,7 +222,7 @@ subroutine computeSingleDrange(n,obs, metrics) if(LDT_rc%endtime.eq.1) then if(obs%selectOpt.eq.1.and.metrics%selectOpt.eq.1) then - if(LDT_rc%group_cdfs.eq.0) then + if(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.0) then do t=1,LDT_rc%ngrid(n) do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels @@ -246,7 +247,7 @@ subroutine computeSingleDrange(n,obs, metrics) enddo enddo enddo - elseif(LDT_rc%group_cdfs.eq.1) then + elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.0) then allocate(strat_drange_total(LDT_rc%group_cdfs_nbins, & LDT_rc%cdf_ntimes, & obs%vlevels)) @@ -344,6 +345,207 @@ subroutine computeSingleDrange(n,obs, metrics) deallocate(strat_mask) deallocate(strat_delta) +!MN: Startification based on monthly precipitation climatology +! monthly total precipitation climatology for each pixel are stored in LDT_rc%stratification_data + + elseif(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.1) then + allocate(strat_drange_total(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_maxval(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_minval(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_mask(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_delta(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_xrange(LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels, & + LDT_rc%cdf_nbins)) + + strat_drange_total = 0 + strat_maxval = -1000000.0 + strat_minval = 1000000.0 + strat_mask = 0 + strat_delta = 0 + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + sindex = LDT_rc%stratification_data(t,j) + strat_drange_total(sindex,j,k) = & + strat_drange_total(sindex,j,k) + & + metrics%count_drange_total(t,j,k) + if(metrics%maxval(t,j,k).gt.& + strat_maxval(sindex,j,k)) then + strat_maxval(sindex,j,k) = metrics%maxval(t,j,k) + endif + if(metrics%minval(t,j,k).lt.& + strat_minval(sindex,j,k)) then + strat_minval(sindex,j,k) = metrics%minval(t,j,k) + endif + enddo + enddo + enddo + + do t=1,LDT_rc%strat_cdfs_nbins + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + if(strat_drange_total(t,j,k).le.& + LDT_rc%obsCountThreshold) then + strat_maxval(t,j,k) = LDT_rc%udef + strat_minval(t,j,k) = LDT_rc%udef + strat_mask(t,j,k) = LDT_rc%udef + else + strat_mask(t,j,k) = strat_drange_total(t,j,k) + strat_delta(t,j,k) = & + (strat_maxval(t,j,k) - & + strat_minval(t,j,k))/& + (LDT_rc%cdf_nbins-1) + strat_xrange(t,j,k,1) = strat_minval(t,j,k) + do i=2, LDT_rc%cdf_nbins + strat_xrange(t,j,k,i) = & + strat_xrange(t,j,k,i-1) + & + strat_delta(t,j,k) + + enddo + endif + enddo + enddo + enddo + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + sindex = LDT_rc%stratification_data(t,j) + if(strat_mask(sindex,j,k).eq.LDT_rc%udef) then + metrics%maxval(t,j,k) = LDT_rc%udef + metrics%minval(t,j,k) = LDT_rc%udef + metrics%mask(t,j,k) = LDT_rc%udef + else + metrics%mask(t,j,k) = strat_mask(sindex,j,k) + metrics%delta(t,j,k) = strat_delta(sindex,j,k) + metrics%xrange(t,j,k,:) =strat_xrange(sindex,j,k,:) + + metrics%maxval(t,j,k) = strat_maxval(sindex,j,k) + metrics%minval(t,j,k) = strat_minval(sindex,j,k) + endif + enddo + enddo + enddo + deallocate(strat_drange_total) + deallocate(strat_maxval) + deallocate(strat_minval) + deallocate(strat_mask) + deallocate(strat_delta) + + elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.1) then + allocate(strat_drange_total(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_maxval(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_minval(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_mask(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_delta(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels)) + allocate(strat_xrange(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & + LDT_rc%cdf_ntimes, & + obs%vlevels, & + LDT_rc%cdf_nbins)) + + strat_drange_total = 0 + strat_maxval = -1000000.0 + strat_minval = 1000000.0 + strat_mask = 0 + strat_delta = 0 + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + sindex0 = LDT_rc%stratification_data(t,j) + sindex1 = LDT_rc%cdf_strat_data(t) + sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins + strat_drange_total(sindex,j,k) = & + strat_drange_total(sindex,j,k) + & + metrics%count_drange_total(t,j,k) + if(metrics%maxval(t,j,k).gt.& + strat_maxval(sindex,j,k)) then + strat_maxval(sindex,j,k) = metrics%maxval(t,j,k) + endif + if(metrics%minval(t,j,k).lt.& + strat_minval(sindex,j,k)) then + strat_minval(sindex,j,k) = metrics%minval(t,j,k) + endif + enddo + enddo + enddo + + do t=1,LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + if(strat_drange_total(t,j,k).le.& + LDT_rc%obsCountThreshold) then + strat_maxval(t,j,k) = LDT_rc%udef + strat_minval(t,j,k) = LDT_rc%udef + strat_mask(t,j,k) = LDT_rc%udef + else + strat_mask(t,j,k) = strat_drange_total(t,j,k) + strat_delta(t,j,k) = & + (strat_maxval(t,j,k) - & + strat_minval(t,j,k))/& + (LDT_rc%cdf_nbins-1) + strat_xrange(t,j,k,1) = strat_minval(t,j,k) + do i=2, LDT_rc%cdf_nbins + strat_xrange(t,j,k,i) = & + strat_xrange(t,j,k,i-1) + & + strat_delta(t,j,k) + + enddo + endif + enddo + enddo + enddo + + do t=1,LDT_rc%ngrid(n) + do j=1,LDT_rc%cdf_ntimes + do k=1,obs%vlevels + sindex0 = LDT_rc%stratification_data(t,j) + sindex1 = LDT_rc%cdf_strat_data(t) + sindex = sindex0 + (sindex1 - 1)*LDT_rc%strat_cdfs_nbins + if(strat_mask(sindex,j,k).eq.LDT_rc%udef) then + metrics%maxval(t,j,k) = LDT_rc%udef + metrics%minval(t,j,k) = LDT_rc%udef + metrics%mask(t,j,k) = LDT_rc%udef + else + metrics%mask(t,j,k) = strat_mask(sindex,j,k) + metrics%delta(t,j,k) = strat_delta(sindex,j,k) + metrics%xrange(t,j,k,:) =strat_xrange(sindex,j,k,:) + + metrics%maxval(t,j,k) = strat_maxval(sindex,j,k) + metrics%minval(t,j,k) = strat_minval(sindex,j,k) + endif + enddo + enddo + enddo + deallocate(strat_drange_total) + deallocate(strat_maxval) + deallocate(strat_minval) + deallocate(strat_mask) + deallocate(strat_delta) + endif endif endif From df0d1fccf3f8652f93acc865c98f423e76423860 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Fri, 11 Mar 2022 18:01:15 -0500 Subject: [PATCH 022/328] Added support to LDT to stratify CDF using precipitation climatology and save the stratified CDF for CDF transfer method. --- ldt/core/LDT_CDFMod.F90 | 9 +- ldt/core/LDT_DAmetricsDataMod.F90 | 4 + ldt/core/LDT_DAmetricsMod.F90 | 222 +++++++++++++++++++++++++++++- ldt/core/LDT_DApreprocMod.F90 | 7 +- ldt/core/LDT_DrangeMod.F90 | 6 +- ldt/core/LDT_PRIV_rcMod.F90 | 3 + 6 files changed, 243 insertions(+), 8 deletions(-) diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index b44eb386d..2d15fd754 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -18,6 +18,7 @@ module LDT_CDFMod ! !REVISION HISTORY: ! 2 Oct 2008 Sujay Kumar Initial Specification ! 2 Dec 2021: Mahdi Navari; modified to stratify CDF based on precipitation +! and save the stratified CDF ! !EOP use LDT_DAobsDataMod @@ -295,7 +296,8 @@ subroutine computeSingleCDF(n,obs, metrics) enddo ! endif enddo - + ! MN: save stratified CDF + metrics%strat_cdf = strat_cdf deallocate(strat_bincounts) deallocate(strat_cdf) @@ -359,7 +361,8 @@ subroutine computeSingleCDF(n,obs, metrics) enddo ! endif enddo - + ! MN: save stratified CDF + metrics%strat_cdf = strat_cdf deallocate(strat_bincounts) deallocate(strat_cdf) @@ -425,6 +428,8 @@ subroutine computeSingleCDF(n,obs, metrics) ! endif enddo + ! MN: save stratified CDF + metrics%strat_cdf = strat_cdf deallocate(strat_bincounts) deallocate(strat_cdf) diff --git a/ldt/core/LDT_DAmetricsDataMod.F90 b/ldt/core/LDT_DAmetricsDataMod.F90 index 3cc28402c..679607312 100644 --- a/ldt/core/LDT_DAmetricsDataMod.F90 +++ b/ldt/core/LDT_DAmetricsDataMod.F90 @@ -18,6 +18,7 @@ module LDT_DAmetricsDataMod ! ! !REVISION HISTORY: ! 02 Oct 2008: Sujay Kumar; Initial version +! 28 Feb 2022: Mahdi navari modified to save stratified CDFs ! ! !USES: use ESMF @@ -36,6 +37,9 @@ module LDT_DAmetricsDataMod real, allocatable :: delta(:,:,:) real, allocatable :: xrange(:,:,:,:) real, allocatable :: cdf(:,:,:,:) + real, allocatable :: strat_xrange(:,:,:,:) + real, allocatable :: strat_cdf(:,:,:,:) + real, allocatable :: sx_mu(:,:,:) real, allocatable :: mu(:,:,:) diff --git a/ldt/core/LDT_DAmetricsMod.F90 b/ldt/core/LDT_DAmetricsMod.F90 index d6bd38666..4fad4eefc 100644 --- a/ldt/core/LDT_DAmetricsMod.F90 +++ b/ldt/core/LDT_DAmetricsMod.F90 @@ -588,7 +588,34 @@ subroutine initMetricsEntry(nsize, obs, metrics) LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) allocate(metrics%cdf(nsize,& LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) - + + if(LDT_rc%write_strat_cdfs.eq.1) then + if(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.0) then + allocate(metrics%strat_xrange(LDT_rc%group_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + allocate(metrics%strat_cdf(LDT_rc%group_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + LDT_rc%stratified_cdfs_nbins = LDT_rc%group_cdfs_nbins + elseif(LDT_rc%group_cdfs.eq.0 .and. LDT_rc%strat_cdfs.eq.1 ) then + allocate(metrics%strat_xrange(LDT_rc%strat_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + allocate(metrics%strat_cdf(LDT_rc%strat_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + LDT_rc%stratified_cdfs_nbins = LDT_rc%strat_cdfs_nbins + elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.1 ) then + allocate(metrics%strat_xrange(LDT_rc%group_cdfs_nbins*& + LDT_rc%strat_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + allocate(metrics%strat_cdf(LDT_rc%group_cdfs_nbins*& + LDT_rc%strat_cdfs_nbins,& + LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) + LDT_rc%stratified_cdfs_nbins = LDT_rc%group_cdfs_nbins*& + LDT_rc%strat_cdfs_nbins + endif + metrics%strat_xrange = 0 + metrics%strat_cdf = 0 + endif + metrics%cdf_bincounts = 0 metrics%delta = 0 metrics%xrange = 0 @@ -680,7 +707,7 @@ subroutine LDT_computeDAobsMetrics(n, pass) implicit none - character*100 :: fname_cdf + character*100 :: fname_cdf, fname_strat_cdf character*100 :: fname_domain integer :: pass integer :: rc @@ -720,6 +747,14 @@ subroutine LDT_computeDAobsMetrics(n, pass) write(LDT_logunit,*) 'Writing CDF domain file ',trim(fname_domain) iret=nf90_create(path=trim(fname_domain),cmode=nf90_clobber,& ncid=LDT_rc%ftn_DAobs_domain) + + if(LDT_rc%write_strat_cdfs.eq.1) then + fname_strat_cdf = trim(LDT_rc%odir)//'/stratified_'//& + trim(LDT_rc%dapreprocfile)//'.nc' + write(LDT_logunit,*) 'Writing stratified CDF file ',trim(fname_strat_cdf) + iret=nf90_create(path=trim(fname_strat_cdf),cmode=nf90_clobber,& + ncid=LDT_rc%ftn_strat_cdf) + endif endif #endif #if (defined USE_NETCDF4) @@ -734,7 +769,16 @@ subroutine LDT_computeDAobsMetrics(n, pass) write(LDT_logunit,*) 'Writing CDF domain file ',trim(fname_domain) iret=nf90_create(path=trim(fname_domain),cmode=nf90_netcdf4,& ncid=LDT_rc%ftn_DAobs_domain) + + if(LDT_rc%write_strat_cdfs.eq.1) then + fname_strat_cdf = trim(LDT_rc%odir)//'/stratified_'//& + trim(LDT_rc%dapreprocfile)//'.nc' + write(LDT_logunit,*) 'Writing stratified CDF file ',trim(fname_strat_cdf) + iret=nf90_create(path=trim(fname_strat_cdf),cmode=nf90_netcdf4,& + ncid=LDT_rc%ftn_strat_cdf) + endif endif + #endif call outputFinalMetrics(n,pass) @@ -744,6 +788,10 @@ subroutine LDT_computeDAobsMetrics(n, pass) write(LDT_logunit,*) 'Successfully wrote CDF file ',trim(fname_cdf) iret=nf90_close(LDT_rc%ftn_DAobs_domain) write(LDT_logunit,*) 'Successfully wrote CDF file ',trim(fname_domain) + if(LDT_rc%write_strat_cdfs.eq.1) then + iret=nf90_close(LDT_rc%ftn_strat_cdf) + write(LDT_logunit,*) 'Successfully wrote geolocation independent stratified CDF file ',trim(fname_strat_cdf) + endif endif #endif @@ -778,7 +826,7 @@ subroutine outputFinalMetrics(n,pass) !EOP integer :: index integer :: c,r - integer :: dimID(4) + integer :: dimID(4), dimID_strat(4) integer :: bdimID(3) character(len=8) :: date character(len=10) :: time @@ -840,6 +888,52 @@ subroutine outputFinalMetrics(n,pass) LDT_DAobsDataPtr(1,index)%dataEntryPtr) enddo + +! geolocation independent stratified CDF + if(LDT_rc%write_strat_cdfs.eq.1) then +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + call LDT_verify(nf90_def_dim(LDT_rc%ftn_strat_cdf,'n_strat_bins',& + LDT_rc%stratified_cdfs_nbins,dimID_strat(1)),'nf90_def_dim failed for n_strat_bins') + call LDT_verify(nf90_def_dim(LDT_rc%ftn_strat_cdf,'ntimes',& + LDT_rc%cdf_ntimes,dimID_strat(2)),'nf90_def_dim failed for ntimes') + call LDT_verify(nf90_def_dim(LDT_rc%ftn_strat_cdf,'nbins',& + LDT_rc%cdf_nbins,dimID_strat(4)),'nf90_def_dim failed for nbins') + + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,& + "missing_value", -9999.0)) + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,& + "temporal_resolution_CDF", LDT_rc%cdf_ntimes)) + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,& + "title", & + "Land Data Toolkit (LDT) output")) + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,& + "institution", & + "NASA GSFC Hydrological Sciences Laboratory")) + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,& + "history", & + "created on date: "//date(1:4)//"-"//date(5:6)//"-"//& + date(7:8)//"T"//time(1:2)//":"//time(3:4)//":"//time(5:10))) + !call LDT_verify(nf90_put_att(LDT_rc%ftn_cdf,NF90_GLOBAL,"references", & + ! "Arsenault_etal_GMD_2018, Kumar_etal_EMS_2006")) + call LDT_verify(nf90_put_att(LDT_rc%ftn_strat_cdf,NF90_GLOBAL,"comment", & + "website: http://lis.gsfc.nasa.gov/")) +#endif + do index=1,LDT_DA_MOC_COUNT + call writeFinalSingleStratifiedCDFEntryHeader(LDT_DAmetricsPtr(index)%dataEntryPtr,& + LDT_DAobsDataPtr(1,index)%dataEntryPtr, dimID_strat) + enddo + +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + call LDT_verify(nf90_enddef(LDT_rc%ftn_strat_cdf)) +#endif + + do index=1,LDT_DA_MOC_COUNT + call writeFinalSingleStratifiedCDFEntry(pass,LDT_DAmetricsPtr(index)%dataEntryPtr,& + LDT_DAobsDataPtr(1,index)%dataEntryPtr) + enddo + + endif + !domain file #if (defined USE_NETCDF3 || defined USE_NETCDF4) @@ -1308,6 +1402,73 @@ subroutine writeFinalSingleEntryHeader(metrics, obs, dimID) end subroutine writeFinalSingleEntryHeader +!BOP +! !ROUTINE: writeFinalSingleStratifiedCDFEntryHeader +! \label{writeFinalSingleStratifiedCDFEntryHeader} +! +! !INTERFACE: + subroutine writeFinalSingleStratifiedCDFEntryHeader(metrics, obs, dimID) +! !USES: + use LDT_coreMod, only : LDT_rc + use LDT_historyMod, only : LDT_writevar_gridded + + implicit none +! !ARGUMENTS: + type(DAmetricsEntry) :: metrics + type(LDT_DAmetadataEntry) :: obs + integer :: dimID(4) +! +! !DESCRIPTION: +! This routine writes the specified set of statistics for a +! single variable at the end of the analysis. +!EOP + + integer :: k + integer :: varid1, varid2 + integer :: i,c,r + integer :: n + character*100 :: vname + integer :: shuffle, deflate, deflate_level + +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + n = 1 + shuffle = NETCDF_shuffle + deflate = NETCDF_deflate + deflate_level =NETCDF_deflate_level + + if(obs%selectOpt.eq.1.and.metrics%selectOpt.eq.1) then + vname = trim(obs%standard_name)//'_levels' + call LDT_verify(nf90_def_dim(LDT_rc%ftn_strat_cdf,trim(vname),& + obs%vlevels,dimID(3))) + + if(LDT_rc%write_strat_cdfs.eq.1) then + call LDT_verify(nf90_def_var(LDT_rc%ftn_strat_cdf,& + trim(obs%standard_name)//'_xrange_stratified',& + nf90_float, dimids = dimID, varid=obs%varID(1))) + +#if (defined USE_NETCDF4) + call LDT_verify(nf90_def_var_deflate(LDT_rc%ftn_strat_cdf,& + obs%varID(1), shuffle, deflate, deflate_level),& + 'nf90_def_var_deflate failed in LDT_DAmetricsMod') +#endif + + call LDT_verify(nf90_def_var(LDT_rc%ftn_strat_cdf,& + trim(obs%standard_name)//'_CDF_stratified',& + nf90_float, dimids = dimID, varid=obs%varID(4))) + +#if (defined USE_NETCDF4) + call LDT_verify(nf90_def_var_deflate(LDT_rc%ftn_strat_cdf,& + obs%varID(4), shuffle, deflate, deflate_level),& + 'nf90_def_var_deflate failed in LDT_DAmetricsMod') +#endif + endif + + endif +#endif + + end subroutine writeFinalSingleStratifiedCDFEntryHeader + + !BOP ! !ROUTINE: writeFinalSingleEntry @@ -1362,6 +1523,61 @@ subroutine writeFinalSingleEntry(pass,metrics, obs) end subroutine writeFinalSingleEntry +!BOP +! !ROUTINE: writeFinalSingleStratifiedCDFEntry +! \label{writeFinalSingleStratifiedCDFEntry} +! +! !INTERFACE: + subroutine writeFinalSingleStratifiedCDFEntry(pass,metrics, obs) +! !USES: + use LDT_coreMod, only : LDT_rc + use LDT_historyMod, only : LDT_writevar_gridded + + implicit none +! !ARGUMENTS: + integer :: pass + type(DAmetricsEntry) :: metrics + type(LDT_DAmetadataEntry) :: obs +! +! !DESCRIPTION: +! This routine writes the specified set of statistics for a +! single variable at the end of the analysis. +!EOP + + integer :: k + integer :: varid, varid2 + integer :: i,c,r + integer :: n + integer :: iret + + n = 1 + if(obs%selectOpt.eq.1.and.metrics%selectOpt.eq.1) then + + if(pass.eq.2.and.LDT_rc%comp_cdf.eq.1) then +! MN: The LDT_writevar_gridded is not generic it assumes the +! first dimension of CDF related vaialbes is LDT_rc%glbngrid(n) +! But for geolocation independent CDFs the first dimension is +! LDT_rc%stratified_cdfs_nbins +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + if(LDT_rc%write_strat_cdfs.eq.1) then + iret = nf90_put_var(LDT_rc%ftn_strat_cdf,obs%varID(1),metrics%strat_xrange,(/1,1,1,1/),& + (/LDT_rc%stratified_cdfs_nbins,LDT_rc%cdf_ntimes, & + obs%vlevels, LDT_rc%cdf_nbins/)) + call LDT_verify(iret, 'nf90_put_var failed in writevar_gridded_real_4d') + + iret = nf90_put_var(LDT_rc%ftn_strat_cdf,obs%varID(4),metrics%strat_cdf,(/1,1,1,1/),& + (/LDT_rc%stratified_cdfs_nbins, LDT_rc%cdf_ntimes, & + obs%vlevels, LDT_rc%cdf_nbins/)) + call LDT_verify(iret, 'nf90_put_var failed in writevar_gridded_real_4d') + endif +#endif + + endif + endif + + end subroutine writeFinalSingleStratifiedCDFEntry + + !BOP ! !ROUTINE: writeFinalSingleDomainEntryHeader ! \label{writeFinalSingleDomainEntryHeader} diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index e355cfaa5..e03f1cd74 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -16,7 +16,7 @@ module LDT_DApreprocMod ! ! !REVISION HISTORY: ! 24 Nov 2008 Sujay Kumar Initial Specification -! 2 Dec 2021: Mahdi Navari; modified to stratify CDF based on precipitation +! 2 Dec 2021: Mahdi Navari; modified to save stratify CDF ! use ESMF @@ -180,6 +180,11 @@ subroutine LDT_DApreprocInit() call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_cdfs,& label="Stratify CDFs by external data:",default=0, rc=rc) call LDT_verify(rc,"Stratify CDFs by external data: not defined") + + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%write_strat_cdfs,& + label="Write stratified geolocation independent CDFs:",default=0, rc=rc) + call LDT_verify(rc,"Write stratify geolocation independent CDFs:: not defined") + if(LDT_rc%strat_cdfs.gt.0) then call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%strat_src,& label="Stratification data source:", rc=rc) diff --git a/ldt/core/LDT_DrangeMod.F90 b/ldt/core/LDT_DrangeMod.F90 index 342baffe9..d7d024e0a 100644 --- a/ldt/core/LDT_DrangeMod.F90 +++ b/ldt/core/LDT_DrangeMod.F90 @@ -17,7 +17,7 @@ module LDT_DrangeMod ! ! !REVISION HISTORY: ! 2 Oct 2008 Sujay Kumar Initial Specification -! 16 Feb 2022 Mahdi Navari; modified to stratify CDF based on precipitation +! 16 Feb 2022 Mahdi Navari; modified to save stratify CDF ! !EOP use LDT_DAobsDataMod @@ -338,7 +338,7 @@ subroutine computeSingleDrange(n,obs, metrics) enddo enddo enddo - + metrics%strat_xrange = strat_xrange deallocate(strat_drange_total) deallocate(strat_maxval) deallocate(strat_minval) @@ -439,6 +439,7 @@ subroutine computeSingleDrange(n,obs, metrics) enddo enddo enddo + metrics%strat_xrange = strat_xrange deallocate(strat_drange_total) deallocate(strat_maxval) deallocate(strat_minval) @@ -540,6 +541,7 @@ subroutine computeSingleDrange(n,obs, metrics) enddo enddo enddo + metrics%strat_xrange = strat_xrange deallocate(strat_drange_total) deallocate(strat_maxval) deallocate(strat_minval) diff --git a/ldt/core/LDT_PRIV_rcMod.F90 b/ldt/core/LDT_PRIV_rcMod.F90 index 558f241e5..e501c6996 100644 --- a/ldt/core/LDT_PRIV_rcMod.F90 +++ b/ldt/core/LDT_PRIV_rcMod.F90 @@ -360,10 +360,12 @@ module LDT_PRIV_rcMod integer :: group_cdfs_nbins integer :: strat_cdfs + integer :: write_strat_cdfs character*50 :: strat_src character*50 :: strat_file !character*50 :: strat_cdfs_attrib_file integer :: strat_cdfs_nbins + integer :: stratified_cdfs_nbins real :: strat_cdfs_min real :: strat_cdfs_max integer, allocatable :: stratification_data(:,:) @@ -383,6 +385,7 @@ module LDT_PRIV_rcMod integer :: pass_id integer :: ftn_cdf + integer :: ftn_strat_cdf integer :: ftn_DAobs_domain character*100 :: institution = 'NASA GSFC' From a2edb898dd97b012a8cf00fb83edb436006bafb1 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Fri, 11 Mar 2022 18:06:34 -0500 Subject: [PATCH 023/328] Added support to LIS to use stratified geolocation independent soil moisture for CDF matching. --- lis/configs/lis.config.adoc | 27 + lis/core/LIS_dataAssimMod.F90 | 554 +++++++ .../cdfTransfer_NASASMAPsm_Mod.F90 | 575 +++++++ .../read_cdfTransfer_NASASMAPsm.F90 | 1475 +++++++++++++++++ .../write_cdfTransfer_NASASMAPsmobs.F90 | 122 ++ lis/make/default.cfg | 4 + lis/plugins/LIS_DAobs_pluginMod.F90 | 19 + lis/plugins/LIS_lsmda_pluginMod.F90 | 20 + lis/plugins/LIS_pluginIndices.F90 | 2 + 9 files changed, 2798 insertions(+) create mode 100644 lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 create mode 100644 lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 create mode 100644 lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 65f99a570..093361c11 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -3038,6 +3038,33 @@ SMAP(NRT) CDF read option: .... +[[sssec_cdftransfersmda,Transfering stratified CDFs from one domain to another]] +==== Transfering stratified CDFs from one domain to another + +`Use CDF transfer for soil moisture data assimilation:` specifies +whether to use CDF transfer method + +`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory + +`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory + +`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF + +'Reference domain precipitation climatology data source:' specifies the reference domain precipitation climatology generated by LVT + +'Target domain precipitation climatology data source:' specifies the target domain precipitation climatology generated by LVT + + +.Example _lis.config_ entry +.... +Use CDF transfer for soil moisture data assimilation: +Reference domain model CDF file: +Reference domain obs CDF file: +Number of bins in the soil moisture CDF: +Reference domain precipitation climatology data source: +Target domain precipitation climatology data source: +.... + [[sssec_smapnasavodda,SMAP (NASA) vegetation optical depth assimilation]] ==== SMAP (NASA) vegetation optical depth assimilation diff --git a/lis/core/LIS_dataAssimMod.F90 b/lis/core/LIS_dataAssimMod.F90 index 3a333ccfc..99f0464b4 100644 --- a/lis/core/LIS_dataAssimMod.F90 +++ b/lis/core/LIS_dataAssimMod.F90 @@ -52,6 +52,11 @@ module LIS_dataAssimMod ! 7 Sep 2017 Mahdi Navari; set a condition to deal the skewness of the both model and obs CDF ! 1 Apr 2019 Yonghwan Kwon; include an option to read soil moisture CDF information for each month separately ! 5 Mar 2021 Eric Kemp; reduced memory usage in read_CDFdata_month +! 25 Feb 2022 Mahdi Navari; added LIS_getCDFtransferattributes +! LIS_rescale_with_stratified_CDF +! read_CDFtransferdata_all +! read_Precip_climo_maxval +! read_Precip_climo ! ! !USES: use ESMF @@ -59,6 +64,7 @@ module LIS_dataAssimMod use LIS_logMod use LIS_historyMod use LIS_DAobservationsMod + use LIS_mpiMod #if(defined USE_NETCDF3 || defined USE_NETCDF4) use netcdf @@ -82,6 +88,11 @@ module LIS_dataAssimMod public :: LIS_readCDFdata !read the CDF files generated by LDT public :: LIS_readMeanSigmaData public :: LIS_forwardEstimate_with_ANN + public :: LIS_getCDFtransferattributes + public :: LIS_rescale_with_stratified_CDF + public :: read_CDFtransferdata_all + public :: read_Precip_climo + public :: read_Precip_climo_maxval !EOP public :: LIS_DA_struc @@ -986,6 +997,176 @@ subroutine LIS_rescale_with_anomaly(& TRACE_EXIT("DA_rescaleAno") end subroutine LIS_rescale_with_anomaly !------------------------------------------------------------------kyh20210422 +! +!MN 2022.02.24 +!BOP +! +! !ROUTINE: LIS_rescale_with_stratified_CDF +! \label{LIS_rescale_with_stratified_CDF} + +! !REVISION HISTORY: +! 3 March 2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: + subroutine LIS_rescale_with_stratified_CDF(& + n, & + k, & + nbins, & + ntimes, & + max_obs_value, & + min_obs_value, & + model_xrange, & + obs_xrange, & + model_cdf, & + obs_cdf, & + ref_precip_climo_maxval, & + target_precip_climo,& + n_strat_bins,& + obs_value) + + + implicit none +! +! !ARGUMENTS: + integer :: n + integer :: k + integer :: nbins + integer :: n_strat_bins + integer :: ntimes + real :: max_obs_value + real :: min_obs_value + real :: model_xrange(n_strat_bins,ntimes, nbins) + real :: obs_xrange(n_strat_bins,ntimes, nbins) + real :: model_cdf(n_strat_bins,ntimes, nbins) + real :: obs_cdf(n_strat_bins,ntimes, nbins) + real :: obs_value(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k)) + !real :: ref_precip_climo(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k),ntimes) + real :: ref_precip_climo_maxval(ntimes) + real :: target_precip_climo(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k),ntimes) +! +! !DESCRIPTION: +! +! This routine rescales the input observation data to the model's +! climatology so that the cumulative distribution functions (CDFs) +! of the observations and the model match (But we use geolocation +! independent CDF, therefore we match the input observation data to +! model's climatology for each stratified bins not for each grid point). +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[nbins] number of bins used to compute the model and obs CDFs +! \item[max\_obs\_value] maximum allowable value of observation +! \item[min\_obs\_value] minimum allowable value of observation +! \item[model\_xrange] x-axis values corresponding to the model CDF +! \item[obs\_xrange] x-axis values corresponding to the obs CDF +! \item[model\_cdf] y-axis (CDF) values corresponding to the model CDF +! \item[obs\_cdf] y-axis (CDF) values corresponding to the obs CDF +! \item[obs\_value] observation value to be rescaled. +! \end{description} +!EOP + + real :: model_delta(n_strat_bins) + real :: obs_delta(n_strat_bins) + real :: ref_p_min, ref_p_max,delta_p_ref + integer :: t,i,kk + integer :: binval, strat_binval + integer :: col,row + real :: cdf_obsval + real :: obs_tmp, obs_in + integer, dimension (1) :: index_25 , index_75 + real :: Lb_xrange, Ub_xrange, iqr_obs, iqr_model + + + if(ntimes.gt.1) then + kk = LIS_rc%mo + else + kk = 1 + endif + do t=1,n_strat_bins + model_delta(t) = model_xrange(t,kk,2)-model_xrange(t,kk,1) + obs_delta(t) = obs_xrange(t,kk,2)-obs_xrange(t,kk,1) + enddo + do t=1,LIS_rc%obs_ngrid(k) + + col = LIS_obs_domain(n,k)%col(t) + row = LIS_obs_domain(n,k)%row(t) + + ! find the reference CDF stratification bin value for each grid cell + if(target_precip_climo(col,row,kk).ne.-9999.0) then + ref_p_min = 0. !minval returns -9999. minval(ref_precip_climo(:,:,j)) ! min value over the entire domain + !ref_p_max = maxval(ref_precip_climo(:,:,kk)) ! max value over the entire domain + ref_p_max = ref_precip_climo_maxval(kk) ! max value over the entire domain + delta_p_ref = (ref_p_max-ref_p_min)/& + n_strat_bins + strat_binval = nint( (target_precip_climo(col,row,kk)-ref_p_min)/& + delta_p_ref)+1 + if(strat_binval.gt.n_strat_bins) strat_binval = n_strat_bins + if(strat_binval.le.0) strat_binval = 1 + endif + + index_25 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.25)) + index_75 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.75)) + Lb_xrange = obs_xrange(strat_binval,kk,index_25(1)) + Ub_xrange = obs_xrange(strat_binval,kk,index_75(1)) + iqr_obs = Ub_xrange - Lb_xrange + + index_25 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.25)) + index_75 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.75)) + Lb_xrange = model_xrange(strat_binval,kk,index_25(1)) + Ub_xrange = model_xrange(strat_binval,kk,index_75(1)) + iqr_model = Ub_xrange - Lb_xrange + + if( iqr_obs .lt. 0.05 * (obs_xrange(strat_binval,kk,nbins)-obs_xrange(strat_binval,kk,1)) .or. & + iqr_model .lt. 0.05 * (model_xrange(strat_binval,kk,nbins)-model_xrange(strat_binval,kk,1)) ) then + obs_delta(strat_binval) = 0 + endif + + + if(obs_value(col,row).ne.-9999.0) then + obs_in = obs_value(col,row) + if(obs_delta(strat_binval).gt.0) then + binval = nint((obs_value(col,row)-obs_xrange(strat_binval,kk,1))/& + obs_delta(strat_binval))+1 + if(binval.gt.nbins) binval = nbins + if(binval.le.0) binval = 1 + cdf_obsval = obs_cdf(strat_binval,kk,binval) + if(cdf_obsval.gt.1.0) cdf_obsval = 1.0 + i=1 + do while((model_cdf(strat_binval,kk,i).lt.cdf_obsval).and.& + (i.le.nbins)) + i = i+1 + if(i.gt.nbins) exit + enddo + if(i.gt.nbins) i = i-1 + obs_tmp = model_xrange(strat_binval,kk,i) + + if(obs_tmp.gt.max_obs_value) then +! obs_tmp = max_obs_value + obs_tmp = LIS_rc%udef + endif + + if(obs_tmp.le.min_obs_value) then +! obs_tmp = obs_value(col,row) + obs_tmp = LIS_rc%udef + endif + obs_value(col,row) = obs_tmp + else + obs_value(col,row) = LIS_rc%udef + endif + if(obs_value(col,row).le.min_obs_value.and.& + obs_value(col,row).ne.-9999.0) then + write(LIS_logunit,*) '[ERR] Problem in CDF scaling of observations in the DA instance ',k + write(LIS_logunit,*) '[ERR] ',col,row,obs_value(col,row), obs_in + call LIS_endrun() + endif + else + obs_value(col,row) = LIS_rc%udef + endif + enddo + !TRACE_EXIT("DA_rescaleCDF") + end subroutine LIS_rescale_with_stratified_CDF +!MN 2022.02.24 !BOP @@ -1045,10 +1226,65 @@ subroutine LIS_getCDFattributes(k,filename, ntimes, ngrid) end subroutine LIS_getCDFattributes +!BOP +! !ROUTINE: LIS_getCDFtransferattributes +! \label{LIS_getCDFtransferattributes} + +! !REVISION HISTORY: +! 3 March 2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: + subroutine LIS_getCDFtransferattributes(k,filename, n_strat_bins, ntimes) + + implicit none +! !ARGUMENTS: + integer :: k + character(len=*), intent(in) :: filename + integer :: ntimes + integer :: n_strat_bins +! +! !DESCRIPTION: +! This routine reads the number of stratification bins abd other CDF attribute from the +! CDF file +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[ntimes] temporal resolution of the CDFs +! \end{description} +!EOP + + integer :: nid, binid + + !TRACE_ENTER("DA_getCDFatt") +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + call LIS_verify(nf90_inq_dimid(nid, 'n_strat_bins',binId), & + 'Error nf90_inq_dimid: n_strat_bins') + + call LIS_verify(nf90_inquire_dimension(nid, binId, len=n_strat_bins), & + 'Error nf90_inquire_dimension:n_strat_bins') + + call LIS_verify(nf90_get_att(nid, NF90_GLOBAL, & + 'temporal_resolution_CDF', & + ntimes), & + 'Error in nf90_get_att: temporal_resolution_CDF') + + call LIS_verify(nf90_close(nid)) +#endif + !TRACE_EXIT("DA_getCDFatt") + + end subroutine LIS_getCDFtransferattributes + !BOP ! !ROUTINE: read_CDFdata_all ! \label{read_CDFdata_all} + +! !REVISION HISTORY: +! 2 March 2022: Mahdi Navari ; Initial Specification ! ! !INTERFACE: subroutine read_CDFdata_all(n, k, nbins, ntimes, ngrid, & @@ -1471,6 +1707,324 @@ subroutine read_MeanSigmaData_month(n, k, ntimes, ngrid, filename, varname, mu, TRACE_EXIT("DA_readSigma") end subroutine read_MeanSigmaData_month + +!BOP +! !ROUTINE: read_CDFtransferdata_all +! \label{read_CDFtransferdata_all} +! !REVISION HISTORY: +! 1 March 2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: + subroutine read_CDFtransferdata_all(n, k, nbins, ntimes, n_strat_bins, & + filename, varname, xrange, cdf) + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: k + integer, intent(in) :: nbins + integer, intent(in) :: ntimes + integer, intent(in) :: n_strat_bins + character(len=*) :: filename + character(len=*) :: varname + real :: xrange(n_strat_bins,ntimes, nbins) + real :: cdf(n_strat_bins,ntimes, nbins) + +! +! !DESCRIPTION: +! This routine reads the input CDF file (generated by LDT in NETCDF format) +! The xrange values and the corresponding CDFs are read for each stratification bin. +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[nbins] number of bins used to compute the model and obs CDFs +! \item[filename] name of the CDF file +! \item[varname] name of the variable being extracted. +! \item[xrange] x-axis values corresponding to the CDF +! \item[cdf] y-axis (CDF) values corresponding to the CDF +! \end{description} +!EOP + integer :: j,kk + integer :: nstratbinId, nbinsId, nlevsId + integer :: nstratbin_file, nbins_file, nlevs_file + integer :: xid, cdfid + real, allocatable :: xrange_file(:,:,:,:) + real, allocatable :: cdf_file(:,:,:,:) + integer :: nid + + !TRACE_ENTER("DA_readCDF") +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + write(LIS_logunit,*) '[INFO] Reading stratified geolocation independent reference CDF file ',trim(filename) + !if(ngrid.gt.0) then + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + call LIS_verify(nf90_inq_dimid(nid,"n_strat_bins",nstratbinId), & + 'nf90_inq_dimid failed for n_strat_bins') + call LIS_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & + 'nf90_inq_dimid failed for nbins') + call LIS_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & + 'nf90_inq_dimid failed for '//trim(varname)//"_levels") + + call LIS_verify(nf90_inquire_dimension(nid,nstratbinId, len=nstratbin_file),& + 'nf90_inquire_dimension failed for n_strat_bins') + call LIS_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& + 'nf90_inquire_dimension failed for nbins') + call LIS_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& + 'nf90_inquire_dimension failed for nlevels') + + if(nbins.ne.nbins_file) then + write(LIS_logunit,*) '[ERR] The number of bins specified in the file '//& + trim(filename) + write(LIS_logunit,*) '[ERR] (',nbins_file, & + ') is different from the number of bins specified' + write(LIS_logunit,*) '[ERR] in the lis.config file (',nbins,')' + call LIS_endrun() + endif + + allocate(xrange_file(nstratbin_file,ntimes,nlevs_file,nbins)) + allocate(cdf_file(nstratbin_file,ntimes,nlevs_file,nbins)) + + !do j=1,ntimes + call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_xrange_stratified',xid),& + 'nf90_inq_varid failed for for '//trim(varname)//'_xrange_stratified') + call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_CDF_stratified',cdfid),& + 'nf90_inq_varid failed for '//trim(varname)//'_CDF_stratified') + + call LIS_verify(nf90_get_var(nid,xid,xrange_file, & + start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& + 'nf90_get_var failed for '//trim(varname)//'_xrange_stratified') + call LIS_verify(nf90_get_var(nid,cdfid,cdf_file,& + start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& + 'nf90_get_var failed for '//trim(varname)//'_CDF_stratified') + + !enddo + xrange = xrange_file(:,:,1,:) + cdf = cdf_file(:,:,1,:) + + deallocate(xrange_file) + deallocate(cdf_file) + + call LIS_verify(nf90_close(nid),& + 'failed to close file '//trim(filename)) + write(LIS_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) + !endif +#endif + ! TRACE_EXIT("DA_readCDF") + end subroutine read_CDFtransferdata_all + +!BOP +! !ROUTINE: read_Precip_climo +! \label{read_Precip_climo} + +! !REVISION HISTORY: +! 28 Feb 2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: +!subroutine read_Precip_climo(n,k,ncol, nrow, filename, precip) +subroutine read_Precip_climo(n,k, filename, precip) + use LIS_coreMod + use LIS_logMod + use LIS_historyMod +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: k + !integer, intent(in) :: ncol, nrow + character(len=*), intent(in) :: filename + real, allocatable, intent(inout) :: precip(:,:,:) + logical :: file_exists +! +! !DESCRIPTION: +! This routine reads the input CDF file (generated by LVT in NETCDF format) +! +! The arguments are: +! \begin{description} +! \item[filename] name of the CDF file +! \item[varname] name of the variable being extracted. +! \end{description} +!EOP + !real, allocatable :: precip_climo(:,:,:), gtmp1d(:),gtmp2d(:,:) + integer :: ios,nid,ncId,nrId,varId + integer :: gnc,gnr,gr,gc,nc,nr,i,c,r + character*3 :: month_name(12) + integer :: gindex,gid + integer :: ierr + + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) + + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + inquire(file=trim(filename), exist=file_exists) + if(file_exists) then + write(LIS_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) + !if(ngrid.gt.0) then + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + ios = nf90_inq_dimid(nid,"east_west",ncId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + + ios = nf90_inq_dimid(nid,"north_south",nrId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + + ios = nf90_inquire_dimension(nid,ncId, len=gnc) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + + ios = nf90_inquire_dimension(nid,nrId, len=gnr) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + + if (gnc .ne. LIS_rc%gnc(n) .or. gnr .ne. LIS_rc%gnr(n)) then + write(LIS_logunit,*) '[ERR] domain dimension mismatch. Number of rows and columns in the ' + write(LIS_logunit,*) 'precipitation climatology file differs from that in the LIS domain ' + call LIS_endrun() + endif + + !allocate(precip_climo(gnc,gnr,12)) + allocate(precip(gnc,gnr,12)) + do i=1,12 + ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) + call LIS_verify(ios,'Precipitation climo field not found in the file') + + ios = nf90_get_var(nid,varId,precip(:,:,i)) ! precip_climo(:,:,i)) + call LIS_verify(ios,'Error in nf90_get_var in read_Precip_climo') + enddo + + ios = nf90_close(nid) + call LIS_verify(ios,'Error in nf90_close in read_Precip_climo') + write(LIS_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) + endif + + !precip = precip_climo + !deallocate(precip_climo) + ! subset from the global 2-d space to the local 2-d space +! do i=1,12 +! precip(:,:,i) = precip_climo(& +! LIS_ews_halo_ind(n,LIS_localPet+1):& +! LIS_ewe_halo_ind(n,LIS_localPet+1), & +! LIS_nss_halo_ind(n,LIS_localPet+1): & +! LIS_nse_halo_ind(n,LIS_localPet+1),i) +! enddo +! deallocate(precip_climo) + +#IF 0 + if(ngrid.gt.0) then + do kk=1,nbins + call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & + xrange(:,j,kk)) + call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & + cdf(:,j,kk)) + enddo + endif +#ENDIF + +! end USE_NETCDF4 +#endif + +end subroutine read_Precip_climo + +!BOP +! !ROUTINE: read_Precip_climo +! \label{read_Precip_climo} + +! !REVISION HISTORY: +! 28 Feb 2022: Mahdi Navari ; Initial Specification +! +! !INTERFACE: +subroutine read_Precip_climo_maxval(n,filename, strat_cdfs_max) + + use LIS_coreMod + use LIS_logMod + use LIS_historyMod +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n +! integer, intent(in) :: k + !integer, intent(in) :: ncol, nrow + character(len=*), intent(in) :: filename + real :: strat_cdfs_max(12) + logical :: file_exists +! +! !DESCRIPTION: +! This routine reads the input CDF file (generated by LVT in NETCDF format) +! +! The arguments are: +! \begin{description} +! \item[filename] name of the CDF file +! \item[varname] name of the variable being extracted. +! \end{description} +!EOP + real, allocatable :: precip_climo(:,:,:) + integer :: ios,nid,ncId,nrId,varId + integer :: gnc,gnr,gr,gc,nc,nr,i,c,r + character*3 :: month_name(12) + integer :: gindex + + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) + + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + inquire(file=trim(filename), exist=file_exists) + if(file_exists) then + write(LIS_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) + !if(ngrid.gt.0) then + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + ios = nf90_inq_dimid(nid,"east_west",ncId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_precip_climo_maxval') + + ios = nf90_inq_dimid(nid,"north_south",nrId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_precip_climo_maxval') + + ios = nf90_inquire_dimension(nid,ncId, len=gnc) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo_maxval') + + ios = nf90_inquire_dimension(nid,nrId, len=gnr) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo_maxval') + + allocate(precip_climo(gnc,gnr,12)) + + do i=1,12 + ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) + call LIS_verify(ios,'Precipitation climo field not found in the file') + + ios = nf90_get_var(nid,varId,precip_climo(:,:,i)) + call LIS_verify(ios,'Error in nf90_get_var in read_Precip_climo_maxval') + enddo + + ios = nf90_close(nid) + call LIS_verify(ios,'Error in nf90_close in read_Precip_climo_maxval') + write(LIS_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) + endif + + !precip = precip_climo + !deallocate(precip_climo) + + ! Note: we just need Max and min values for each month (Min is zero) + do i=1,12 ! number of month + strat_cdfs_max(i) = maxval(precip_climo(:,:,i)) ! max value over the entire domain + enddo + + deallocate(precip_climo) + +! end USE_NETCDF4 +#endif + +end subroutine read_Precip_climo_maxval + + !BOP ! ! !ROUTINE: LIS_forwardEstimate_with_ANN diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 new file mode 100644 index 000000000..95986eb40 --- /dev/null +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 @@ -0,0 +1,575 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !MODULE: cdfTransfer_NASASMAPsm_Mod +! +! !DESCRIPTION: +! This module contains interfaces and subroutines to +! handle +! +! !REVISION HISTORY: +! 2 Mar 2022 Mahdi Navari; initial specification +! +module cdfTransfer_NASASMAPsm_Mod +! !USES: + use ESMF + use map_utils + + implicit none + + PRIVATE + +!----------------------------------------------------------------------------- +! !PUBLIC MEMBER FUNCTIONS: +!----------------------------------------------------------------------------- + public :: cdfTransfer_NASASMAPsm_setup +!----------------------------------------------------------------------------- +! !PUBLIC TYPES: +!----------------------------------------------------------------------------- + public :: cdfT_SMAPsm_struc +!EOP + type, public:: cdfT_SMAPsm_dec + + integer :: useSsdevScal + logical :: startMode + integer :: nc + integer :: nr + real, allocatable :: smobs(:,:) + real*8, allocatable :: smtime(:,:) + + real :: ssdev_inp + integer, allocatable :: n11(:) + real, allocatable :: rlat(:) + real, allocatable :: rlon(:) + + real, allocatable :: model_xrange(:,:,:) + real, allocatable :: obs_xrange(:,:,:) + real, allocatable :: model_cdf(:,:,:) + real, allocatable :: obs_cdf(:,:,:) + real, allocatable :: model_mu(:,:) + real, allocatable :: obs_mu(:,:) + real, allocatable :: model_sigma(:,:) + real, allocatable :: obs_sigma(:,:) + character*20 :: data_designation + character*3 :: release_number + integer :: nbins + integer :: ntimes + + logical :: cdf_read_mon !(for reading monthly CDF when + !LIS_rc%da > 1 but the first model time step, + !e.g., 4/29 13:00:00) + integer :: cdf_read_opt ! 0: read all months at one time + ! 1: read only the current month + character*100 :: modelcdffile + character*100 :: obscdffile + integer :: n_strat_bins + integer :: useCDFtransfer + character*100 :: ref_p_climo_file + character*100 :: target_p_climo_file + !real, allocatable :: ref_p_climo(:,:,:) + real, allocatable :: ref_p_climo_maxval(:) + real, allocatable :: target_p_climo(:,:,:) + + end type cdfT_SMAPsm_dec + + type(cdfT_SMAPsm_dec),allocatable :: cdfT_SMAPsm_struc(:) + +contains + +!BOP +! +! !ROUTINE: cdfTransfer_NASASMAPsm_setup +! \label{cdfTransfer_NASASMAPsm_setup} +! +! !INTERFACE: + subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) +! !USES: + use LIS_coreMod + use LIS_timeMgrMod + use LIS_historyMod + use LIS_dataAssimMod + use LIS_perturbMod + use LIS_DAobservationsMod + use LIS_logmod + + implicit none + +! !ARGUMENTS: + integer :: k + type(ESMF_State) :: OBS_State(LIS_rc%nnest) + type(ESMF_State) :: OBS_Pert_State(LIS_rc%nnest) +! +! !DESCRIPTION: +! +! This routine completes the runtime initializations and +! creation of data strctures required for handling NASASMAP +! soil moisture data. +! +! The arguments are: +! \begin{description} +! \item[OBS\_State] observation state +! \item[OBS\_Pert\_State] observation perturbations state +! \end{description} +!EOP + real, parameter :: minssdev =0.001 + integer :: n,i,t,kk,jj + integer :: ftn + integer :: status + type(ESMF_Field) :: obsField(LIS_rc%nnest) + type(ESMF_ArraySpec) :: intarrspec, realarrspec + type(ESMF_Field) :: pertField(LIS_rc%nnest) + type(ESMF_ArraySpec) :: pertArrSpec + character*100 :: rtsmopssmobsdir + character*100 :: temp + real, allocatable :: obsstd(:) + character*1 :: vid(2) + character*40, allocatable :: vname(:) + real , allocatable :: varmin(:) + real , allocatable :: varmax(:) + type(pert_dec_type) :: obs_pert + real, pointer :: obs_temp(:,:) + real :: gridDesci(50) + real, allocatable :: ssdev(:) + + real, allocatable :: obserr(:,:) + real, allocatable :: lobserr(:,:) + integer :: c,r + real, allocatable :: ssdev_grid(:,:) + integer :: ngrid + real, allocatable :: target_precip_climo(:,:,:) + + allocate(cdfT_SMAPsm_struc(LIS_rc%nnest)) + + call ESMF_ArraySpecSet(intarrspec,rank=1,typekind=ESMF_TYPEKIND_I4,& + rc=status) + call LIS_verify(status) + + call ESMF_ArraySpecSet(realarrspec,rank=1,typekind=ESMF_TYPEKIND_R4,& + rc=status) + call LIS_verify(status) + + call ESMF_ArraySpecSet(pertArrSpec,rank=2,typekind=ESMF_TYPEKIND_R4,& + rc=status) + call LIS_verify(status) + + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) soil moisture data directory:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,rtsmopssmobsdir,& + rc=status) + call LIS_verify(status, 'SMAP(NASA) soil moisture data directory: is missing') + + call ESMF_AttributeSet(OBS_State(n),"Data Directory",& + rtsmopssmobsdir, rc=status) + call LIS_verify(status) + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) soil moisture data designation:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%data_designation,& + rc=status) + call LIS_verify(status, 'SMAP(NASA) soil moisture data designation: is missing') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) soil moisture Composite Release ID:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%release_number,& + rc=status) + call LIS_verify(status, 'SMAP(NASA) soil moisture Composite Release ID: is missing') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) soil moisture use scaled standard deviation model:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%useSsdevScal,& + rc=status) + call LIS_verify(status, 'SMAP(NASA) soil moisture use scaled standard deviation model: is missing') + + enddo +#IF 0 + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) model CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%modelcdffile,rc=status) + call LIS_verify(status, 'SMAP(NASA) model CDF file: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) observation CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%obscdffile,rc=status) + call LIS_verify(status, 'SMAP(NASA) observation CDF file: not defined') + enddo +#ENDIF + call ESMF_ConfigFindLabel(LIS_config, "SMAP(NASA) soil moisture number of bins in the CDF:", rc=status) + do n=1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) + call LIS_verify(status, "SMAP(NASA) soil moisture number of bins in the CDF: not defined") + enddo +#IF 0 + do n=1, LIS_rc%nnest + cdfT_SMAPsm_struc(n)%cdf_read_mon = .false. + + call ESMF_ConfigFindLabel(LIS_config, "SMAP(NASA) CDF read option:", rc=status) ! 0: read CDF for all months/year + ! 1: read CDF for current month + call ESMF_ConfigGetAttribute(LIS_config, cdfT_SMAPsm_struc(n)%cdf_read_opt, rc=status) + call LIS_verify(status, "SMAP(NASA) CDF read option: not defined") + enddo +#ENDIF + + call ESMF_ConfigFindLabel(LIS_config,"Use CDF transfer for soil moisture data assimilation:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%useCDFtransfer,& + default=0,rc=status) + call LIS_verify(status, 'Use CDF transfer for soil moisture data assimilation: is missing') + enddo + + !if(cdfT_SMAPsm_struc(n)%useCDFtransfer.gt.0) then + call ESMF_ConfigFindLabel(LIS_config,"Reference domain model CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%modelcdffile,& + rc=status) + call LIS_verify(status, 'Reference domain model CDF file: is missing') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"Reference domain obs CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%obscdffile,& + rc=status) + call LIS_verify(status, 'Reference domain obs CDF file: is missing') + enddo +#IF 0 + call ESMF_ConfigFindLabel(LIS_config, "Number of bins in the soil moisture CDF:", rc=status) + do n=1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) + call LIS_verify(status, "Number of bins in the soil moisture CDF not defined") + enddo +#ENDIF + + call ESMF_ConfigFindLabel(LIS_config,"Reference domain precipitation climatology data source:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%ref_p_climo_file,& + rc=status) + call LIS_verify(status, 'Reference domain precipitation climatology data source: is missing') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"Target domain precipitation climatology data source:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%target_p_climo_file,& + rc=status) + call LIS_verify(status, 'Target domain precipitation climatology data source: is missing') + enddo + + + do n=1,LIS_rc%nnest + call ESMF_AttributeSet(OBS_State(n),"Data Update Status",& + .false., rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(OBS_State(n),"Data Update Time",& + -99.0, rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(OBS_State(n),"Data Assimilate Status",& + .false., rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(OBS_State(n),"Number Of Observations",& + LIS_rc%obs_ngrid(k),rc=status) + call LIS_verify(status) + + enddo + + write(LIS_logunit,*)& + '[INFO] read reference and target domains precipitation climatology data' +!-------------------------------------------------------------------------------- +! Data must be in the local domain +! The stratified CDF is geolocation independent +! Subset the precipition climotology to local space +!------------------------------------------------------------------------------- + do n=1,LIS_rc%nnest + !allocate(cdfT_SMAPsm_struc(n)%ref_p_climo(LIS_rc%lnc(n), LIS_rc%lnr(n), cdfT_SMAPsm_struc(n)%ntimes)) + allocate(cdfT_SMAPsm_struc(n)%ref_p_climo_maxval(12)) !cdfT_SMAPsm_struc(n)%ntimes)) + allocate(cdfT_SMAPsm_struc(n)%target_p_climo(LIS_rc%lnc(n), LIS_rc%lnr(n),12)) !cdfT_SMAPsm_struc(n)%ntimes)) + ! Note: we do not need to know the dimenesions of the reference domain precip climatology + ! for allocation so we just extract max value for each month + + call read_Precip_climo_maxval (n,cdfT_SMAPsm_struc(n)%ref_p_climo_file,& + cdfT_SMAPsm_struc(n)%ref_p_climo_maxval) + + !call read_Precip_climo (n,k,LIS_rc%lnc(n), LIS_rc%lnr(n),& + ! cdfT_SMAPsm_struc(n)%target_p_climo_file,& + ! cdfT_SMAPsm_struc(n)%target_p_climo) + call read_Precip_climo (n,k,& + cdfT_SMAPsm_struc(n)%target_p_climo_file,& + target_precip_climo) + + ! subset from the global 2-d space to the local 2-d space + do i=1,12 + cdfT_SMAPsm_struc(n)%target_p_climo(:,:,i) = target_precip_climo(& + LIS_ews_halo_ind(n,LIS_localPet+1):& + LIS_ewe_halo_ind(n,LIS_localPet+1), & + LIS_nss_halo_ind(n,LIS_localPet+1): & + LIS_nse_halo_ind(n,LIS_localPet+1),i) + enddo + enddo + + write(LIS_logunit,*)& + '[INFO] read SMAP(NASA) soil moisture data specifications' + +!---------------------------------------------------------------------------- +! Create the array containers that will contain the observations and +! the perturbations. NASASMAP +! observations are in the grid space. Since there is only one layer +! being assimilated, the array size is LIS_rc%obs_ngrid(k). +! +!---------------------------------------------------------------------------- + + do n=1,LIS_rc%nnest + + write(unit=temp,fmt='(i2.2)') 1 + read(unit=temp,fmt='(2a1)') vid + + obsField(n) = ESMF_FieldCreate(arrayspec=realarrspec,& + grid=LIS_obsvecGrid(n,k),& + name="Observation"//vid(1)//vid(2),rc=status) + call LIS_verify(status) + +!Perturbations State + write(LIS_logunit,*) '[INFO] Opening attributes for observations ',& + trim(LIS_rc%obsattribfile(k)) + ftn = LIS_getNextUnitNumber() + open(ftn,file=trim(LIS_rc%obsattribfile(k)),status='old') + read(ftn,*) + read(ftn,*) LIS_rc%nobtypes(k) + read(ftn,*) + + allocate(vname(LIS_rc%nobtypes(k))) + allocate(varmax(LIS_rc%nobtypes(k))) + allocate(varmin(LIS_rc%nobtypes(k))) + + do i=1,LIS_rc%nobtypes(k) + read(ftn,fmt='(a40)') vname(i) + read(ftn,*) varmin(i),varmax(i) + write(LIS_logunit,*) '[INFO] ',vname(i),varmin(i),varmax(i) + enddo + call LIS_releaseUnitNumber(ftn) + + allocate(ssdev(LIS_rc%obs_ngrid(k))) + + if(trim(LIS_rc%perturb_obs(k)).ne."none") then + allocate(obs_pert%vname(1)) + allocate(obs_pert%perttype(1)) + allocate(obs_pert%ssdev(1)) + allocate(obs_pert%stdmax(1)) + allocate(obs_pert%zeromean(1)) + allocate(obs_pert%tcorr(1)) + allocate(obs_pert%xcorr(1)) + allocate(obs_pert%ycorr(1)) + allocate(obs_pert%ccorr(1,1)) + + call LIS_readPertAttributes(1,LIS_rc%obspertAttribfile(k),& + obs_pert) + +! Set obs err to be uniform (will be rescaled later for each grid point). + ssdev = obs_pert%ssdev(1) + cdfT_SMAPsm_struc(n)%ssdev_inp = obs_pert%ssdev(1) + + pertField(n) = ESMF_FieldCreate(arrayspec=pertArrSpec,& + grid=LIS_obsensOnGrid(n,k),name="Observation"//vid(1)//vid(2),& + rc=status) + call LIS_verify(status) + +! initializing the perturbations to be zero + call ESMF_FieldGet(pertField(n),localDE=0,farrayPtr=obs_temp,rc=status) + call LIS_verify(status) + obs_temp(:,:) = 0 + + call ESMF_AttributeSet(pertField(n),"Perturbation Type",& + obs_pert%perttype(1), rc=status) + call LIS_verify(status) + + if(LIS_rc%obs_ngrid(k).gt.0) then + call ESMF_AttributeSet(pertField(n),"Standard Deviation",& + ssdev,itemCount=LIS_rc%obs_ngrid(k),rc=status) + call LIS_verify(status) + endif + + call ESMF_AttributeSet(pertField(n),"Std Normal Max",& + obs_pert%stdmax(1), rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(pertField(n),"Ensure Zero Mean",& + obs_pert%zeromean(1),rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(pertField(n),"Temporal Correlation Scale",& + obs_pert%tcorr(1),rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(pertField(n),"X Correlation Scale",& + obs_pert%xcorr(1),rc=status) + + call ESMF_AttributeSet(pertField(n),"Y Correlation Scale",& + obs_pert%ycorr(1),rc=status) + + call ESMF_AttributeSet(pertField(n),"Cross Correlation Strength",& + obs_pert%ccorr(1,:),itemCount=1,rc=status) + + endif + + deallocate(vname) + deallocate(varmax) + deallocate(varmin) + deallocate(ssdev) + + enddo + + write(LIS_logunit,*) & + '[INFO] Created the States to hold the SMAP NASA observations data' + do n=1,LIS_rc%nnest + if(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP") then + cdfT_SMAPsm_struc(n)%nc = 964 + cdfT_SMAPsm_struc(n)%nr = 406 + elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP") then + cdfT_SMAPsm_struc(n)%nc = 964 + cdfT_SMAPsm_struc(n)%nr = 406 + elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E") then + cdfT_SMAPsm_struc(n)%nc = 3856 + cdfT_SMAPsm_struc(n)%nr = 1624 + elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") then + cdfT_SMAPsm_struc(n)%nc = 3856 + cdfT_SMAPsm_struc(n)%nr = 1624 + endif + + allocate(cdfT_SMAPsm_struc(n)%smobs(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k))) + allocate(cdfT_SMAPsm_struc(n)%smtime(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k))) + + cdfT_SMAPsm_struc(n)%smtime = -1 + + enddo + + + write(LIS_logunit,*)& + '[INFO] read cdf transfer data specifications' + + + do n=1,LIS_rc%nnest + allocate(ssdev(LIS_rc%obs_ngrid(k))) + ssdev = obs_pert%ssdev(1) + + if(cdfT_SMAPsm_struc(n)%useCDFtransfer.gt.0) then ! LIS_rc%dascaloption(k).eq."CDF matching" .and. & + + call LIS_getCDFtransferattributes(k,cdfT_SMAPsm_struc(n)%modelcdffile,& + cdfT_SMAPsm_struc(n)%n_strat_bins , cdfT_SMAPsm_struc(n)%ntimes) + + allocate(cdfT_SMAPsm_struc(n)%model_xrange(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%obs_xrange(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%model_cdf(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%obs_cdf(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + endif + + if(cdfT_SMAPsm_struc(n)%useSsdevScal.eq.1) then + write(LIS_logunit,*) '[ERR] "use scaled standard deviation model" does not work ' + write(LIS_logunit,*) '[ERR] for CDF transfer method' + call LIS_endrun() + endif + + if(LIS_rc%obs_ngrid(k).gt.0) then + call ESMF_AttributeSet(pertField(n),"Standard Deviation",& + ssdev,itemCount=LIS_rc%obs_ngrid(k),rc=status) + call LIS_verify(status) + endif + + deallocate(ssdev) + enddo + + + do n=1,LIS_rc%nnest + if(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP".or.& + cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP") then + gridDesci = 0 + gridDesci(1) = 9 + gridDesci(2) = 964 + gridDesci(3) = 406 + gridDesci(9) = 4 !M36 grid + gridDesci(20) = 64 + gridDesci(10) = 0.36 + gridDesci(11) = 1 !for the global switch + elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E".or.& + cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") then + gridDesci = 0 + gridDesci(1) = 9 + gridDesci(2) = 3856 + gridDesci(3) = 1624 + gridDesci(9) = 5 !M09 grid + gridDesci(20) = 64 + gridDesci(10) = 0.09 + gridDesci(11) = 1 !for the global switch + endif + + allocate(cdfT_SMAPsm_struc(n)%n11(LIS_rc%obs_lnc(k)*& + LIS_rc%obs_lnr(k))) + allocate(cdfT_SMAPsm_struc(n)%rlat(& + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k))) + allocate(cdfT_SMAPsm_struc(n)%rlon(& + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k))) + + call neighbor_interp_input_withgrid(gridDesci,& + LIS_rc%obs_gridDesc(k,:),& + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k),& + cdfT_SMAPsm_struc(n)%rlat, & + cdfT_SMAPsm_struc(n)%rlon, & + cdfT_SMAPsm_struc(n)%n11) + + if(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP".or.& + cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E") then + call LIS_registerAlarm("NASASMAP read alarm",& + 86400.0, 86400.0) + else + call LIS_registerAlarm("NASASMAP read alarm",& + 3600.0, 3600.0) + endif + + cdfT_SMAPsm_struc(n)%startMode = .true. + + call ESMF_StateAdd(OBS_State(n),(/obsField(n)/),rc=status) + call LIS_verify(status) + + call ESMF_StateAdd(OBS_Pert_State(n),(/pertField(n)/),rc=status) + call LIS_verify(status) + + enddo + end subroutine cdfTransfer_NASASMAPsm_setup + +end module cdfTransfer_NASASMAPsm_Mod diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 new file mode 100644 index 000000000..6a30396da --- /dev/null +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 @@ -0,0 +1,1475 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! !ROUTINE: read_cdfTransfer_NASASMAPsm +! \label{read_cdfTransfer_NASASMAPsm} +! +! !REVISION HISTORY: +! 2 MAR 2022: Mahdi Navari: initial specification based on read_NASASMAPsm.F90 +! +! !INTERFACE: +subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) +! !USES: + use ESMF + use LIS_mpiMod + use LIS_coreMod + use LIS_logMod + use LIS_timeMgrMod + use LIS_dataAssimMod + use LIS_DAobservationsMod + use map_utils + use LIS_pluginIndices + use cdfTransfer_NASASMAPsm_Mod, only: cdfT_SMAPsm_struc + !use cdfTransfer_NASASMAPsm_Mod, only: cdfT_SMAPsm_struc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: k + type(ESMF_State) :: OBS_State + type(ESMF_State) :: OBS_Pert_State +! +! !DESCRIPTION: +! +! reads the AMSRE soil moisture observations +! from NETCDF files and applies the spatial masking for dense +! vegetation, rain and RFI. The data is then rescaled +! to the land surface model's climatology using rescaling +! algorithms. +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[OBS\_State] observations state +! \end{description} +! +!EOP + real, parameter :: minssdev = 0.05 + real, parameter :: maxssdev = 0.11 + real, parameter :: MAX_SM_VALUE = 0.45, MIN_SM_VALUE = 0.0001 + integer :: status + integer :: grid_index + character*100 :: smobsdir + character*100 :: fname + logical :: alarmCheck, file_exists + integer :: t, c, r, jj + real, pointer :: obsl(:) + type(ESMF_Field) :: smfield, pertField + integer :: gid(LIS_rc%obs_ngrid(k)) + integer :: assimflag(LIS_rc%obs_ngrid(k)) + real :: obs_unsc(LIS_rc%obs_ngrid(k)) + logical :: data_update + logical :: data_upd_flag(LIS_npes) + logical :: data_upd_flag_local + logical :: data_upd + real :: smobs(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: smobs_D(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: smobs_A(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: sm_current(LIS_rc%obs_lnc(k), LIS_rc%obs_lnr(k)) + real :: dt + real :: lon + real :: lhour + real :: gmt + integer :: zone + integer :: fnd + real, allocatable :: ssdev(:) + character*4 :: yyyy + character*8 :: yyyymmdd + character*2 :: mm, dd, hh + integer :: yr, mo, da, hr, mn, ss + integer :: cyr, cmo, cda, chr, cmn, css + integer :: nyr, nmo, nda, nhr, nmn, nss + real*8 :: timenow, time1,time2,time3 + integer :: doy + character*200 :: list_files + integer :: mn_ind + integer :: ftn, ierr + integer :: rc + character(len=3) :: CRID + integer, external :: create_filelist ! C function + + + call ESMF_AttributeGet(OBS_State, "Data Directory", & + smobsdir, rc=status) + call LIS_verify(status) + call ESMF_AttributeGet(OBS_State, "Data Update Status", & + data_update, rc=status) + call LIS_verify(status) + + data_upd = .false. + obs_unsc = LIS_rc%udef + + alarmCheck = LIS_isAlarmRinging(LIS_rc, "NASASMAP read alarm") + + smobs_A = LIS_rc%udef + smobs_D = LIS_rc%udef + + cyr = LIS_rc%yr + cmo = LIS_rc%mo + cda = LIS_rc%da + chr = LIS_rc%hr + cmn = LIS_rc%mn + css = LIS_rc%ss + + call LIS_tick(time1,doy,gmt,cyr,cmo,cda,chr,cmn,css,0.0) + nyr = LIS_rc%yr + nmo = LIS_rc%mo + nda = LIS_rc%da + nhr = LIS_rc%hr + nmn = LIS_rc%mn + nss = LIS_rc%ss + + call LIS_tick(time2,doy,gmt,nyr,nmo,nda,nhr,nmn,nss,3600.0) + nyr = LIS_rc%yr + nmo = LIS_rc%mo + nda = LIS_rc%da + nhr = LIS_rc%hr + nmn = LIS_rc%mn + nss = LIS_rc%ss + + call LIS_tick(time3,doy,gmt,nyr,nmo,nda,nhr,nmn,nss,LIS_rc%ts) + + if (alarmCheck .or. cdfT_SMAPsm_struc(n)%startMode) then + cdfT_SMAPsm_struc(n)%startMode = .false. + if ( (cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") .or. & + (cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP") ) then + + cdfT_SMAPsm_struc(n)%smobs = LIS_rc%udef + cdfT_SMAPsm_struc(n)%smtime = -1.0 + + write(yyyymmdd,'(i4.4,2i2.2)') LIS_rc%yr, LIS_rc%mo, LIS_rc%da + write(yyyy,'(i4.4)') LIS_rc%yr + write(mm,'(i2.2)') LIS_rc%mo + write(dd,'(i2.2)') LIS_rc%da + write(hh,'(i2.2)') LIS_rc%hr + + if(LIS_masterproc) then + list_files = trim(smobsdir)//'/'//trim(yyyy)//'.'//trim(mm)//'.'//& + trim(dd)//'/SMAP_L2_*' & + //trim(yyyy)//trim(mm)//trim(dd)//'T'//trim(hh)//'*.h5' + write(LIS_logunit,*) & + '[INFO] Searching for ',trim(list_files) + rc = create_filelist(trim(list_files)//char(0), & + "SMAP_filelist.sm.dat"//char(0)) + if (rc .ne. 0) then + write(LIS_logunit,*) & + '[WARN] Problem encountered when searching for SMAP files' + write(LIS_logunit,*) & + 'Was searching for ',trim(list_files) + write(LIS_logunit,*) & + 'LIS will continue...' + endif + end if +#if (defined SPMD) + call mpi_barrier(lis_mpi_comm,ierr) +#endif + + ftn = LIS_getNextUnitNumber() + open(ftn,file="./SMAP_filelist.sm.dat",status='old',iostat=ierr) + + do while(ierr.eq.0) + read(ftn,'(a)',iostat=ierr) fname + if(ierr.ne.0) then + exit + endif + + mn_ind = index(fname,trim(yyyymmdd)//'T'//trim(hh))+11 + read(fname(mn_ind:mn_ind+1),'(i2.2)') mn + ss=0 + call LIS_tick(timenow,doy,gmt,LIS_rc%yr, LIS_rc%mo, LIS_rc%da, & + LIS_rc%hr, mn, ss, 0.0) + + write(LIS_logunit,*) '[INFO] reading ',trim(fname) + + call read_SMAPL2sm_data_cdfTransfer(n,k,fname,& + cdfT_SMAPsm_struc(n)%smobs,timenow) + enddo + call LIS_releaseUnitNumber(ftn) + + elseif (cdfT_SMAPsm_struc(n)%data_designation .eq. "SPL3SMP_E") then +!--------------------------------------------------------------------------- +! MN: create filename for 9 km product +!--------------------------------------------------------------------------- + + write (yyyy, '(i4.4)') LIS_rc%yr + write (mm, '(i2.2)') LIS_rc%mo + write (dd, '(i2.2)') LIS_rc%da + write (CRID, '(a)') cdfT_SMAPsm_struc(n)%release_number + + ! EMK...Make sure only one PET calls the file system to determine what + ! SMAP files are available. + if (LIS_masterproc) then + + list_files = trim(smobsdir)//'/'//trim(yyyy)//'.'//trim(mm)//'.'// & + trim(dd)//'/SMAP_L3_SM_P_E_' & + //trim(yyyy)//trim(mm)//trim(dd)//'_'// & + trim(CRID)//'*.h5' + write(LIS_logunit,*) & + '[INFO] Searching for ',trim(list_files) + rc = create_filelist(trim(list_files)//char(0), & + "SMAP_filelist.dat"//char(0)) + if (rc .ne. 0) then + write(LIS_logunit,*) & + '[WARN] Problem encountered when searching for SMAP files' + write(LIS_logunit,*) & + 'Was searching for ',trim(list_files) + write(LIS_logunit,*) & + 'LIS will continue...' + endif + end if +#if (defined SPMD) + call mpi_barrier(lis_mpi_comm, ierr) +#endif + + ftn = LIS_getNextUnitNumber() + open (ftn, file="./SMAP_filelist.dat", & + action='read', status='old', iostat=ierr) + +! if multiple files for the same time and orbits are present, the latest +! one will overwrite older ones, though multiple (redundant) reads occur. +! This assumes that the 'ls command' will list the files in that order. + + do while (ierr .eq. 0) + read (ftn, '(a)', iostat=ierr) fname + if (ierr .ne. 0) then + exit + endif + + write (LIS_logunit, *) '[INFO] Reading descending pass ', trim(fname) + call read_NASASMAP_E_data_cdfTransfer(n, k, 'D', fname, smobs_D) + + write (LIS_logunit, *) '[INFO] Reading ascending pass ', trim(fname) + call read_NASASMAP_E_data_cdfTransfer(n, k, 'A', fname, smobs_A) + enddo + + cdfT_SMAPsm_struc(n)%smobs = LIS_rc%udef + cdfT_SMAPsm_struc(n)%smtime = -1 + call LIS_releaseUnitNumber(ftn) +!------------------------------------------------------------------------- +! Ascending pass assumed to be at 6pm localtime and the descending +! pass is assumed to be at 6am local time +!------------------------------------------------------------------------- + do r = 1, LIS_rc%obs_lnr(k) + do c = 1, LIS_rc%obs_lnc(k) + grid_index = LIS_obs_domain(n, k)%gindex(c, r) + if (grid_index .ne. -1) then + + if (smobs_D(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0) then + cdfT_SMAPsm_struc(n)%smobs(c, r) = & + smobs_D(c + (r - 1)*LIS_rc%obs_lnc(k)) + lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) + lhour = 6.0 + call LIS_localtime2gmt(gmt, lon, lhour, zone) + cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt + + endif +!------------------------------------------------------------------------- +! The ascending data is used only over locations where descending data +! doesn't exist. +!------------------------------------------------------------------------- + if (smobs_A(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0 .and. & + cdfT_SMAPsm_struc(n)%smobs(c, r) .eq. -9999.0) then + cdfT_SMAPsm_struc(n)%smobs(c, r) = & + smobs_A(c + (r - 1)*LIS_rc%obs_lnc(k)) + lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) + lhour = 18.0 + call LIS_localtime2gmt(gmt, lon, lhour, zone) + cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt + endif + endif + enddo + enddo + + elseif (cdfT_SMAPsm_struc(n)%data_designation .eq. "SPL3SMP") then +!------------------------------------------------------------------------- +! MN: create filename for 36km product (SMAP_L3_SM_P_) +!------------------------------------------------------------------------- + + write (yyyy, '(i4.4)') LIS_rc%yr + write (mm, '(i2.2)') LIS_rc%mo + write (dd, '(i2.2)') LIS_rc%da + write (CRID, '(a)') cdfT_SMAPsm_struc(n)%release_number + + ! EMK...Make sure only one PET calls the file system to determine what + ! SMAP files are available. + if (LIS_masterproc) then + list_files = trim(smobsdir)//'/'//trim(yyyy)//'.'//trim(mm)//'.'// & + trim(dd)//'/SMAP_L3_SM_P_' & + //trim(yyyy)//trim(mm)//trim(dd)//'_'// & + trim(CRID)//'*.h5' + write(LIS_logunit,*) & + '[INFO] Searching for ',trim(list_files) + rc = create_filelist(trim(list_files)//char(0), & + "SMAP_filelist.dat"//char(0)) + if (rc .ne. 0) then + write(LIS_logunit,*) & + '[WARN] Problem encountered when searching for SMAP files' + write(LIS_logunit,*) & + 'Was searching for ',trim(list_files) + write(LIS_logunit,*) & + 'LIS will continue...' + endif + end if +#if (defined SPMD) + call mpi_barrier(lis_mpi_comm, ierr) +#endif + + ftn = LIS_getNextUnitNumber() + open (ftn, file="./SMAP_filelist.dat", & + action='read', status='old', iostat=ierr) + +! if multiple files for the same time and orbits are present, the latest +! one will overwrite older ones, though multiple (redundant) reads occur. +! This assumes that the 'ls command' will list the files in that order. + + do while (ierr .eq. 0) + read (ftn, '(a)', iostat=ierr) fname + if (ierr .ne. 0) then + exit + endif + + write (LIS_logunit, *) '[INFO] Reading descending pass ', trim(fname) + call read_NASASMAP_data_cdfTransfer(n, k, 'D', fname, smobs_D) + + write (LIS_logunit, *) '[INFO] Reading ascending pass ', trim(fname) + call read_NASASMAP_data_cdfTransfer(n, k, 'A', fname, smobs_A) + enddo + + cdfT_SMAPsm_struc(n)%smobs = LIS_rc%udef + cdfT_SMAPsm_struc(n)%smtime = -1 + call LIS_releaseUnitNumber(ftn) +!------------------------------------------------------------------------- +! Ascending pass assumed to be at 6pm localtime and the descending +! pass is assumed to be at 6am local time +!------------------------------------------------------------------------- + do r = 1, LIS_rc%obs_lnr(k) + do c = 1, LIS_rc%obs_lnc(k) + grid_index = LIS_obs_domain(n, k)%gindex(c, r) + if (grid_index .ne. -1) then + + if (smobs_D(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0) then + cdfT_SMAPsm_struc(n)%smobs(c, r) = & + smobs_D(c + (r - 1)*LIS_rc%obs_lnc(k)) + lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) + lhour = 6.0 + call LIS_localtime2gmt(gmt, lon, lhour, zone) + cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt + + endif +!------------------------------------------------------------------------- +! The ascending data is used only over locations where descending data +! doesn't exist. +!------------------------------------------------------------------------- + if (smobs_A(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0 .and. & + cdfT_SMAPsm_struc(n)%smobs(c, r) .eq. -9999.0) then + cdfT_SMAPsm_struc(n)%smobs(c, r) = & + smobs_A(c + (r - 1)*LIS_rc%obs_lnc(k)) + lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) + lhour = 18.0 + call LIS_localtime2gmt(gmt, lon, lhour, zone) + cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt + endif + endif + enddo + enddo + +#if 0 +!------------------------------------------------------------------------- +! From the SMAP documentation: +! The current approach for the SPL3SMP product is to use the nearest +! 6:00 a.m. LST criterion to perform Level-3 compositing for the +! descending passes. According to this criterion, for a given grid cell, +! an L2 data point acquired closest to 6:00 a.m. local solar time will +! make its way to the final Level-3 file; other late-coming L2 data +! points falling into the same grid cell will be ignored. For a given +! file whose time stamp (yyyy-mm-ddThh:mm:ss) is expressed in UTC, only +! the hh:mm:ss part is converted into local solar time. +! (O'Neill et al. 2012) +!------------------------------------------------------------------------- + do r = 1, LIS_rc%obs_lnr(k) + do c = 1, LIS_rc%obs_lnc(k) + grid_index = LIS_obs_domain(n, k)%gindex(c, r) + if (grid_index .ne. -1) then + + if (smobs(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0) then + cdfT_SMAPsm_struc(n)%smobs(c, r) = & + smobs(c + (r - 1)*LIS_rc%obs_lnc(k)) + lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) + lhour = 6.0 + call LIS_localtime2gmt(gmt, lon, lhour, zone) + cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt + endif + endif + enddo + enddo +#endif + + endif ! sensor + endif ! alram + + call ESMF_StateGet(OBS_State, "Observation01", smfield, & + rc=status) + call LIS_verify(status, 'Error: StateGet Observation01') + + call ESMF_FieldGet(smfield, localDE=0, farrayPtr=obsl, rc=status) + call LIS_verify(status, 'Error: FieldGet') + + fnd = 0 + sm_current = LIS_rc%udef + + ! dt is not defined as absolute value of the time difference to avoid + ! double counting of the data in assimilation. + + if ( (cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") .or. & + (cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP") ) then + + do r=1,LIS_rc%obs_lnr(k) + do c=1,LIS_rc%obs_lnc(k) + if(LIS_obs_domain(n,k)%gindex(c,r).ne.-1) then + grid_index = c+(r-1)*LIS_rc%obs_lnc(k) + dt = (cdfT_SMAPsm_struc(n)%smtime(c,r)-time1) + if(dt.ge.0.and.dt.lt.(time3-time1)) then + sm_current(c,r) = & + cdfT_SMAPsm_struc(n)%smobs(c,r) + if(LIS_obs_domain(n,k)%gindex(c,r).ne.-1) then + obs_unsc(LIS_obs_domain(n,k)%gindex(c,r)) = & + sm_current(c,r) + endif + if(sm_current(c,r).ne.LIS_rc%udef) then + fnd = 1 + endif + endif + endif + enddo + enddo + + else + + do r = 1, LIS_rc%obs_lnr(k) + do c = 1, LIS_rc%obs_lnc(k) + if (LIS_obs_domain(n, k)%gindex(c, r) .ne. -1) then + grid_index = c + (r - 1)*LIS_rc%obs_lnc(k) + + dt = (LIS_rc%gmt - cdfT_SMAPsm_struc(n)%smtime(c, r))*3600.0 + if (dt .ge. 0 .and. dt .lt. LIS_rc%ts) then + sm_current(c, r) = & + cdfT_SMAPsm_struc(n)%smobs(c, r) + if (LIS_obs_domain(n, k)%gindex(c, r) .ne. -1) then + obs_unsc(LIS_obs_domain(n, k)%gindex(c, r)) = & + sm_current(c, r) + endif + if (sm_current(c, r) .ne. LIS_rc%udef) then + fnd = 1 + endif + endif + endif + enddo + enddo + endif + + +!------------------------------------------------------------------------- +! Transform data to the LSM climatology using a geolocation independent +! CDF-scaling approach +!------------------------------------------------------------------------- + if (cdfT_SMAPsm_struc(n)%useCDFtransfer .gt. 0) then + call read_CDFtransferdata_all(n,k,& + cdfT_SMAPsm_struc(n)%nbins,& + cdfT_SMAPsm_struc(n)%ntimes,& + cdfT_SMAPsm_struc(n)%n_strat_bins, & + cdfT_SMAPsm_struc(n)%modelcdffile, & + "SoilMoist",& + cdfT_SMAPsm_struc(n)%model_xrange,& + cdfT_SMAPsm_struc(n)%model_cdf) + + call read_CDFtransferdata_all(n,k,& + cdfT_SMAPsm_struc(n)%nbins,& + cdfT_SMAPsm_struc(n)%ntimes,& + cdfT_SMAPsm_struc(n)%n_strat_bins, & + cdfT_SMAPsm_struc(n)%obscdffile, & + "SoilMoist",& + cdfT_SMAPsm_struc(n)%obs_xrange,& + cdfT_SMAPsm_struc(n)%obs_cdf) + + if (fnd .ne. 0) then + + call LIS_rescale_with_stratified_CDF(& + n, & + k, & + cdfT_SMAPsm_struc(n)%nbins, & + cdfT_SMAPsm_struc(n)%ntimes, & + MAX_SM_VALUE, & + MIN_SM_VALUE, & + cdfT_SMAPsm_struc(n)%model_xrange, & + cdfT_SMAPsm_struc(n)%obs_xrange, & + cdfT_SMAPsm_struc(n)%model_cdf, & + cdfT_SMAPsm_struc(n)%obs_cdf, & + cdfT_SMAPsm_struc(n)%ref_p_climo_maxval, & + cdfT_SMAPsm_struc(n)%target_p_climo,& + cdfT_SMAPsm_struc(n)%n_strat_bins,& + sm_current) + endif + endif + + obsl = LIS_rc%udef + do r = 1, LIS_rc%obs_lnr(k) + do c = 1, LIS_rc%obs_lnc(k) + if (LIS_obs_domain(n, k)%gindex(c, r) .ne. -1) then + obsl(LIS_obs_domain(n, k)%gindex(c, r)) = sm_current(c, r) + endif + enddo + enddo + !------------------------------------------------------------------------- + ! Apply LSM based QC and screening of observations + !------------------------------------------------------------------------- + call lsmdaqcobsstate(trim(LIS_rc%lsm)//"+" & + //trim(LIS_CDFTRANSFERNASASMAPsmobsId)//char(0), n, k, OBS_state) + + call LIS_checkForValidObs(n, k, obsl, fnd, sm_current) + + if (fnd .eq. 0) then + data_upd_flag_local = .false. + else + data_upd_flag_local = .true. + endif + +#if (defined SPMD) + call MPI_ALLGATHER(data_upd_flag_local, 1, & + MPI_LOGICAL, data_upd_flag(:), & + 1, MPI_LOGICAL, LIS_mpi_comm, status) + data_upd = any(data_upd_flag) +#else + data_upd = data_upd_flag_local +#endif + + if (data_upd) then + + do t = 1, LIS_rc%obs_ngrid(k) + gid(t) = t + if (obsl(t) .ne. -9999.0) then + assimflag(t) = 1 + else + assimflag(t) = 0 + endif + enddo + + call ESMF_AttributeSet(OBS_State, "Data Update Status", & + .true., rc=status) + call LIS_verify(status) + + if (LIS_rc%obs_ngrid(k) .gt. 0) then + call ESMF_AttributeSet(smField, "Grid Number", & + gid, itemCount=LIS_rc%obs_ngrid(k), rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(smField, "Assimilation Flag", & + assimflag, itemCount=LIS_rc%obs_ngrid(k), rc=status) + call LIS_verify(status) + + call ESMF_AttributeSet(smfield, "Unscaled Obs", & + obs_unsc, itemCount=LIS_rc%obs_ngrid(k), rc=status) + call LIS_verify(status, 'Error in setting Unscaled Obs attribute') + + endif + + if(cdfT_SMAPsm_struc(n)%useSsdevScal.eq.1) then + write(LIS_logunit,*) '[ERR] "use scaled standard deviation model" does not work ' + write(LIS_logunit,*) '[ERR] for CDF transfer method' + call LIS_endrun() + endif +#IF 0 + if (LIS_rc%dascaloption(k) .eq. "CDF matching") then + if (cdfT_SMAPsm_struc(n)%useSsdevScal .eq. 1) then + call ESMF_StateGet(OBS_Pert_State, "Observation01", pertfield, & + rc=status) + call LIS_verify(status, 'Error: StateGet Observation01') + + allocate (ssdev(LIS_rc%obs_ngrid(k))) + ssdev = cdfT_SMAPsm_struc(n)%ssdev_inp + + if (cdfT_SMAPsm_struc(n)%ntimes .eq. 1) then + jj = 1 + else + jj = LIS_rc%mo + endif + do t = 1, LIS_rc%obs_ngrid(k) + if (cdfT_SMAPsm_struc(n)%obs_sigma(t, jj) .gt. 0) then + ssdev(t) = ssdev(t)*cdfT_SMAPsm_struc(n)%model_sigma(t, jj)/ & + cdfT_SMAPsm_struc(n)%obs_sigma(t, jj) + if (ssdev(t) .lt. minssdev) then + ssdev(t) = minssdev + endif + endif + enddo + + if (LIS_rc%obs_ngrid(k) .gt. 0) then + call ESMF_AttributeSet(pertField, "Standard Deviation", & + ssdev, itemCount=LIS_rc%obs_ngrid(k), rc=status) + call LIS_verify(status) + endif + deallocate (ssdev) + endif + endif +#ENDIF + else + call ESMF_AttributeSet(OBS_State, "Data Update Status", & + .false., rc=status) + call LIS_verify(status) + endif + +end subroutine read_cdfTransfer_NASASMAPsm + +!BOP +! +! !ROUTINE: read_SMAPL2sm_data_cdfTransfer +! \label{read_SMAPL2sm_data_cdfTransfer} +! +! !INTERFACE: +subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) +! +! !USES: + + use LIS_coreMod + use LIS_logMod + use LIS_timeMgrMod + use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc + +#if (defined USE_HDF5) + use hdf5 +#endif + + implicit none +! +! !INPUT PARAMETERS: +! + integer :: n + integer :: k + character (len=*) :: fname + real :: smobs_inp(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k)) + real*8 :: time + +! !OUTPUT PARAMETERS: +! +! +! !DESCRIPTION: +! +! +!EOP + +#if (defined USE_HDF5) + + character*100, parameter :: sm_gr_name = "Soil_Moisture_Retrieval_Data" + character*100, parameter :: sm_field_name = "soil_moisture" + character*100, parameter :: sm_qa_name = "retrieval_qual_flag" +!YK + character*100, parameter :: vwc_field_name = "vegetation_water_content" + + integer(hsize_t), dimension(1) :: dims + integer(hsize_t), dimension(1) :: maxdims + integer(hid_t) :: file_id + integer(hid_t) :: dspace_id + integer(hid_t) :: row_id, col_id + integer(hid_t) :: sm_gr_id,sm_field_id, sm_qa_id + integer(hid_t) :: sm_gr_id_A,sm_field_id_A + integer(hid_t) :: vwc_field_id ! YK + real, allocatable :: sm_field(:) + real, allocatable :: vwc_field(:)! YK + integer, allocatable :: sm_qa(:) + integer, allocatable :: ease_row(:) + integer, allocatable :: ease_col(:) + integer :: c,r,t + logical*1 :: sm_data_b(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + logical*1 :: smobs_b_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: sm_data(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + real :: smobs_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + + integer :: status,ios,iret + + call h5open_f(status) + call LIS_verify(status, 'Error opening HDF fortran interface') + + call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) + call LIS_verify(status, 'Error opening SMAP L2 file ') + + call h5gopen_f(file_id,sm_gr_name,sm_gr_id, status) + call LIS_verify(status, 'Error opening SM group in SMAP L2 file') + + call h5dopen_f(sm_gr_id,sm_field_name,sm_field_id, status) + call LIS_verify(status, 'Error opening SM field in SMAP L2 file') + + call h5dopen_f(sm_gr_id,"EASE_row_index",row_id, status) + call LIS_verify(status, 'Error opening row index field in SMAP L2 file') + + call h5dopen_f(sm_gr_id,"EASE_column_index",col_id, status) + call LIS_verify(status, 'Error opening column index field in SMAP L2 file') + +!YK + call h5dopen_f(sm_gr_id, sm_qa_name,sm_qa_id, status) + call LIS_verify(status, 'Error opening QA field in SMAP L2 file') + +!YK + call h5dopen_f(sm_gr_id, vwc_field_name,vwc_field_id, status) + call LIS_verify(status, 'Error opening Veg water content field in SMAP L2 file') + + call h5dget_space_f(sm_field_id, dspace_id, status) + call LIS_verify(status, 'Error in h5dget_space_f: reaSMAP L2Obs') + +! Size of the arrays +! This routine returns -1 on failure, rank on success. + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, status) + if(status.eq.-1) then + call LIS_verify(status, 'Error in h5sget_simple_extent_dims_f: readSMAP L2Obs') + endif + + allocate(sm_field(maxdims(1))) + allocate(sm_qa(maxdims(1))) !YK + allocate(vwc_field(maxdims(1))) !YK + allocate(ease_row(maxdims(1))) + allocate(ease_col(maxdims(1))) + + call h5dread_f(row_id, H5T_NATIVE_INTEGER,ease_row,dims,status) + call LIS_verify(status, 'Error extracting row index from SMAP L2 file') + + call h5dread_f(col_id, H5T_NATIVE_INTEGER,ease_col,dims,status) + call LIS_verify(status, 'Error extracting col index from SMAP L2 file') + + call h5dread_f(sm_field_id, H5T_NATIVE_REAL,sm_field,dims,status) + call LIS_verify(status, 'Error extracting SM field from SMAP L2 file') + +!YK + call h5dread_f(sm_qa_id, H5T_NATIVE_INTEGER,sm_qa,dims,status) + call LIS_verify(status, 'Error extracting SM field from SMAP L2 file') + +!YK get the vegetation water content + call h5dread_f(vwc_field_id, H5T_NATIVE_REAL,vwc_field,dims,status) + call LIS_verify(status, 'Error extracting Veg water content (AM) field from SMAP L2 file') + +!YK + call h5dclose_f(sm_qa_id,status) + call LIS_verify(status,'Error in H5DCLOSE call') + +!YK + call h5dclose_f(vwc_field_id,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dclose_f(row_id,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dclose_f(col_id,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dclose_f(sm_field_id,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5gclose_f(sm_gr_id,status) + call LIS_verify(status,'Error in H5GCLOSE call') + + call h5fclose_f(file_id,status) + call LIS_verify(status,'Error in H5FCLOSE call') + + call h5close_f(status) + call LIS_verify(status,'Error in H5CLOSE call') + + sm_data = LIS_rc%udef + sm_data_b = .false. + +!-------------------------------------------------------------------original +!!grid the data in EASE projection +! do t=1,maxdims(1) +! if(ease_col(t).gt.0.and.ease_row(t).gt.0) then +! sm_data(ease_col(t) + & +! (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = sm_field(t) +! if(sm_field(t).ne.-9999.0) then +! sm_data_b(ease_col(t) + & +! (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = .true. +! endif +! endif +! enddo + +!--------------------------------------------------------------------YK +!grid the data in EASE projection +! The retrieval_quality_field variable's binary representation consists of bits +! that indicate whether retrieval is performed or not at a given grid cell. +! When retrieval is performed, it contains additional bits to further +! indicate the exit status and quality of the retrieval. The first bit +! indicates the recommended quality (0-means retrieval has recommended quality). + do t=1,maxdims(1) + if(ease_col(t).gt.0.and.ease_row(t).gt.0) then + sm_data(ease_col(t) + & + (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = sm_field(t) + + if(vwc_field(t).gt.5) then !YK Aply QC : if VWC > 5 kg/m2 + sm_data(ease_col(t) + & + (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = LIS_rc%udef + else + if(sm_data(ease_col(t) + & + (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc).ne.-9999.0) then + if(ibits(sm_qa(t),0,1).eq.0) then + sm_data_b(ease_col(t) + & + (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = .true. + else + sm_data(ease_col(t) + & + (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = LIS_rc%udef + endif + endif + endif + endif + enddo +!----------------------------------------------------------------------- + + !t = 1 +!-------------------------------------------------------------------------- +! Interpolate to the LIS running domain +!-------------------------------------------------------------------------- + call neighbor_interp(LIS_rc%obs_gridDesc(k,:), sm_data_b, sm_data, & + smobs_b_ip, smobs_ip, & + cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k), & + cdfT_SMAPsm_struc(n)%rlat, cdfT_SMAPsm_struc(n)%rlon,& + cdfT_SMAPsm_struc(n)%n11, LIS_rc%udef, ios) + + + deallocate(sm_field) +! deallocate(sm_qa) + deallocate(ease_row) + deallocate(ease_col) + +!overwrite the input data + do r=1,LIS_rc%obs_lnr(k) + do c=1,LIS_rc%obs_lnc(k) + if(smobs_ip(c+(r-1)*LIS_rc%obs_lnc(k)).ne.-9999.0) then + smobs_inp(c,r) = & + smobs_ip(c+(r-1)*LIS_rc%obs_lnc(k)) + + cdfT_SMAPsm_struc(n)%smtime(c,r) = & + time + endif + enddo + enddo +#endif + +end subroutine read_SMAPL2sm_data_cdfTransfer + +!BOP +! +! !ROUTINE: read_NASASMAP_E_data_cdfTransfer +! \label{read_NASASMAP_E_data_cdfTransfer} +! +! !INTERFACE: +subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) +! +! !USES: + + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_logMod + use LIS_timeMgrMod + use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc +#if (defined USE_HDF5) + use hdf5 +#endif + + implicit none +! +! !INPUT PARAMETERS: +! + integer :: n + integer :: k + character (len=*) :: pass + character (len=*) :: fname + real :: smobs_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + + +! !OUTPUT PARAMETERS: +! +! +! !DESCRIPTION: +! This subroutine reads the SMOS NESDIS binary file and applies the data +! quality flags to filter the data. !\normalsize +! +! tb_time_seconds +! Arithmetic average of the same parameters found in the +! fore- and aft-looking groups in the input SPL1CTB granule. +! The resulting parameter thus describes the average of UTC +! acquisition times of SPL1BTB observations whose boresights +! fall within a 36 km EASE-Grid 2.0 cell. The result is then +! expressed in J2000 seconds (the number of seconds since +! 11:58:55.816 on January 1, 2000 UT). +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[fname] name of the RTNASASMAP AMSR-E file +! \item[smobs\_ip] soil moisture data processed to the LIS domain +! \end{description} +! +! +!EOP + +#if (defined USE_HDF5) + + character*100, parameter :: sm_gr_name_D = "Soil_Moisture_Retrieval_Data_AM" + character*100, parameter :: sm_field_name_D = "soil_moisture" + character*100, parameter :: sm_qa_name_D = "retrieval_qual_flag" + character*100, parameter :: sm_gr_name_A = "Soil_Moisture_Retrieval_Data_PM" + character*100, parameter :: sm_field_name_A = "soil_moisture_pm" + character*100, parameter :: sm_qa_name_A = "retrieval_qual_flag_pm" +! MN + character*100, parameter :: vwc_field_name_D = "vegetation_water_content" + character*100, parameter :: vwc_field_name_A = "vegetation_water_content_pm" + + integer(hsize_t), allocatable :: dims(:) + integer(hsize_t), dimension(2) :: dimsm + integer(hsize_t), dimension(2) :: count_file + integer(hsize_t), dimension(2) :: count_mem + integer(hid_t) :: memspace + integer(hid_t) :: dataspace + integer :: memrank = 2 ! scaler--> rank = 0 ; 2D array--> rank = 2 + integer(hsize_t), dimension(2) :: offset_mem = (/0,0/) + integer(hsize_t), dimension(2) :: offset_file = (/0,0/) + integer(hid_t) :: file_id + integer(hid_t) :: sm_gr_id_D,sm_field_id_D,sm_qa_id_D + integer(hid_t) :: sm_gr_id_A,sm_field_id_A,sm_qa_id_A + integer(hid_t) :: vwc_field_id_D ! MN + integer(hid_t) :: vwc_field_id_A ! MN + real, allocatable :: sm_field(:,:) + real, allocatable :: vwc_field(:,:)! MN + integer, allocatable :: sm_qa(:,:) + integer :: c,r,t + logical*1 :: sm_data_b(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + logical*1 :: smobs_b_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: sm_data(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + integer :: status,ios + + dimsm = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + count_file = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + count_mem = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + + allocate(sm_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(sm_qa(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(vwc_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(dims(2)) + + dims(1) = cdfT_SMAPsm_struc(n)%nc + dims(2) = cdfT_SMAPsm_struc(n)%nr + + call h5open_f(status) + call LIS_verify(status, 'Error opening HDF fortran interface') + + call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) + call LIS_verify(status, 'Error opening NASASMAP file ') + + if(pass.eq.'D') then + call h5gopen_f(file_id,sm_gr_name_D,sm_gr_id_D, status) + call LIS_verify(status, 'Error opening SM group in NASASMAP file') + + call h5dopen_f(sm_gr_id_D,sm_field_name_D,sm_field_id_D, status) + call LIS_verify(status, 'Error opening SM field in NASASMAP file') + + call h5dget_space_f(sm_field_id_D, dataspace, status) + call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') + + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & + start=offset_file, count=count_file, hdferr=status) + call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') + + call h5screate_simple_f(memrank,dimsm, memspace, status) + call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') + + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & + start=offset_mem, count=count_mem, hdferr=status) + call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') + + call h5dread_f(sm_field_id_D, H5T_NATIVE_REAL,sm_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') + + call h5dclose_f(sm_field_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dopen_f(sm_gr_id_D,sm_qa_name_D,sm_qa_id_D, status) + call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') + + call h5dread_f(sm_qa_id_D, H5T_NATIVE_INTEGER,sm_qa,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') + + call h5dclose_f(sm_qa_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + +! MN get the vegetation water contnent + call h5dopen_f(sm_gr_id_D,vwc_field_name_D,vwc_field_id_D, status) + call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') + + call h5dread_f(vwc_field_id_D, H5T_NATIVE_REAL,vwc_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting Veg water content (AM) field from NASASMAPfile') + + call h5dclose_f(vwc_field_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5gclose_f(sm_gr_id_D,status) + call LIS_verify(status,'Error in H5GCLOSE call') + + else + call h5gopen_f(file_id,sm_gr_name_A,sm_gr_id_A, status) + call LIS_verify(status, 'Error opening SM group in NASASMAP file') + + call h5dopen_f(sm_gr_id_A,sm_field_name_A,sm_field_id_A, status) + call LIS_verify(status, 'Error opening SM field in NASASMAP file') + + call h5dget_space_f(sm_field_id_A, dataspace, status) + call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') + + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & + start=offset_file, count=count_file, hdferr=status) + call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') + + call h5screate_simple_f(memrank,dimsm, memspace, status) + call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') + + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & + start=offset_mem, count=count_mem, hdferr=status) + call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') + + call h5dread_f(sm_field_id_A, H5T_NATIVE_REAL,sm_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') + + call h5dclose_f(sm_field_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dopen_f(sm_gr_id_A,sm_qa_name_A,sm_qa_id_A, status) + call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') + + call h5dread_f(sm_qa_id_A, H5T_NATIVE_INTEGER,sm_qa,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') + + call h5dclose_f(sm_qa_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + +! MN get the vegetation water contnent + call h5dopen_f(sm_gr_id_A,vwc_field_name_A,vwc_field_id_A, status) + call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') + + call h5dread_f(vwc_field_id_A, H5T_NATIVE_REAL,vwc_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting Veg water content (AM) field from NASASMAPfile') + + call h5dclose_f(vwc_field_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5gclose_f(sm_gr_id_A,status) + call LIS_verify(status,'Error in H5GCLOSE call') + + endif + + call h5fclose_f(file_id,status) + call LIS_verify(status,'Error in H5FCLOSE call') + + call h5close_f(status) + call LIS_verify(status,'Error in H5CLOSE call') + + + sm_data_b = .false. + t = 1 + +! The retrieval_quality_field variable's binary representation consists of bits +! that indicate whether retrieval is performed or not at a given grid cell. +! When retrieval is performed, it contains additional bits to further +! indicate the exit status and quality of the retrieval. The first bit +! indicates the recommended quality (0-means retrieval has recommended quality). + + do r=1,cdfT_SMAPsm_struc(n)%nr + do c=1,cdfT_SMAPsm_struc(n)%nc + sm_data(t) = sm_field(c,r) + + if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 + sm_data(t) = LIS_rc%udef + else + + if(sm_data(t).ne.-9999.0) then + if(ibits(sm_qa(c,r),0,1).eq.0) then + sm_data_b(t) = .true. + else + sm_data(t) = -9999.0 + endif + endif + endif + + t = t+1 + enddo + enddo + + deallocate(sm_qa) + +!-------------------------------------------------------------------------- +! Interpolate to the LIS running domain +!-------------------------------------------------------------------------- + call neighbor_interp(LIS_rc%obs_gridDesc(k,:),& + sm_data_b, sm_data, smobs_b_ip, smobs_ip, & + cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k), & + cdfT_SMAPsm_struc(n)%rlat, cdfT_SMAPsm_struc(n)%rlon,& + cdfT_SMAPsm_struc(n)%n11, LIS_rc%udef, ios) + + deallocate(sm_field) + deallocate(dims) + +#endif + +end subroutine read_NASASMAP_E_data_cdfTransfer + +! MN: the data structure in both 36 km and 9 km products is the same therefore +! read_NASASMAP_E_data_cdfTransfer is similar to read_NASASMAP_data_cdfTransfer + +!BOP +! +! !ROUTINE: read_NASASMAP_data_cdfTransfer +! \label{read_NASASMAP_data_cdfTransfer} +! +! !INTERFACE: +subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) +! +! !USES: + + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_logMod + use LIS_timeMgrMod + use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc +#if (defined USE_HDF5) + use hdf5 +#endif + + implicit none +! +! !INPUT PARAMETERS: +! + integer :: n + integer :: k + character (len=*) :: pass + character (len=*) :: fname + real :: smobs_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + + +! !OUTPUT PARAMETERS: +! +! +! !DESCRIPTION: +! This subroutine reads the SMOS NESDIS binary file and applies the data +! quality flags to filter the data. !\normalsize +! +! tb_time_seconds +! Arithmetic average of the same parameters found in the +! fore- and aft-looking groups in the input SPL1CTB granule. +! The resulting parameter thus describes the average of UTC +! acquisition times of SPL1BTB observations whose boresights +! fall within a 36 km EASE-Grid 2.0 cell. The result is then +! expressed in J2000 seconds (the number of seconds since +! 11:58:55.816 on January 1, 2000 UT). +! +! The arguments are: +! \begin{description} +! \item[n] index of the nest +! \item[fname] name of the RTNASASMAP AMSR-E file +! \item[smobs\_ip] soil moisture data processed to the LIS domain +! \end{description} +! +! +!EOP + +#if (defined USE_HDF5) + + character*100, parameter :: sm_gr_name_D = "Soil_Moisture_Retrieval_Data_AM" + character*100, parameter :: sm_field_name_D = "soil_moisture" + character*100, parameter :: sm_qa_name_D = "retrieval_qual_flag" + character*100, parameter :: sm_gr_name_A = "Soil_Moisture_Retrieval_Data_PM" + character*100, parameter :: sm_field_name_A = "soil_moisture_pm" + character*100, parameter :: sm_qa_name_A = "retrieval_qual_flag_pm" +! MN + character*100, parameter :: vwc_field_name_D = "vegetation_water_content" + character*100, parameter :: vwc_field_name_A = "vegetation_water_content_pm" + + integer(hsize_t), allocatable :: dims(:) + integer(hsize_t), dimension(2) :: dimsm + integer(hsize_t), dimension(2) :: count_file + integer(hsize_t), dimension(2) :: count_mem + integer(hid_t) :: memspace + integer(hid_t) :: dataspace + integer :: memrank = 2 ! scaler--> rank = 0 ; 2D array--> rank = 2 + integer(hsize_t), dimension(2) :: offset_mem = (/0,0/) + integer(hsize_t), dimension(2) :: offset_file = (/0,0/) + integer(hid_t) :: file_id + integer(hid_t) :: sm_gr_id_D,sm_field_id_D,sm_qa_id_D + integer(hid_t) :: sm_gr_id_A,sm_field_id_A,sm_qa_id_A + integer(hid_t) :: vwc_field_id_D ! MN + integer(hid_t) :: vwc_field_id_A ! MN + real, allocatable :: sm_field(:,:) + real, allocatable :: vwc_field(:,:)! MN + integer, allocatable :: sm_qa(:,:) + integer :: c,r,t + logical*1 :: sm_data_b(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + logical*1 :: smobs_b_ip(LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k)) + real :: sm_data(cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr) + integer :: status,ios + + dimsm = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + count_file = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + count_mem = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) + + allocate(sm_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(sm_qa(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(vwc_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) + allocate(dims(2)) + + dims(1) = cdfT_SMAPsm_struc(n)%nc + dims(2) = cdfT_SMAPsm_struc(n)%nr + + call h5open_f(status) + call LIS_verify(status, 'Error opening HDF fortran interface') + + call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) + call LIS_verify(status, 'Error opening NASASMAP file ') + + if(pass.eq.'D') then + call h5gopen_f(file_id,sm_gr_name_D,sm_gr_id_D, status) + call LIS_verify(status, 'Error opening SM group in NASASMAP file') + + call h5dopen_f(sm_gr_id_D,sm_field_name_D,sm_field_id_D, status) + call LIS_verify(status, 'Error opening SM field in NASASMAP file') + + call h5dget_space_f(sm_field_id_D, dataspace, status) + call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') + + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & + start=offset_file, count=count_file, hdferr=status) + call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') + + call h5screate_simple_f(memrank,dimsm, memspace, status) + call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') + + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & + start=offset_mem, count=count_mem, hdferr=status) + call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') + + call h5dread_f(sm_field_id_D, H5T_NATIVE_REAL,sm_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') + + call h5dclose_f(sm_field_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dopen_f(sm_gr_id_D,sm_qa_name_D,sm_qa_id_D, status) + call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') + + call h5dread_f(sm_qa_id_D, H5T_NATIVE_INTEGER,sm_qa,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') + + call h5dclose_f(sm_qa_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + +! MN get the vegetation water contnent + call h5dopen_f(sm_gr_id_D,vwc_field_name_D,vwc_field_id_D, status) + call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') + + call h5dread_f(vwc_field_id_D, H5T_NATIVE_REAL,vwc_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting Veg water content (AM) field from NASASMAPfile') + + call h5dclose_f(vwc_field_id_D,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5gclose_f(sm_gr_id_D,status) + call LIS_verify(status,'Error in H5GCLOSE call') + + else + call h5gopen_f(file_id,sm_gr_name_A,sm_gr_id_A, status) + call LIS_verify(status, 'Error opening SM group in NASASMAP file') + + call h5dopen_f(sm_gr_id_A,sm_field_name_A,sm_field_id_A, status) + call LIS_verify(status, 'Error opening SM field in NASASMAP file') + + call h5dget_space_f(sm_field_id_A, dataspace, status) + call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') + + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & + start=offset_file, count=count_file, hdferr=status) + call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') + + call h5screate_simple_f(memrank,dimsm, memspace, status) + call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') + + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & + start=offset_mem, count=count_mem, hdferr=status) + call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') + + call h5dread_f(sm_field_id_A, H5T_NATIVE_REAL,sm_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') + + call h5dclose_f(sm_field_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5dopen_f(sm_gr_id_A,sm_qa_name_A,sm_qa_id_A, status) + call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') + + call h5dread_f(sm_qa_id_A, H5T_NATIVE_INTEGER,sm_qa,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') + + call h5dclose_f(sm_qa_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + +! MN get the vegetation water contnent + call h5dopen_f(sm_gr_id_A,vwc_field_name_A,vwc_field_id_A, status) + call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') + + call h5dread_f(vwc_field_id_A, H5T_NATIVE_REAL,vwc_field,dims,status, & + memspace, dataspace) + call LIS_verify(status, 'Error extracting Veg water content (AM) field from NASASMAPfile') + + call h5dclose_f(vwc_field_id_A,status) + call LIS_verify(status,'Error in H5DCLOSE call') + + call h5gclose_f(sm_gr_id_A,status) + call LIS_verify(status,'Error in H5GCLOSE call') + + endif + + call h5fclose_f(file_id,status) + call LIS_verify(status,'Error in H5FCLOSE call') + + call h5close_f(status) + call LIS_verify(status,'Error in H5CLOSE call') + + sm_data_b = .false. + t = 1 + +! The retrieval_quality_field variable's binary representation consists of bits +! that indicate whether retrieval is performed or not at a given grid cell. +! When retrieval is performed, it contains additional bits to further +! indicate the exit status and quality of the retrieval. The first bit +! indicates the recommended quality (0-means retrieval has recommended quality). + + do r=1,cdfT_SMAPsm_struc(n)%nr + do c=1,cdfT_SMAPsm_struc(n)%nc + sm_data(t) = sm_field(c,r) + + if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 + sm_data(t) = LIS_rc%udef + else + + if(sm_data(t).ne.-9999.0) then + if(ibits(sm_qa(c,r),0,1).eq.0) then + sm_data_b(t) = .true. + else + sm_data(t) = -9999.0 + endif + endif + endif + + t = t+1 + enddo + enddo + + deallocate(sm_qa) + +!-------------------------------------------------------------------------- +! Interpolate to the LIS running domain +!-------------------------------------------------------------------------- + call neighbor_interp(LIS_rc%obs_gridDesc(k,:),& + sm_data_b, sm_data, smobs_b_ip, smobs_ip, & + cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & + LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k), & + cdfT_SMAPsm_struc(n)%rlat, cdfT_SMAPsm_struc(n)%rlon,& + cdfT_SMAPsm_struc(n)%n11, LIS_rc%udef, ios) + + deallocate(sm_field) + deallocate(dims) + +#endif + + + +end subroutine read_NASASMAP_data_cdfTransfer + +#if 0 +!BOP +! !ROUTINE: create_cdfTransfer_NASASMAPsm_filename +! \label{create_cdfTransfer_NASASMAPsm_filename} +! +! !INTERFACE: +subroutine create_cdfTransfer_NASASMAPsm_filename(ndir, designation, yr, mo,da, filename) +! !USES: + + implicit none +! !ARGUMENTS: + character(len=*) :: filename + character(len=*) :: designation + integer :: yr, mo, da + character (len=*) :: ndir +! +! !DESCRIPTION: +! This subroutine creates the SMAP filename (from NSIDC) +! based on the time and date +! +! The arguments are: +! \begin{description} +! \item[ndir] name of the SMAP soil moisture data directory +! \item[yr] current year +! \item[mo] current month +! \item[da] current day +! \item[filename] Generated SMAP filename +! \end{description} +!EOP + + character (len=4) :: fyr + character (len=2) :: fmo,fda + + write(unit=fyr, fmt='(i4.4)') yr + write(unit=fmo, fmt='(i2.2)') mo + write(unit=fda, fmt='(i2.2)') da + + if(designation.eq."SPL3SMAP") then + filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& + trim(fda)//'/SMAP_L3_SM_AP_'& + //trim(fyr)//trim(fmo)//trim(fda)//& + '_R12170_001.h5' +! MN: +! The SMAP file names contain components that change in a way that +! is difficult to programatically generate. So after downloading +! a SMAP data file, a symbolic link was created to it which make it +! easier to generate file name. +! For example: +! SMAP_L3_SM_P_20170902.h5 -> SMAP_L3_SM_P_20170902_R15152_001.h5 + elseif(designation.eq."SPL3SMP") then + filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& + trim(fda)//'/SMAP_L3_SM_P_'& + //trim(fyr)//trim(fmo)//trim(fda)//& + '.h5' +! For example: +! SMAP_L3_SM_P_E_20180811.h5 -> SMAP_L3_SM_P_E_20180811_R16010_001.h5 +! MN for sake of convenience instead of real name the symbolic link was used + elseif(designation.eq."SPL3SMP_E") then + filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& + trim(fda)//'/SMAP_L3_SM_P_E_'& + //trim(fyr)//trim(fmo)//trim(fda)//& + '.h5' + + endif + +end subroutine create_cdfTransfer_NASASMAPsm_filename + +#endif + + + diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 new file mode 100644 index 000000000..48aa3cbd7 --- /dev/null +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 @@ -0,0 +1,122 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: write_cdfTransfer_NASASMAPsmobs +! \label{write_cdfTransfer_NASASMAPsmobs} +! +! !REVISION HISTORY: +! 25Jan2008: Sujay Kumar; Initial Specification +! 2 Mar 2022: Mahdi navari; modified for cdf transfer DA +! +! !INTERFACE: +subroutine write_cdfTransfer_NASASMAPsmobs(n, k, OBS_State) +! !USES: + use ESMF + use LIS_coreMod + use LIS_logMod + use LIS_fileIOMod + use LIS_historyMod + use LIS_DAobservationsMod + + implicit none + +! !ARGUMENTS: + + integer, intent(in) :: n + integer, intent(in) :: k + type(ESMF_State) :: OBS_State +! +! !DESCRIPTION: +! +! writes the transformed (interpolated/upscaled/reprojected) +! LPRM AMSRE observations to a file +! +!EOP + type(ESMF_Field) :: smField + logical :: data_update + real, pointer :: smobs(:) + real :: smobs_unsc(LIS_rc%obs_ngrid(k)) + character*100 :: obsname + integer :: ftn + integer :: status + + call ESMF_AttributeGet(OBS_State, "Data Update Status", & + data_update, rc=status) + call LIS_verify(status) + + if(data_update) then + + call ESMF_StateGet(OBS_State, "Observation01",smField, & + rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(smField, localDE=0, farrayPtr=smobs, rc=status) + call LIS_verify(status) + + if(LIS_rc%obs_ngrid(k).gt.0) then + call ESMF_AttributeGet(smfield,"Unscaled Obs",smobs_unsc,& + itemCount=LIS_rc%obs_ngrid(k),rc=status) + call LIS_verify(status, 'Error in AttributeGet-Unscaled Obs') + endif + + if(LIS_masterproc) then + ftn = LIS_getNextUnitNumber() + call cdfTransfer_smobsname(n,k,obsname) + + call LIS_create_output_directory('DAOBS') + open(ftn,file=trim(obsname), form='unformatted') + endif + + call LIS_writevar_gridded_obs(ftn,n,k,smobs_unsc) + call LIS_writevar_gridded_obs(ftn,n,k,smobs) + + if(LIS_masterproc) then + call LIS_releaseUnitNumber(ftn) + endif + + endif + +end subroutine write_cdfTransfer_NASASMAPsmobs + +!BOP +! !ROUTINE: cdfTransfer_smobsname +! \label{cdfTransfer_smobsname} +! +! !INTERFACE: +subroutine cdfTransfer_smobsname(n,k,obsname) +! !USES: + use LIS_coreMod, only : LIS_rc + +! !ARGUMENTS: + integer :: n + integer :: k + character(len=*) :: obsname +! +! !DESCRIPTION: +! +!EOP + + character(len=12) :: cdate1 + character(len=12) :: cdate + character(len=10) :: cda + + write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & + LIS_rc%yr, LIS_rc%mo, & + LIS_rc%da, LIS_rc%hr,LIS_rc%mn + + write(unit=cda, fmt='(a2,i2.2)') '.a',k + write(unit=cdate, fmt='(a2,i2.2)') '.d',n + + obsname = trim(LIS_rc%odir)//'/DAOBS/'//cdate1(1:6)//& + '/LISDAOBS_'//cdate1// & + trim(cda)//trim(cdate)//'.1gs4r' + +end subroutine cdfTransfer_smobsname diff --git a/lis/make/default.cfg b/lis/make/default.cfg index 4a1676d11..7a887fc0b 100644 --- a/lis/make/default.cfg +++ b/lis/make/default.cfg @@ -820,6 +820,10 @@ enabled: True macro: DA_OBS_GRACE path: dataassim/obs/GRACE +[DA CDF TRANSFER NASA SMAPSM] +enabled: True +macro: DA_CDF_TRANSFER_NASA_SMAPSM +path: dataassim/obs/CDF_Transfer_NASA_SMAPsm #}}} # diff --git a/lis/plugins/LIS_DAobs_pluginMod.F90 b/lis/plugins/LIS_DAobs_pluginMod.F90 index bc242a744..acf1d4df1 100644 --- a/lis/plugins/LIS_DAobs_pluginMod.F90 +++ b/lis/plugins/LIS_DAobs_pluginMod.F90 @@ -249,6 +249,11 @@ subroutine LIS_DAobs_plugin #if ( defined DA_OBS_NASA_SMAPSM ) use NASASMAPsm_Mod, only : NASASMAPsm_setup +! use cdfTransfer_Mod, only : cdfTransfer_setup +#endif + +#if ( defined DA_CDF_TRANSFER_NASA_SMAPSM ) + use cdfTransfer_NASASMAPsm_Mod, only : cdfTransfer_NASASMAPsm_setup #endif !YK @@ -432,6 +437,10 @@ subroutine LIS_DAobs_plugin external read_NASASMAPsm, write_NASASMAPsmobs #endif +#if ( defined DA_CDF_TRANSFER_NASA_SMAPSM ) + external read_cdfTransfer_NASASMAPsm, write_cdfTransfer_NASASMAPsmobs +#endif + !YK #if ( defined DA_OBS_SMOS_NRT_NN ) external read_SMOSNRTNNL2sm, write_SMOSNRTNNL2smobs @@ -802,6 +811,16 @@ subroutine LIS_DAobs_plugin write_NASASMAPsmobs) #endif +#if ( defined DA_CDF_TRANSFER_NASA_SMAPSM ) + call registerdaobsclass(trim(LIS_CDFTRANSFERNASASMAPsmobsId),"LSM") + call registerdaobssetup(trim(LIS_CDFTRANSFERNASASMAPsmobsId)//char(0),& + cdfTransfer_NASASMAPsm_setup) + call registerreaddaobs(trim(LIS_CDFTRANSFERNASASMAPsmobsId)//char(0),& + read_cdfTransfer_NASASMAPsm) + call registerwritedaobs(trim(LIS_CDFTRANSFERNASASMAPsmobsId)//char(0),& + write_cdfTransfer_NASASMAPsmobs) +#endif + !YK #if ( defined DA_OBS_SMOS_NRT_NN ) call registerdaobsclass(trim(LIS_SMOSNRTNNL2smobsId),"LSM") diff --git a/lis/plugins/LIS_lsmda_pluginMod.F90 b/lis/plugins/LIS_lsmda_pluginMod.F90 index 32f60889c..c78cc1908 100644 --- a/lis/plugins/LIS_lsmda_pluginMod.F90 +++ b/lis/plugins/LIS_lsmda_pluginMod.F90 @@ -2554,6 +2554,26 @@ subroutine LIS_lsmda_plugin trim(LIS_NASASMAPsmobsId )//char(0),NoahMP401_descale_soilm) call registerlsmdaupdatestate(trim(LIS_noahmp401Id)//"+"//& trim(LIS_NASASMAPsmobsId )//char(0),NoahMP401_updatesoilm) +!MN +! Noah-MP.4.0.1 SMAP(NASA) soil moisture with CDF Transfer + call registerlsmdainit(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_dasoilm_init) + call registerlsmdagetstatevar(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_getsoilm) + call registerlsmdasetstatevar(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_setsoilm) + call registerlsmdagetobspred(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_getsmpred) + call registerlsmdaqcstate(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_qcsoilm) + call registerlsmdaqcobsstate(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_qc_soilmobs) + call registerlsmdascalestatevar(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_scale_soilm) + call registerlsmdadescalestatevar(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_descale_soilm) + call registerlsmdaupdatestate(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_CDFTRANSFERNASASMAPsmobsId )//char(0),NoahMP401_updatesoilm) !YK ! Noah-MP.4.0.1 SMOS NRT NN soil moisture diff --git a/lis/plugins/LIS_pluginIndices.F90 b/lis/plugins/LIS_pluginIndices.F90 index adbd46d6b..b7c9e5703 100644 --- a/lis/plugins/LIS_pluginIndices.F90 +++ b/lis/plugins/LIS_pluginIndices.F90 @@ -266,6 +266,8 @@ module LIS_pluginIndices "SMOS(NESDIS) soil moisture" character*50, public, parameter :: LIS_NASASMAPsmobsId = & "SMAP(NASA) soil moisture" + character*50, public, parameter :: LIS_CDFTRANSFERNASASMAPsmobsId = & + "SMAP(NASA) soil moisture with CDF Transfer" !MN character*50, public, parameter :: LIS_SMOSNRTNNL2smobsId = & "SMOS NRT NN soil moisture" !YK character*50, public, parameter :: LIS_NASASMAPvodobsId = & From 9630bba0df5ac9074829d79182e85ab1b65272aa Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 1 Apr 2022 14:18:48 -0400 Subject: [PATCH 024/328] ensures MMF params are generated only for Noah-MP-4.0.1 --- ldt/params/Noah/Noah_parmsMod.F90 | 261 ++++++++++++++++-------------- 1 file changed, 138 insertions(+), 123 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 529088d0a..087a290af 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -131,6 +131,7 @@ subroutine NoahParms_init (flag) character*50 :: slopetype_proj character*50 :: MMF_proj type(MMF_BCsReader):: MBR_FDEPTH, MBR_RECH, MBR_RIVERBED, MBR_WTD, MBR_HGT + logical :: run_mmf = .false. ! _____________________________________________________________________ @@ -156,25 +157,30 @@ subroutine NoahParms_init (flag) call set_param_attribs(Noah_struc(n)%pblh,"NOAHMP36_PBLH",& units="m", & full_name="Noah-MP LSM planetary boundary height") - - call set_param_attribs(Noah_struc(n)%fdepth,"MMF_FDEPTH",& - units="m", & - full_name="transmissivity e-folding depth") - call set_param_attribs(Noah_struc(n)%rechclim,"MMF_RECHCLIM",& - units="mm", & - full_name="climatological recharge") - call set_param_attribs(Noah_struc(n)%riverbed,"MMF_RIVERBED",& - units="m", & - full_name="riverbed elevation") - call set_param_attribs(Noah_struc(n)%eqwtd,"MMF_EQWTD",& - units="m", & - full_name="equilibrium water table depth") - call set_param_attribs(Noah_struc(n)%areaxy,"AREAXY",& - units="km^2", & - full_name="area of the grid cell") - call set_param_attribs(Noah_struc(n)%hgtm,"MMF_HGTM",& - units="m MSL", & - full_name="GMTED2010 30-arc-second topography height") + + if (LDT_rc%lsm.eq."Noah-MP.4.0.1") then + call ESMF_ConfigGetAttribute(LDT_config, run_mmf,label='Process Noah-MP-4.0.1 MMF groundwater parameters:', DEFAULT= .false., rc=rc) + if (run_mmf) then + call set_param_attribs(Noah_struc(n)%fdepth,"MMF_FDEPTH",& + units="m", & + full_name="transmissivity e-folding depth") + call set_param_attribs(Noah_struc(n)%rechclim,"MMF_RECHCLIM",& + units="mm", & + full_name="climatological recharge") + call set_param_attribs(Noah_struc(n)%riverbed,"MMF_RIVERBED",& + units="m", & + full_name="riverbed elevation") + call set_param_attribs(Noah_struc(n)%eqwtd,"MMF_EQWTD",& + units="m", & + full_name="equilibrium water table depth") + call set_param_attribs(Noah_struc(n)%areaxy,"AREAXY",& + units="km^2", & + full_name="area of the grid cell") + call set_param_attribs(Noah_struc(n)%hgtm,"MMF_HGTM",& + units="m MSL", & + full_name="GMTED2010 30-arc-second topography height") + endif + endif endif enddo @@ -488,108 +494,110 @@ subroutine NoahParms_init (flag) endif !== MMF parameters - - check_data = .false. - - write(LDT_logunit,*)" - - - - - - - MMF Groundwater Parameters - - - - - - - - - -" - - do n = 1,LDT_rc%nnest - - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_fdepth_dir, label='MMF transmissivity dir:', rc=rc) - call LDT_verify(rc,"MMF Groundwater parameter directory not defined") - check_data = .true. - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_rechclim_dir, label='MMF climatological recharge dir:', RC=RC) - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_riverbed_dir, label='MMF riverbed elevation dir:', RC=RC) - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_eqwtd_dir , label='MMF equilibrium water table depth dir:', RC=RC) - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_hgtm_dir , label='MMF HGT_M dir:', RC=RC) + RUN_MMF_SCHME: if (run_mmf) then - end do - - if (check_data) then - - call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") - - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc); call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%watervalue,label='FDEPTH water value:', DEFAULT= 100., rc=rc) - call LDT_verify(rc,"FDEPTH water value not defined." ) + check_data = .false. - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc); call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%watervalue,label='RECHCLIM water value:',DEFAULT=0., rc=rc) - call LDT_verify(rc,"RECHCLIM water value not defined." ) - - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc); call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%watervalue,label='RIVERBED water value:',DEFAULT=-100., rc=rc) - call LDT_verify(rc,"RIVERBED water value not defined." ) - - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc); call LDT_verify(rc,"EQWTD neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%watervalue,label='EQWTD water value:',DEFAULT = 0., rc=rc) - call LDT_verify(rc,"EQWTD fill value not defined." ) - - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc); call LDT_verify(rc,"HGT_M neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%watervalue,label='HGT_M water value:',DEFAULT=-100.,rc=rc) - call LDT_verify(rc,"HGT_M fill value not defined." ) + write(LDT_logunit,*)" - - - - - - - MMF Groundwater Parameters - - - - - - - - - -" do n = 1,LDT_rc%nnest - allocate (Noah_struc(n)%fdepth%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%fdepth%num_bins )) - allocate (Noah_struc(n)%rechclim%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%rechclim%num_bins)) - allocate (Noah_struc(n)%riverbed%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%riverbed%num_bins)) - allocate (Noah_struc(n)%eqwtd%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) - allocate (Noah_struc(n)%areaxy%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) - allocate (Noah_struc(n)%hgtm%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%hgtm%num_bins )) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_fdepth_dir, label='MMF transmissivity dir:', rc=rc) + call LDT_verify(rc,"MMF Groundwater parameter directory not defined") + check_data = .true. + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_rechclim_dir, label='MMF climatological recharge dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_riverbed_dir, label='MMF riverbed elevation dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_eqwtd_dir , label='MMF equilibrium water table depth dir:', RC=RC) + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_hgtm_dir , label='MMF HGT_M dir:', RC=RC) - call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) - call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") - - ! Read in index files in GEOGRID directories and create mapping - - call MBR_FDEPTH%mi (n, MMF_proj, Noah_struc(n)%mmf_fdepth_dir) - call MBR_RECH%mi (n, MMF_proj, Noah_struc(n)%mmf_rechclim_dir, MBR_FDEPTH%MMF_mapping) - call MBR_RIVERBED%mi (n, MMF_proj, Noah_struc(n)%mmf_riverbed_dir, MBR_FDEPTH%MMF_mapping) - call MBR_WTD%mi (n, MMF_proj, Noah_struc(n)%mmf_eqwtd_dir , MBR_FDEPTH%MMF_mapping) - call MBR_HGT%mi (n, MMF_proj, Noah_struc(n)%mmf_hgtm_dir , MBR_FDEPTH%MMF_mapping) - - ! Read in variables fields - - call MBR_FDEPTH%mr (n, trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value , Noah_struc(n)%mmf_transform) - call MBR_RECH%mr (n, trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value, Noah_struc(n)%mmf_transform) - call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform) - call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform) - call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform) - - ! write areaXY - - call cell_area (n,Noah_struc(n)%areaxy%value) - end do - endif - + if (check_data) then + + call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") + + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc); call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%watervalue,label='FDEPTH water value:', DEFAULT= 100., rc=rc) + call LDT_verify(rc,"FDEPTH water value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc); call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%watervalue,label='RECHCLIM water value:',DEFAULT=0., rc=rc) + call LDT_verify(rc,"RECHCLIM water value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc); call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%watervalue,label='RIVERBED water value:',DEFAULT=-100., rc=rc) + call LDT_verify(rc,"RIVERBED water value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc); call LDT_verify(rc,"EQWTD neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%watervalue,label='EQWTD water value:',DEFAULT = 0., rc=rc) + call LDT_verify(rc,"EQWTD fill value not defined." ) + + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc); call LDT_verify(rc,"HGT_M neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%watervalue,label='HGT_M water value:',DEFAULT=-100.,rc=rc) + call LDT_verify(rc,"HGT_M fill value not defined." ) + + do n = 1,LDT_rc%nnest + + allocate (Noah_struc(n)%fdepth%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%fdepth%num_bins )) + allocate (Noah_struc(n)%rechclim%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%rechclim%num_bins)) + allocate (Noah_struc(n)%riverbed%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%riverbed%num_bins)) + allocate (Noah_struc(n)%eqwtd%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) + allocate (Noah_struc(n)%areaxy%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%eqwtd%num_bins )) + allocate (Noah_struc(n)%hgtm%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%hgtm%num_bins )) + + call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_transform, label='MMF spatial transform:', rc=rc) + call LDT_verify(rc,"MMF spatial transform method is not defined in the config file.") + + ! Read in index files in GEOGRID directories and create mapping + + call MBR_FDEPTH%mi (n, MMF_proj, Noah_struc(n)%mmf_fdepth_dir) + call MBR_RECH%mi (n, MMF_proj, Noah_struc(n)%mmf_rechclim_dir, MBR_FDEPTH%MMF_mapping) + call MBR_RIVERBED%mi (n, MMF_proj, Noah_struc(n)%mmf_riverbed_dir, MBR_FDEPTH%MMF_mapping) + call MBR_WTD%mi (n, MMF_proj, Noah_struc(n)%mmf_eqwtd_dir , MBR_FDEPTH%MMF_mapping) + call MBR_HGT%mi (n, MMF_proj, Noah_struc(n)%mmf_hgtm_dir , MBR_FDEPTH%MMF_mapping) + + ! Read in variables fields + + call MBR_FDEPTH%mr (n, trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value , Noah_struc(n)%mmf_transform) + call MBR_RECH%mr (n, trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value, Noah_struc(n)%mmf_transform) + call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform) + call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform) + call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform) + + ! write areaXY + + call cell_area (n,Noah_struc(n)%areaxy%value) + + end do + endif + endif RUN_MMF_SCHME + end subroutine NoahParms_init ! -------------------------------------------------------------------- subroutine NoahParms_writeHeader(n,ftn,dimID) - integer :: n + integer :: n, rc integer :: ftn integer :: dimID(3) - + logical :: run_mmf = .false. + call LDT_writeNETCDFdataHeader(n,ftn,dimID,& Noah_struc(n)%tbot) @@ -601,21 +609,25 @@ subroutine NoahParms_writeHeader(n,ftn,dimID) call LDT_writeNETCDFdataHeader(n,ftn,dimID,& Noah_struc(n)%pblh) endif - - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%fdepth ) - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%rechclim ) - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%riverbed ) - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%eqwtd ) - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%areaxy ) - call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%hgtm ) - + if (LDT_rc%lsm.eq."Noah-MP.4.0.1") then + call ESMF_ConfigGetAttribute(LDT_config, run_mmf,label='Process Noah-MP-4.0.1 MMF groundwater parameters:', DEFAULT= .false., rc=rc) + if (run_mmf) then + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%fdepth ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%rechclim ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%riverbed ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%eqwtd ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%areaxy ) + call LDT_writeNETCDFdataHeader(n,ftn,dimID,Noah_struc(n)%hgtm ) + endif + endif end subroutine NoahParms_writeHeader subroutine NoahParms_writeData(n,ftn) - integer :: n + integer :: n, rc integer :: ftn - + logical :: run_mmf = .false. + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%tbot) call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%slopetype) @@ -624,14 +636,17 @@ subroutine NoahParms_writeData(n,ftn) (LDT_rc%lsm.eq."Noah-MP.4.0.1")) then call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%pblh) endif - - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%fdepth ) - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%rechclim ) - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%riverbed ) - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%eqwtd ) - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%areaxy ) - call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%hgtm ) - + if (LDT_rc%lsm.eq."Noah-MP.4.0.1") then + call ESMF_ConfigGetAttribute(LDT_config, run_mmf,label='Process Noah-MP-4.0.1 MMF groundwater parameters:', DEFAULT= .false., rc=rc) + if (run_mmf) then + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%fdepth ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%rechclim ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%riverbed ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%eqwtd ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%areaxy ) + call LDT_writeNETCDFdata(n,ftn,Noah_struc(n)%hgtm ) + endif + endif end subroutine NoahParms_writeData From c2592337b02d5a4e00fa3917714621f3b9f08621 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 15:58:58 -0400 Subject: [PATCH 025/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 1 + 1 file changed, 1 insertion(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index e1b835355..930257ac3 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2375,6 +2375,7 @@ Bottom temperature resolution (dy): 0.2500 .... Noah-MP PBL Height Value: 900. # in meters .... +===Miguez-Macho and Fan (MMF) Groundwater Parameters If selecting the Community Land Model (4.5 version), the following config entires are also required. From 136f745e70c62c8e3e3036763485dfa874742436 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:05:25 -0400 Subject: [PATCH 026/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 930257ac3..8ff3af88d 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -7,7 +7,7 @@ This section describes the options in the _ldt.config_ file. Not all options described here are available in the public version of LDT. [[ssec-driveropts]] -=== Overall driver options +===Overall driver options `LDT running mode:` specifies the running mode used in LDT. Acceptable values are: @@ -2375,7 +2375,11 @@ Bottom temperature resolution (dy): 0.2500 .... Noah-MP PBL Height Value: 900. # in meters .... -===Miguez-Macho and Fan (MMF) Groundwater Parameters +Miguez-Macho and Fan (MMF) Groundwater Parameters +NOTE: Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwater scheme. +`Process Noah-MP-4.0.1 MMF groundwater parameters:` is the switch to turn on processing MMF parameters. +.Example _ldt.config_ entry +`Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` If selecting the Community Land Model (4.5 version), the following config entires are also required. From 46cf4cbf8fd5caf4dd0d29ae37a6a86772dd8434 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:07:23 -0400 Subject: [PATCH 027/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 2 ++ 1 file changed, 2 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8ff3af88d..1f8f65bc1 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2376,7 +2376,9 @@ Bottom temperature resolution (dy): 0.2500 Noah-MP PBL Height Value: 900. # in meters .... Miguez-Macho and Fan (MMF) Groundwater Parameters + NOTE: Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwater scheme. + `Process Noah-MP-4.0.1 MMF groundwater parameters:` is the switch to turn on processing MMF parameters. .Example _ldt.config_ entry `Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` From 8f662302b9663057c70f571602b6aeda6df9d2f1 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:09:04 -0400 Subject: [PATCH 028/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 1f8f65bc1..36c40d27d 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2377,10 +2377,12 @@ Noah-MP PBL Height Value: 900. # in meters .... Miguez-Macho and Fan (MMF) Groundwater Parameters -NOTE: Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwater scheme. +NOTE Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwater scheme. `Process Noah-MP-4.0.1 MMF groundwater parameters:` is the switch to turn on processing MMF parameters. + .Example _ldt.config_ entry + `Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` If selecting the Community Land Model (4.5 version), the following config entires are also required. From 43c0d88c31cfcab6c5dc58a1694140f1d58ca43b Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:15:27 -0400 Subject: [PATCH 029/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 36c40d27d..655c21cd7 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2385,6 +2385,16 @@ NOTE Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwate `Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` +Directories where 1km FEDEPTH, RECHARGE, RIVERBED, EQWTD, and GMTED2010 data on GEOGRID tiles are located. + +.Example _ldt.config_ entry +.... +MMF transmissivity dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/f/ +MMF climatological recharge dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/recharge/ +MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed/ +MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/wtd/ +MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ +.... If selecting the Community Land Model (4.5 version), the following config entires are also required. `CLM45 parameter mode:` specifies whether to "`readin`" the CLM-4.5 parameters from pre-processed files. Currently, only the "`readin`" option is available. From 3576f904bdec1d1a72999158492f7fa599c26d28 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:18:30 -0400 Subject: [PATCH 030/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 44 +++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 655c21cd7..d3d21e2fa 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2395,6 +2395,50 @@ MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/wtd/ MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ .... + +Spatial interpolation and gap filling parameters for each MMF variable. + +.Example _ldt.config_ entry +.... +# MMF parameter interpolation follows that of WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp +# WPS first (average_gcell) spatially averages finer resolution data to coarser resolution grid cells +# which is similar to LDT's "upscaleByAveraging". +MMF map projection: latlon +MMF spatial transform: average + +# WPS uses a two-step gap procedure to fill gaps: (1) average from the immediate neighborhood (average_4pt), (2) search and fill + +# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. +FDEPTH neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +FDEPTH fill option: neighbor +FDEPTH fill radius: 1200 # Number of #pixels to search for neighbor +FDEPTH fill value: 100. + +# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. +RECHCLIM neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +RECHCLIM fill option: neighbor +RECHCLIM fill radius: 1200 # Number of #pixels to search for neighbor +RECHCLIM fill value: -1. + +# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +RIVERBED fill option: neighbor +RIVERBED fill radius: 1200 # Number of #pixels to search for neighbor +RIVERBED fill value: 0. + +# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +EQWTD fill option: neighbor +EQWTD fill radius: 1200 # Number of #pixels to search for neighbor +EQWTD fill value: 0. + +# WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. +HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure +HGT_M fill option: neighbor +HGT_M fill radius: 1200 # Number of #pixels to search for neighbor +HGT_M fill value: 0. +.... + If selecting the Community Land Model (4.5 version), the following config entires are also required. `CLM45 parameter mode:` specifies whether to "`readin`" the CLM-4.5 parameters from pre-processed files. Currently, only the "`readin`" option is available. From 718a1e49d90115c4f06c8a9ab57606238e45e1fc Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 1 Apr 2022 16:25:10 -0400 Subject: [PATCH 031/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index d3d21e2fa..28d8237fc 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2409,30 +2409,35 @@ MMF spatial transform: average # WPS uses a two-step gap procedure to fill gaps: (1) average from the immediate neighborhood (average_4pt), (2) search and fill # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. +# FDEPTH: Transmissivity e-folding depth [m] FDEPTH neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure FDEPTH fill option: neighbor FDEPTH fill radius: 1200 # Number of #pixels to search for neighbor FDEPTH fill value: 100. # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. +# RECHCLIM: Climatological recharge [mm] RECHCLIM neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure RECHCLIM fill option: neighbor RECHCLIM fill radius: 1200 # Number of #pixels to search for neighbor RECHCLIM fill value: -1. # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +# RIVERBED Riverbed elevation [m] RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure RIVERBED fill option: neighbor RIVERBED fill radius: 1200 # Number of #pixels to search for neighbor RIVERBED fill value: 0. # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +# EQWTD: Equilibrium water table depth [m] EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure EQWTD fill option: neighbor EQWTD fill radius: 1200 # Number of #pixels to search for neighbor EQWTD fill value: 0. # WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. +HGT_M: GMTED2010 30-arc-second topography height [m from MSL] HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure HGT_M fill option: neighbor HGT_M fill radius: 1200 # Number of #pixels to search for neighbor From 3b9dc81844cb5d4de285f7ae109ae87024ddb7ad Mon Sep 17 00:00:00 2001 From: Brendan McAndrew Date: Wed, 6 Apr 2022 17:32:14 -0400 Subject: [PATCH 032/328] Enable soil layer attrs in LIS postprocessing mode --- lvt/core/LVT_LISpostMod.F90 | 58 ++++++++++++++++++++++++++++++++----- 1 file changed, 51 insertions(+), 7 deletions(-) diff --git a/lvt/core/LVT_LISpostMod.F90 b/lvt/core/LVT_LISpostMod.F90 index d3ac73155..e7e86bac8 100644 --- a/lvt/core/LVT_LISpostMod.F90 +++ b/lvt/core/LVT_LISpostMod.F90 @@ -62,6 +62,8 @@ module LVT_LISpostMod integer :: npes integer :: nfields integer :: nlevels + integer :: nsoilmoistlayers, nsoiltemplayers + real, pointer :: soilmoistlyrthk(:), soiltemplyrthk(:) end type lispost_type_dec type(lispost_type_dec) :: LVT_LISpost @@ -87,7 +89,7 @@ subroutine LVT_initialize_LISpost() ! !EOP - integer :: rc + integer :: i, rc call ESMF_ConfigGetAttribute(LVT_config,LVT_LISpost%npes,& label="Number of processors used in the LIS output generation:",rc=rc) @@ -98,6 +100,36 @@ subroutine LVT_initialize_LISpost() call ESMF_ConfigGetAttribute(LVT_config,LVT_LISpost%nlevels,& label="Number of vertical levels in the LIS output:",rc=rc) call LVT_verify(rc,'Number of vertical levels in the LIS output: option not specified in the config file') + call ESMF_ConfigGetAttribute(LVT_config, LVT_LISpost%nsoilmoistlayers, & + label="LIS output number of soil moisture layers:", default=0, rc=rc) + call ESMF_ConfigGetAttribute(LVT_config, LVT_LISpost%nsoiltemplayers, & + label="LIS output number of soil temperature layers:", default=0, rc=rc) + + if (LVT_LISpost%nsoilmoistlayers .gt. 0) then + allocate(LVT_LISpost%soilmoistlyrthk(LVT_LISpost%nsoilmoistlayers)) + + call ESMF_ConfigFindLabel(LVT_config, "LIS output soil moisture layer thickness:", rc=rc) + call LVT_verify(rc, 'LIS output soil moisture layer thickness: option not specified in the config file') + + do i=1, LVT_LISpost%nsoilmoistlayers + call ESMF_ConfigGetAttribute(LVT_config,LVT_LISpost%soilmoistlyrthk(i), rc=rc) + call LVT_verify(rc, 'The number of soil moisture layers indicated in the & + config file is greater than the number of thickness values provided') + enddo + endif + + if (LVT_LISpost%nsoiltemplayers .gt. 0) then + allocate(LVT_LISpost%soiltemplyrthk(LVT_LISpost%nsoiltemplayers)) + + call ESMF_ConfigFindLabel(LVT_config, "LIS output soil temperature layer thickness:", rc=rc) + call LVT_verify(rc, 'LIS output soil temperature layer thickness: option not specified in the config file') + + do i=1, LVT_LISpost%nsoilmoistlayers + call ESMF_ConfigGetAttribute(LVT_config,LVT_LISpost%soiltemplyrthk(i), rc=rc) + call LVT_verify(rc, 'The number of soil temperature layers indicated in the & + config file is greater than the number of thickness values provided') + enddo + endif end subroutine LVT_initialize_LISpost @@ -266,12 +298,24 @@ subroutine LVT_process_LISoutput 'nf90_def_att for lat failed in LVT_LISpostMod') ! Global attributes -! call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"NUM_SOIL_LAYERS", & -! nsoillayers),& -! 'nf90_put_att for title failed in LVT_LISpostMod') -! call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"SOIL_LAYER_THICKNESSES", & -! lyrthk),& -! 'nf90_put_att for title failed in LVT_LISpostMod') + if (LVT_LISpost%nsoilmoistlayers .gt. 0) then + call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"NUM_SOIL_MOIST_LAYERS", & + LVT_LISpost%nsoilmoistlayers),& + 'nf90_put_att for NUM_SOIL_MOIST_LAYERS failed in LVT_LISpostMod') + call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"SOIL_MOIST_LAYER_THICKNESSES", & + LVT_LISpost%soilmoistlyrthk),& + 'nf90_put_att for SOIL_MOIST_LAYER_THICKNESSES failed in LVT_LISpostMod') + endif + + if (LVT_LISpost%nsoiltemplayers .gt. 0) then + call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"NUM_SOIL_TEMP_LAYERS", & + LVT_LISpost%nsoiltemplayers),& + 'nf90_put_att for NUM_SOIL_TEMP_LAYERS failed in LVT_LISpostMod') + call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"SOIL_TEMP_LAYER_THICKNESSES", & + LVT_LISpost%soiltemplyrthk),& + 'nf90_put_att for SOIL_TEMP_LAYER_THICKNESSES failed in LVT_LISpostMod') + endif + call LVT_verify(nf90_put_att(ftn_nc,NF90_GLOBAL,"title", & "LIS land surface model output"),& 'nf90_put_att for title failed in LVT_LISpostMod') From 92cc877e9a2a579deacd6ecfd99cce38147825dd Mon Sep 17 00:00:00 2001 From: Brendan McAndrew <19274445+bmcandr@users.noreply.github.com> Date: Thu, 7 Apr 2022 13:45:49 -0400 Subject: [PATCH 033/328] Add soil moist and temp layer options to config Adds configuration entries for soil moisture and temperature layers to LIS postprocessing mode section --- lvt/configs/lvt.config.adoc | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/lvt/configs/lvt.config.adoc b/lvt/configs/lvt.config.adoc index f89440394..e9f7590e2 100644 --- a/lvt/configs/lvt.config.adoc +++ b/lvt/configs/lvt.config.adoc @@ -2632,3 +2632,23 @@ Number of fields in the LIS output: 11 .... Number of vertical levels in the LIS output: 4 .... + +`LIS output number of soil moisture layers:` specifies the number of soil moisture layers used in the LIS output. This is optional and defaults to 0. + +`LIS output soil moisture layer thickness:` specifies the number of soil moisture layers used in the LIS output. These values will be written to the NetCDF as global attributes and should match those used in the LIS configuration file to define the LSM soil moisture layer thicknesses. If the number of soil moisture layers is omitted or set to 0, this entry is not read and soil moisture layer thicknesses are not written to the NetCDF global attributes. + +.Example _lvt.config_ entry +.... +LIS output number of soil moisture layers: 4 +LIS output soil moisture layer thickness: 0.1 0.3 0.6 1.0 +.... + +`LIS output number of soil temperature layers:` specifies the thicknesses of soil moisture layers in the LIS output. This is optional and defaults to 0. + +`LIS output soil temperature layer thickness:` specifies the thicknesses of soil temperature layers in the LIS output. These values will be written to the NetCDF as global attributes and should match those used in the LIS configuration file to define the LSM soil temperature layer thicknesses. If the number of soil temperature layers is omitted or set to 0, this entry is not read and soil temperature layer thicknesses are not written to the NetCDF global attributes. + +.Example _lvt.config_ entry +.... +LIS output number of soil temperature layers: 4 +LIS output soil temperature layer thickness: 0.1 0.3 0.6 1.0 +.... From 88ace083bb48af11d95a5b05d7a4c67c6c1e4e75 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Fri, 15 Apr 2022 15:22:57 -0400 Subject: [PATCH 034/328] addressed @dmocko comments --- ldt/params/Noah/Noah_parmsMod.F90 | 85 ++++++++++++++-------- ldt/params/Noah/module_MMF_groundwater.F90 | 14 ++-- 2 files changed, 63 insertions(+), 36 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 087a290af..17a88cc1d 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -500,54 +500,77 @@ subroutine NoahParms_init (flag) write(LDT_logunit,*)" - - - - - - - MMF Groundwater Parameters - - - - - - - - - -" - do n = 1,LDT_rc%nnest - + do n = 1,LDT_rc%nnest call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_fdepth_dir, label='MMF transmissivity dir:', rc=rc) - call LDT_verify(rc,"MMF Groundwater parameter directory not defined") - check_data = .true. + call LDT_verify(rc,"MMF transmissivity dir: not defined") call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_rechclim_dir, label='MMF climatological recharge dir:', RC=RC) + call LDT_verify(rc,"MMF climatological recharge dir: not defined") call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_riverbed_dir, label='MMF riverbed elevation dir:', RC=RC) + call LDT_verify(rc,"MMF riverbed elevation dir: not defined") call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_eqwtd_dir , label='MMF equilibrium water table depth dir:', RC=RC) + call LDT_verify(rc,"MMF equilibrium water table depth dir: not defined") call ESMF_ConfigGetAttribute(LDT_config, Noah_struc(n)%mmf_hgtm_dir , label='MMF HGT_M dir:', RC=RC) - + call LDT_verify(rc,"MMF HGT_M dir: not defined") + check_data = .true. end do if (check_data) then - call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) ; call LDT_verify(rc,"MMF map projection not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) + call LDT_verify(rc,"MMF map projection not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc); call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc); call LDT_verify(rc,"FDEPTH fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc); call LDT_verify(rc,"FDEPTH fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc); call LDT_verify(rc,"FDEPTH fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc) + call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc) + call LDT_verify(rc,"FDEPTH fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc) + call LDT_verify(rc,"FDEPTH fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc) + call LDT_verify(rc,"FDEPTH fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%watervalue,label='FDEPTH water value:', DEFAULT= 100., rc=rc) call LDT_verify(rc,"FDEPTH water value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc); call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc); call LDT_verify(rc,"RECHCLIM fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc); call LDT_verify(rc,"RECHCLIM fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc); call LDT_verify(rc,"RECHCLIM fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc) + call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc) + call LDT_verify(rc,"RECHCLIM fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc) + call LDT_verify(rc,"RECHCLIM fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc) + call LDT_verify(rc,"RECHCLIM fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%watervalue,label='RECHCLIM water value:',DEFAULT=0., rc=rc) call LDT_verify(rc,"RECHCLIM water value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc); call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc); call LDT_verify(rc,"RIVERBED fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc); call LDT_verify(rc,"RIVERBED fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc); call LDT_verify(rc,"RIVERBED fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc) + call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc) + call LDT_verify(rc,"RIVERBED fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc) + call LDT_verify(rc,"RIVERBED fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc) + call LDT_verify(rc,"RIVERBED fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%watervalue,label='RIVERBED water value:',DEFAULT=-100., rc=rc) call LDT_verify(rc,"RIVERBED water value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc); call LDT_verify(rc,"EQWTD neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc); call LDT_verify(rc,"EQWTD fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc); call LDT_verify(rc,"EQWTD fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc); call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc) + call LDT_verify(rc,"EQWTD neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc) + call LDT_verify(rc,"EQWTD fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc) + call LDT_verify(rc,"EQWTD fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc) + call LDT_verify(rc,"EQWTD fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%watervalue,label='EQWTD water value:',DEFAULT = 0., rc=rc) call LDT_verify(rc,"EQWTD fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc); call LDT_verify(rc,"HGT_M neighborhood radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc); call LDT_verify(rc,"HGT_M fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc); call LDT_verify(rc,"HGT_M fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc); call LDT_verify(rc,"HGT_M fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc) + call LDT_verify(rc,"HGT_M neighborhood radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc) + call LDT_verify(rc,"HGT_M fill option not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc) + call LDT_verify(rc,"HGT_M fill radius not defined.") + call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc) + call LDT_verify(rc,"HGT_M fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%watervalue,label='HGT_M water value:',DEFAULT=-100.,rc=rc) call LDT_verify(rc,"HGT_M fill value not defined." ) @@ -573,11 +596,11 @@ subroutine NoahParms_init (flag) ! Read in variables fields - call MBR_FDEPTH%mr (n, trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value , Noah_struc(n)%mmf_transform) - call MBR_RECH%mr (n, trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value, Noah_struc(n)%mmf_transform) - call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform) - call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform) - call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform) + call MBR_FDEPTH%mr (n, trim(Noah_struc(n)%mmf_fdepth_dir ), Noah_struc(n)%fdepth%value , Noah_struc(n)%mmf_transform, Noah_struc(n)%fdepth%short_name ) + call MBR_RECH%mr (n, trim(Noah_struc(n)%mmf_rechclim_dir), Noah_struc(n)%rechclim%value, Noah_struc(n)%mmf_transform, Noah_struc(n)%rechclim%short_name) + call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform, Noah_struc(n)%riverbed%short_name) + call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform, Noah_struc(n)%eqwtd%short_name ) + call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform, Noah_struc(n)%hgtm%short_name ) ! write areaXY diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 7f1c4ae6a..3cee6c156 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -25,7 +25,7 @@ module MMF_groundwater use LDT_logMod, only : LDT_logunit, LDT_endrun, LDT_verify use LDT_coreMod, only : LDT_rc, LDT_domain, LDT_config use LDT_gridmappingMod, only : LDT_RunDomainPts - use LDT_paramMaskCheckMod,only : LDT_fillopts, LDT_contIndivParam_Fill + use LDT_paramMaskCheckMod,only : LDT_fillopts, LDT_contIndivParam_Fill, fill_logunit use LDT_paramDataMod, only : LDT_LSMparam_struc implicit none @@ -191,12 +191,12 @@ END SUBROUTINE mmf_init ! ---------------------------------------------------------------- - SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) + SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform, short_name) implicit none class (MMF_BCsReader), intent(inout) :: MBR - character(*), intent (in) :: datadir, mmf_transform + character(*), intent (in) :: datadir, mmf_transform, short_name real, dimension (:,:,:), intent (inout) :: lisout integer, intent (in) :: nest character(len=1024):: geogridFile @@ -214,7 +214,8 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) ! Reading GEOGRID data ! -------------------- - + write(LDT_logunit,*) "Reading data from: ",trim(datadir) + num_tile_lon = NX_MMF / MBR%gp%tile_x num_tile_lat = NY_MMF / MBR%gp%tile_y @@ -293,7 +294,10 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform) ! Search and fill -also fill lakes ! -------------------------------- - + write(LDT_logunit,*) "Checking/filling mask values for: ", & + trim(short_name) + write(fill_logunit,*) "Checking/filling mask values for: ", & + trim(short_name) call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & mmf_transform, & nbins, & From a898c46fa8d6168544363e5e785ac3bf18406211 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 11:50:23 -0400 Subject: [PATCH 035/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 28d8237fc..4a087db14 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2384,6 +2384,10 @@ NOTE Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwate .Example _ldt.config_ entry `Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` +If this config entry is not present, then it is assumed to be .false., and the Noah-MP-4.0.1 MMF groundwater parameters will not be processed. +Note that these parameters are only needed when running option "5" for the following lis.config entry when running LIS: +Noah-MP.4.0.1 runoff and groundwater option: 5 +Finally, note that this MMF groundwater option (option 5) is not yet supported in LIS, although the LIS team is nearing completion of its implementation. Directories where 1km FEDEPTH, RECHARGE, RIVERBED, EQWTD, and GMTED2010 data on GEOGRID tiles are located. From 39b3a9b49f3aff82cca442443e3adf36208b41fc Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 12:03:37 -0400 Subject: [PATCH 036/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 2 ++ 1 file changed, 2 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 4a087db14..8ceca1417 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2386,7 +2386,9 @@ NOTE Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwate `Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` If this config entry is not present, then it is assumed to be .false., and the Noah-MP-4.0.1 MMF groundwater parameters will not be processed. Note that these parameters are only needed when running option "5" for the following lis.config entry when running LIS: + Noah-MP.4.0.1 runoff and groundwater option: 5 + Finally, note that this MMF groundwater option (option 5) is not yet supported in LIS, although the LIS team is nearing completion of its implementation. Directories where 1km FEDEPTH, RECHARGE, RIVERBED, EQWTD, and GMTED2010 data on GEOGRID tiles are located. From 97f4a64ccf33e5d5b99292a91776acf4ba5a35c9 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 12:28:44 -0400 Subject: [PATCH 037/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8ceca1417..75ecd7069 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2420,6 +2420,7 @@ FDEPTH neighborhood radius: 1 # average neighborhood points for the first of WPS FDEPTH fill option: neighbor FDEPTH fill radius: 1200 # Number of #pixels to search for neighbor FDEPTH fill value: 100. +FDEPTH water value: 100. # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. # RECHCLIM: Climatological recharge [mm] @@ -2427,27 +2428,31 @@ RECHCLIM neighborhood radius: 1 # average neighborhood points for the first of W RECHCLIM fill option: neighbor RECHCLIM fill radius: 1200 # Number of #pixels to search for neighbor RECHCLIM fill value: -1. - +RECHCLIM water value: 0. + # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. # RIVERBED Riverbed elevation [m] RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure RIVERBED fill option: neighbor RIVERBED fill radius: 1200 # Number of #pixels to search for neighbor RIVERBED fill value: 0. - +RIVERBED water value: -100. + # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. # EQWTD: Equilibrium water table depth [m] EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure EQWTD fill option: neighbor EQWTD fill radius: 1200 # Number of #pixels to search for neighbor EQWTD fill value: 0. - +EQWTD water value: 0. + # WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. HGT_M: GMTED2010 30-arc-second topography height [m from MSL] HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure HGT_M fill option: neighbor HGT_M fill radius: 1200 # Number of #pixels to search for neighbor HGT_M fill value: 0. +HGT_M water value: -100. .... If selecting the Community Land Model (4.5 version), the following config entires are also required. From 3ffacc5f06bc32d810f187e8750ad5409697b034 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 22:00:23 -0400 Subject: [PATCH 038/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 75ecd7069..6a703f45b 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2406,9 +2406,9 @@ Spatial interpolation and gap filling parameters for each MMF variable. .Example _ldt.config_ entry .... -# MMF parameter interpolation follows that of WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp -# WPS first (average_gcell) spatially averages finer resolution data to coarser resolution grid cells -# which is similar to LDT's "upscaleByAveraging". +https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp +describe WPS's preprocessing procedures of MMF parameters from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native GEOGRID space makes it fundamentally differ from LDT because LDT first aggregates input data from the native grid to the model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter processing does not attempt to replicate the WPS interpolation procedures, instead it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. + MMF map projection: latlon MMF spatial transform: average From a1d7c666dc87fe6e19148d355459fa1a6b0527c7 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 22:13:10 -0400 Subject: [PATCH 039/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 6a703f45b..d0f18809e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2406,14 +2406,17 @@ Spatial interpolation and gap filling parameters for each MMF variable. .Example _ldt.config_ entry .... -https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp -describe WPS's preprocessing procedures of MMF parameters from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native GEOGRID space makes it fundamentally differ from LDT because LDT first aggregates input data from the native grid to the model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter processing does not attempt to replicate the WPS interpolation procedures, instead it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. +https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and +WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp describe WPS's preprocessing procedures of MMF parameters from the GEOGRID +grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native +GEOGRID space makes it fundamentally differ from LDT because LDT first aggregates input data from the native grid to the +model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter processing does not +attempt to replicate the WPS interpolation procedures, instead it uses existing LDT interpolation utilities to follow +the WPS's interpolation concept. MMF map projection: latlon MMF spatial transform: average -# WPS uses a two-step gap procedure to fill gaps: (1) average from the immediate neighborhood (average_4pt), (2) search and fill - # WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. # FDEPTH: Transmissivity e-folding depth [m] FDEPTH neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure From 936ef27cffcd0612f674b651a65e19fe3245ad05 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 22:17:06 -0400 Subject: [PATCH 040/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index d0f18809e..132dcde89 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2407,11 +2407,11 @@ Spatial interpolation and gap filling parameters for each MMF variable. .Example _ldt.config_ entry .... https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and -WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp describe WPS's preprocessing procedures of MMF parameters from the GEOGRID +WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp describe WPS's MMF parameter preprocessing procedures from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native -GEOGRID space makes it fundamentally differ from LDT because LDT first aggregates input data from the native grid to the -model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter processing does not -attempt to replicate the WPS interpolation procedures, instead it uses existing LDT interpolation utilities to follow +GEOGRID space makes it fundamentally different to LDT because LDT first aggregates input data from the native grid to the +model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter preprocessing does not +attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. MMF map projection: latlon From 246589caddabbb16d96830272e75b3e9ad9b085e Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 22:29:05 -0400 Subject: [PATCH 041/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 132dcde89..9aef027dc 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2402,7 +2402,7 @@ MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwat MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ .... -Spatial interpolation and gap filling parameters for each MMF variable. +Spatial interpolation and gap filling parameters for each MMF variable are also required. .Example _ldt.config_ entry .... From 7ed323b897ec48a45291cedcac1669859b88ff29 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 22:39:37 -0400 Subject: [PATCH 042/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 9aef027dc..33f733f9a 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2404,7 +2404,6 @@ MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ Spatial interpolation and gap filling parameters for each MMF variable are also required. -.Example _ldt.config_ entry .... https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp describe WPS's MMF parameter preprocessing procedures from the GEOGRID @@ -2413,7 +2412,17 @@ GEOGRID space makes it fundamentally different to LDT because LDT first aggregat model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter preprocessing does not attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. +.... +`MMF map projection: ` +`MMF spatial transform:` +`MMF neighborhood radius:` +`MMF fill option:` +`MMF fill radius:` +`MMF fill value:` +`MMF water value:` +.Example _ldt.config_ entry +.... MMF map projection: latlon MMF spatial transform: average From 3156ec18314ff4dc1b77b3eccf1f439ecd0fe224 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 23:12:49 -0400 Subject: [PATCH 043/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 65 ++++++++++++++++++++++++------------- 1 file changed, 42 insertions(+), 23 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 33f733f9a..b9d08da21 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2413,53 +2413,72 @@ model grid and then fills gaps on the model grid space. Current LDT implementati attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. .... -`MMF map projection: ` -`MMF spatial transform:` -`MMF neighborhood radius:` -`MMF fill option:` -`MMF fill radius:` -`MMF fill value:` -`MMF water value:` + +Below MMF is referred to FEDEPTH, RECHARGE, RIVERBED, EQWTD, or GMTED2010 parameter value. + +`MMF map projection: ` map projection parameter is always set to latlon for MMF parameters. + +`MMF spatial transform:` spatial transform parameter is always set to average for MMF parameters. + +`MMF neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. + +`MMF fill option:` + +`MMF fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`MMF fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`MMF water value:` indicates the parameter value to be used on lakes or water grid cells. .Example _ldt.config_ entry .... MMF map projection: latlon MMF spatial transform: average +.... -# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. -# FDEPTH: Transmissivity e-folding depth [m] -FDEPTH neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +FDEPTH: Transmissivity e-folding depth [m] +WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. +.... +FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor -FDEPTH fill radius: 1200 # Number of #pixels to search for neighbor +FDEPTH fill radius: 1200 FDEPTH fill value: 100. FDEPTH water value: 100. +.... -# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. -# RECHCLIM: Climatological recharge [mm] -RECHCLIM neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +RECHCLIM: Climatological recharge [mm] +WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. +.... +RECHCLIM neighborhood radius: 1 RECHCLIM fill option: neighbor -RECHCLIM fill radius: 1200 # Number of #pixels to search for neighbor +RECHCLIM fill radius: 1200 RECHCLIM fill value: -1. RECHCLIM water value: 0. - -# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. -# RIVERBED Riverbed elevation [m] +.... + +RIVERBED Riverbed elevation [m] +WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +.... RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure RIVERBED fill option: neighbor RIVERBED fill radius: 1200 # Number of #pixels to search for neighbor RIVERBED fill value: 0. RIVERBED water value: -100. - -# WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. -# EQWTD: Equilibrium water table depth [m] +.... + +EQWTD: Equilibrium water table depth [m] +WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +.... EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure EQWTD fill option: neighbor EQWTD fill radius: 1200 # Number of #pixels to search for neighbor EQWTD fill value: 0. EQWTD water value: 0. - -# WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. +.... + HGT_M: GMTED2010 30-arc-second topography height [m from MSL] +WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. +.... HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure HGT_M fill option: neighbor HGT_M fill radius: 1200 # Number of #pixels to search for neighbor From fdd7d2f67f7836be58323da0f754fbf6a79caf49 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 23:15:01 -0400 Subject: [PATCH 044/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index b9d08da21..b04882ef0 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2416,7 +2416,7 @@ the WPS's interpolation concept. Below MMF is referred to FEDEPTH, RECHARGE, RIVERBED, EQWTD, or GMTED2010 parameter value. -`MMF map projection: ` map projection parameter is always set to latlon for MMF parameters. +`MMF map projection:` map projection parameter is always set to latlon for MMF parameters. `MMF spatial transform:` spatial transform parameter is always set to average for MMF parameters. @@ -2437,6 +2437,7 @@ MMF spatial transform: average .... FDEPTH: Transmissivity e-folding depth [m] + WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. .... FDEPTH neighborhood radius: 1 @@ -2447,6 +2448,7 @@ FDEPTH water value: 100. .... RECHCLIM: Climatological recharge [mm] + WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. .... RECHCLIM neighborhood radius: 1 @@ -2457,6 +2459,7 @@ RECHCLIM water value: 0. .... RIVERBED Riverbed elevation [m] + WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. .... RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure @@ -2467,6 +2470,7 @@ RIVERBED water value: -100. .... EQWTD: Equilibrium water table depth [m] + WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. .... EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure @@ -2477,6 +2481,7 @@ EQWTD water value: 0. .... HGT_M: GMTED2010 30-arc-second topography height [m from MSL] + WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. .... HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure From 78937c85bf5515614e5d50a6462b229332cb1760 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 23:17:06 -0400 Subject: [PATCH 045/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index b04882ef0..d38ee69ab 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2437,8 +2437,7 @@ MMF spatial transform: average .... FDEPTH: Transmissivity e-folding depth [m] - -WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. +.WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. .... FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor @@ -2462,9 +2461,9 @@ RIVERBED Riverbed elevation [m] WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. .... -RIVERBED neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +RIVERBED neighborhood radius: 1 RIVERBED fill option: neighbor -RIVERBED fill radius: 1200 # Number of #pixels to search for neighbor +RIVERBED fill radius: 1200 RIVERBED fill value: 0. RIVERBED water value: -100. .... @@ -2473,9 +2472,9 @@ EQWTD: Equilibrium water table depth [m] WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. .... -EQWTD neighborhood radius: 1 # average neighborhood points for the first of WPS's two-step gap filling procedure +EQWTD neighborhood radius: 1 EQWTD fill option: neighbor -EQWTD fill radius: 1200 # Number of #pixels to search for neighbor +EQWTD fill radius: 1200 EQWTD fill value: 0. EQWTD water value: 0. .... @@ -2484,9 +2483,9 @@ HGT_M: GMTED2010 30-arc-second topography height [m from MSL] WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. .... -HGT_M neighborhood radius: 0 # average neighborhood points for the first of WPS's two-step gap filling procedure +HGT_M neighborhood radius: 0 HGT_M fill option: neighbor -HGT_M fill radius: 1200 # Number of #pixels to search for neighbor +HGT_M fill radius: 1200 HGT_M fill value: 0. HGT_M water value: -100. .... From f1fe1f546be1fd0061db6db8e5b15ebb37bbed15 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 23:18:06 -0400 Subject: [PATCH 046/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index d38ee69ab..ed11a9812 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2437,7 +2437,8 @@ MMF spatial transform: average .... FDEPTH: Transmissivity e-folding depth [m] -.WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. + +WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. .... FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor From 1890a7db1e4de867af771aaf9c6239876b4dceb7 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 19 Apr 2022 23:19:54 -0400 Subject: [PATCH 047/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index ed11a9812..d3814a049 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2422,7 +2422,7 @@ Below MMF is referred to FEDEPTH, RECHARGE, RIVERBED, EQWTD, or GMTED2010 parame `MMF neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. -`MMF fill option:` +`MMF fill option:` specifies the MMF parameter fill option. neighbor's value is preferred. `MMF fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. From d0909efab48c2bdb304ffd6e863b8d8a3b1377a9 Mon Sep 17 00:00:00 2001 From: Brendan McAndrew <19274445+bmcandr@users.noreply.github.com> Date: Mon, 9 May 2022 11:17:06 -0400 Subject: [PATCH 048/328] Fix LDT MMF documentation --- ldt/configs/ldt.config.adoc | 143 ++++++++++++++++++++++++------------ 1 file changed, 97 insertions(+), 46 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index d3814a049..8c4c9c15c 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -7,7 +7,7 @@ This section describes the options in the _ldt.config_ file. Not all options described here are available in the public version of LDT. [[ssec-driveropts]] -===Overall driver options +=== Overall driver options `LDT running mode:` specifies the running mode used in LDT. Acceptable values are: @@ -2375,71 +2375,85 @@ Bottom temperature resolution (dy): 0.2500 .... Noah-MP PBL Height Value: 900. # in meters .... + Miguez-Macho and Fan (MMF) Groundwater Parameters -NOTE Currently, Noah-MP.4.0.1 is the only model that supports the MMF groundwater scheme. +IMPORTANT: Currently, Noah-MP.4.0.1 is the only land surface model that supports the MMF groundwater scheme. + +`Process Noah-MP-4.0.1 MMF groundwater parameters:` specifies whether to process Noah-MP-4.0.1 MMF groundwater parameters. Acceptable values are: -`Process Noah-MP-4.0.1 MMF groundwater parameters:` is the switch to turn on processing MMF parameters. +[cols="<,<",] +|=== +|Value |Description + +|.false. | do not process (default) +|.true. | process +|=== .Example _ldt.config_ entry +.... +Process Noah-MP-4.0.1 MMF groundwater parameters: .true. +.... -`Process Noah-MP-4.0.1 MMF groundwater parameters: .true.` -If this config entry is not present, then it is assumed to be .false., and the Noah-MP-4.0.1 MMF groundwater parameters will not be processed. -Note that these parameters are only needed when running option "5" for the following lis.config entry when running LIS: +[NOTE] +==== +The Noah-MP-4.0.1 parameters are only needed when running option "5" for the following lis.config entry when running LIS: + +`Noah-MP.4.0.1 runoff and groundwater option: 5` + +// TODO: remove following admonition when MMF groundwater option 5 is implemented in LIS +IMPORTANT: The MMF groundwater option (option 5) is not yet supported in LIS. Work on this feature is currently in progress. +==== -Noah-MP.4.0.1 runoff and groundwater option: 5 +`MMF transmissivity dir:` specifies the location of the directory containing FDEPTH (transmissivity e-folding depth [m]) data on GEOGRID tiles. -Finally, note that this MMF groundwater option (option 5) is not yet supported in LIS, although the LIS team is nearing completion of its implementation. +`MMF climatological recharge dir:` specifies the location of the directory containing RECHARGE (climatological recharge [mm]) data on GEOGRID tiles. -Directories where 1km FEDEPTH, RECHARGE, RIVERBED, EQWTD, and GMTED2010 data on GEOGRID tiles are located. +`MMF riverbed elevation dir:` specifies the location of the directory containing RIVERBED (riverbed elevation [m]) data on GEOGRID tiles. + +`MMF equilibrium water table depth dir:` specifies the location of the directory containing EQWTD (equilibrium water table depth [m]) data on GEOGRID tiles. + +`MMF HGT_M dir:` specifies the location of the directory containing GMTED2010 (30-arc-second topography height [m from MSL]) data on GEOGRID tiles. .Example _ldt.config_ entry .... -MMF transmissivity dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/f/ -MMF climatological recharge dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/recharge/ -MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed/ +MMF transmissivity dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/f/ +MMF climatological recharge dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/recharge/ +MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed/ MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/wtd/ -MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ +MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ .... -Spatial interpolation and gap filling parameters for each MMF variable are also required. - -.... -https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL, and -WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp describe WPS's MMF parameter preprocessing procedures from the GEOGRID -grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native -GEOGRID space makes it fundamentally different to LDT because LDT first aggregates input data from the native grid to the -model grid and then fills gaps on the model grid space. Current LDT implementation of MMF parameter preprocessing does not -attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow -the WPS's interpolation concept. -.... +[NOTE] +==== +Spatial interpolation and gap filling parameters for each MMF variable are also required. See the config entries below. -Below MMF is referred to FEDEPTH, RECHARGE, RIVERBED, EQWTD, or GMTED2010 parameter value. +link:https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL[The WRF User's Guide, window=_blank] (and link:https://github.com/wrf-model/WPS/blob/master/geogrid/GEOGRID.TBL.ARW.noahmp[WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp, window=_blank]) describe WPS's MMF parameter preprocessing procedures from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native GEOGRID space makes it fundamentally different to LDT because LDT first aggregates input data from the native grid to the model grid and then fills gaps on the model grid space. The current LDT implementation of MMF parameter preprocessing does not attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. +==== `MMF map projection:` map projection parameter is always set to latlon for MMF parameters. `MMF spatial transform:` spatial transform parameter is always set to average for MMF parameters. -`MMF neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. - -`MMF fill option:` specifies the MMF parameter fill option. neighbor's value is preferred. - -`MMF fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. - -`MMF fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - -`MMF water value:` indicates the parameter value to be used on lakes or water grid cells. - .Example _ldt.config_ entry .... -MMF map projection: latlon +MMF map projection: latlon MMF spatial transform: average .... -FDEPTH: Transmissivity e-folding depth [m] +`FDEPTH neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. -WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. +`FDEPTH fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`FDEPTH fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`FDEPTH fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`FDEPTH water value:` indicates the parameter value to be used on lakes or water grid cells. + +.Example _ldt.config_ entry .... +# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor FDEPTH fill radius: 1200 @@ -2447,10 +2461,19 @@ FDEPTH fill value: 100. FDEPTH water value: 100. .... -RECHCLIM: Climatological recharge [mm] +`RECHCLIM neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. + +`RECHCLIM fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`RECHCLIM fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. -WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. +`RECHCLIM fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`RECHCLIM water value:` indicates the parameter value to be used on lakes or water grid cells. + +.Example _ldt.config_ entry .... +# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. RECHCLIM neighborhood radius: 1 RECHCLIM fill option: neighbor RECHCLIM fill radius: 1200 @@ -2458,10 +2481,20 @@ RECHCLIM fill value: -1. RECHCLIM water value: 0. .... -RIVERBED Riverbed elevation [m] -WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +`RIVERBED neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. + +`RIVERBED fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`RIVERBED fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`RIVERBED fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`RIVERBED water value:` indicates the parameter value to be used on lakes or water grid cells. + +.Example _ldt.config_ entry .... +# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. RIVERBED neighborhood radius: 1 RIVERBED fill option: neighbor RIVERBED fill radius: 1200 @@ -2469,10 +2502,19 @@ RIVERBED fill value: 0. RIVERBED water value: -100. .... -EQWTD: Equilibrium water table depth [m] +`EQWTD neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. + +`EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`EQWTD fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`EQWTD fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`EQWTD water value:` indicates the parameter value to be used on lakes or water grid cells. -WPS interp_option=default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. +.Example _ldt.config_ entry .... +# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. EQWTD neighborhood radius: 1 EQWTD fill option: neighbor EQWTD fill radius: 1200 @@ -2480,10 +2522,19 @@ EQWTD fill value: 0. EQWTD water value: 0. .... -HGT_M: GMTED2010 30-arc-second topography height [m from MSL] +`HGT_M neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. + +`HGT_M fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`HGT_M fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. -WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. +`HGT_M fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`HGT_M water value:` indicates the parameter value to be used on lakes or water grid cells. + +.Example _ldt.config_ entry .... +# WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. HGT_M neighborhood radius: 0 HGT_M fill option: neighbor HGT_M fill radius: 1200 From 1a3924a3d5e7af173ddf1a78c9fd68f7b9e8aa04 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Thu, 26 May 2022 14:29:27 -0400 Subject: [PATCH 049/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8c4c9c15c..7ac7dda93 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2456,7 +2456,7 @@ MMF spatial transform: average # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor -FDEPTH fill radius: 1200 +FDEPTH fill radius: 3 FDEPTH fill value: 100. FDEPTH water value: 100. .... @@ -2476,7 +2476,7 @@ FDEPTH water value: 100. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. RECHCLIM neighborhood radius: 1 RECHCLIM fill option: neighbor -RECHCLIM fill radius: 1200 +RECHCLIM fill radius: 3 RECHCLIM fill value: -1. RECHCLIM water value: 0. .... @@ -2497,7 +2497,7 @@ RECHCLIM water value: 0. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. RIVERBED neighborhood radius: 1 RIVERBED fill option: neighbor -RIVERBED fill radius: 1200 +RIVERBED fill radius: 3 RIVERBED fill value: 0. RIVERBED water value: -100. .... @@ -2517,7 +2517,7 @@ RIVERBED water value: -100. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. EQWTD neighborhood radius: 1 EQWTD fill option: neighbor -EQWTD fill radius: 1200 +EQWTD fill radius: 3 EQWTD fill value: 0. EQWTD water value: 0. .... @@ -2537,7 +2537,7 @@ EQWTD water value: 0. # WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. HGT_M neighborhood radius: 0 HGT_M fill option: neighbor -HGT_M fill radius: 1200 +HGT_M fill radius: 3 HGT_M fill value: 0. HGT_M water value: -100. .... From 4b910eddbaad9bf528a44997ab7888b824423429 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Thu, 26 May 2022 14:33:06 -0400 Subject: [PATCH 050/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 7ac7dda93..40cebbb1e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2456,7 +2456,7 @@ MMF spatial transform: average # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor -FDEPTH fill radius: 3 +FDEPTH fill radius: 3. FDEPTH fill value: 100. FDEPTH water value: 100. .... @@ -2476,7 +2476,7 @@ FDEPTH water value: 100. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. RECHCLIM neighborhood radius: 1 RECHCLIM fill option: neighbor -RECHCLIM fill radius: 3 +RECHCLIM fill radius: 3. RECHCLIM fill value: -1. RECHCLIM water value: 0. .... @@ -2497,7 +2497,7 @@ RECHCLIM water value: 0. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. RIVERBED neighborhood radius: 1 RIVERBED fill option: neighbor -RIVERBED fill radius: 3 +RIVERBED fill radius: 3. RIVERBED fill value: 0. RIVERBED water value: -100. .... @@ -2517,7 +2517,7 @@ RIVERBED water value: -100. # WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. EQWTD neighborhood radius: 1 EQWTD fill option: neighbor -EQWTD fill radius: 3 +EQWTD fill radius: 3. EQWTD fill value: 0. EQWTD water value: 0. .... @@ -2537,7 +2537,7 @@ EQWTD water value: 0. # WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. HGT_M neighborhood radius: 0 HGT_M fill option: neighbor -HGT_M fill radius: 3 +HGT_M fill radius: 3. HGT_M fill value: 0. HGT_M water value: -100. .... From 89e1b1b7b354dfff538f06ee902316474bcdf752 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 31 May 2022 10:49:26 -0400 Subject: [PATCH 051/328] Bugfix: initialize CDF and Xrange values to prevent NaN and undefined values --- ldt/core/LDT_DrangeMod.F90 | 4 ++ lis/core/LIS_dataAssimMod.F90 | 45 ++++++++++--------- .../cdfTransfer_NASASMAPsm_Mod.F90 | 2 + .../read_cdfTransfer_NASASMAPsm.F90 | 5 ++- 4 files changed, 33 insertions(+), 23 deletions(-) diff --git a/ldt/core/LDT_DrangeMod.F90 b/ldt/core/LDT_DrangeMod.F90 index d7d024e0a..fa85ae598 100644 --- a/ldt/core/LDT_DrangeMod.F90 +++ b/ldt/core/LDT_DrangeMod.F90 @@ -374,6 +374,7 @@ subroutine computeSingleDrange(n,obs, metrics) strat_minval = 1000000.0 strat_mask = 0 strat_delta = 0 + strat_xrange = 0 do t=1,LDT_rc%ngrid(n) do j=1,LDT_rc%cdf_ntimes @@ -445,6 +446,7 @@ subroutine computeSingleDrange(n,obs, metrics) deallocate(strat_minval) deallocate(strat_mask) deallocate(strat_delta) + deallocate(strat_xrange) elseif(LDT_rc%group_cdfs.eq.1 .and. LDT_rc%strat_cdfs.eq.1) then allocate(strat_drange_total(LDT_rc%group_cdfs_nbins*LDT_rc%strat_cdfs_nbins, & @@ -472,6 +474,7 @@ subroutine computeSingleDrange(n,obs, metrics) strat_minval = 1000000.0 strat_mask = 0 strat_delta = 0 + strat_xrange = 0 do t=1,LDT_rc%ngrid(n) do j=1,LDT_rc%cdf_ntimes @@ -547,6 +550,7 @@ subroutine computeSingleDrange(n,obs, metrics) deallocate(strat_minval) deallocate(strat_mask) deallocate(strat_delta) + deallocate(strat_xrange) endif endif diff --git a/lis/core/LIS_dataAssimMod.F90 b/lis/core/LIS_dataAssimMod.F90 index 99f0464b4..d6dd31d84 100644 --- a/lis/core/LIS_dataAssimMod.F90 +++ b/lis/core/LIS_dataAssimMod.F90 @@ -1132,25 +1132,29 @@ subroutine LIS_rescale_with_stratified_CDF(& if(binval.le.0) binval = 1 cdf_obsval = obs_cdf(strat_binval,kk,binval) if(cdf_obsval.gt.1.0) cdf_obsval = 1.0 - i=1 - do while((model_cdf(strat_binval,kk,i).lt.cdf_obsval).and.& - (i.le.nbins)) - i = i+1 - if(i.gt.nbins) exit - enddo - if(i.gt.nbins) i = i-1 - obs_tmp = model_xrange(strat_binval,kk,i) - - if(obs_tmp.gt.max_obs_value) then -! obs_tmp = max_obs_value - obs_tmp = LIS_rc%udef - endif - - if(obs_tmp.le.min_obs_value) then -! obs_tmp = obs_value(col,row) - obs_tmp = LIS_rc%udef - endif - obs_value(col,row) = obs_tmp + if(cdf_obsval .gt.0)then + i=1 + do while((model_cdf(strat_binval,kk,i).lt.cdf_obsval).and.& + (i.le.nbins)) + i = i+1 + if(i.gt.nbins) exit + enddo + if(i.gt.nbins) i = i-1 + obs_tmp = model_xrange(strat_binval,kk,i) + + if(obs_tmp.gt.max_obs_value) then +! obs_tmp = max_obs_value + obs_tmp = LIS_rc%udef + endif + + if(obs_tmp.le.min_obs_value) then +! obs_tmp = obs_value(col,row) + obs_tmp = LIS_rc%udef + endif + obs_value(col,row) = obs_tmp + else + obs_value(col,row) = LIS_rc%udef + endif else obs_value(col,row) = LIS_rc%udef endif @@ -1282,9 +1286,6 @@ end subroutine LIS_getCDFtransferattributes !BOP ! !ROUTINE: read_CDFdata_all ! \label{read_CDFdata_all} - -! !REVISION HISTORY: -! 2 March 2022: Mahdi Navari ; Initial Specification ! ! !INTERFACE: subroutine read_CDFdata_all(n, k, nbins, ntimes, ngrid, & diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 index 95986eb40..5cf542a40 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 @@ -497,6 +497,8 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) allocate(cdfT_SMAPsm_struc(n)%obs_cdf(& cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & cdfT_SMAPsm_struc(n)%nbins)) + write(LIS_logunit,*)& + '[INFO] Successfully read cdf transfer data specifications' endif if(cdfT_SMAPsm_struc(n)%useSsdevScal.eq.1) then diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 index 6a30396da..264933025 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 @@ -481,6 +481,8 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) ! CDF-scaling approach !------------------------------------------------------------------------- if (cdfT_SMAPsm_struc(n)%useCDFtransfer .gt. 0) then + if (LIS_rc%da .eq. 1 .and. LIS_rc%hr .eq. 0 .and. & + LIS_rc%mn .eq. 0 .and. LIS_rc%ss .eq. 0) then call read_CDFtransferdata_all(n,k,& cdfT_SMAPsm_struc(n)%nbins,& cdfT_SMAPsm_struc(n)%ntimes,& @@ -499,6 +501,7 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) cdfT_SMAPsm_struc(n)%obs_xrange,& cdfT_SMAPsm_struc(n)%obs_cdf) + endif if (fnd .ne. 0) then call LIS_rescale_with_stratified_CDF(& @@ -516,7 +519,7 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) cdfT_SMAPsm_struc(n)%target_p_climo,& cdfT_SMAPsm_struc(n)%n_strat_bins,& sm_current) - endif + endif endif obsl = LIS_rc%udef From baff286e969e3d295b5c7ec416c073a59e5cc724 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Thu, 23 Jun 2022 12:15:15 -0400 Subject: [PATCH 052/328] The gap filling process of MMF parameters was revisted. --- ldt/core/LDT_paramMaskCheckMod.F90 | 18 ++++++---- ldt/params/Noah/Noah_parmsMod.F90 | 38 +++++++++------------- ldt/params/Noah/module_MMF_groundwater.F90 | 36 ++++++++------------ 3 files changed, 39 insertions(+), 53 deletions(-) diff --git a/ldt/core/LDT_paramMaskCheckMod.F90 b/ldt/core/LDT_paramMaskCheckMod.F90 index 507a7063f..986a30409 100644 --- a/ldt/core/LDT_paramMaskCheckMod.F90 +++ b/ldt/core/LDT_paramMaskCheckMod.F90 @@ -332,7 +332,7 @@ end subroutine LDT_discreteParam_Fill ! ! !INTERFACE: subroutine LDT_contIndivParam_Fill( n, pnc, pnr, gridtransform, pnl, & - param_value, undef, mask_value, fill_option, fill_value, fill_rad ) + param_value, undef, mask_value, fill_option, fill_value, fill_rad, leave_good_data) ! !USES: use ESMF @@ -359,6 +359,7 @@ subroutine LDT_contIndivParam_Fill( n, pnc, pnr, gridtransform, pnl, & real, intent(in) :: fill_value real, intent(in) :: fill_rad character(50), intent(in) :: fill_option + logical, intent(in), optional :: leave_good_data !- Local parameters: integer :: i, j, l @@ -464,12 +465,15 @@ subroutine LDT_contIndivParam_Fill( n, pnc, pnr, gridtransform, pnl, & end if end if - !== Mask: indicates water point; Parameter: indicates valid value - if( mask_value(i, j, 1) == 0 .and. & - param_value(i, j, l) /= undef ) then - param_value(i, j, l) = undef - end if ! End mask-param value check - + ! MMF scheme is active on lake/water grid cells. Thus, when MMF parameters are being processed, + ! "leave_good_data" optional argument is used to leave acceptable parameter values in lake/water grid cells intact. + if(.not.present(leave_good_data)) then + !== Mask: indicates water point; Parameter: indicates valid value + if( mask_value(i, j, 1) == 0 .and. & + param_value(i, j, l) /= undef ) then + param_value(i, j, l) = undef + end if ! End mask-param value check + endif end do ! End nc-loop end do ! End nr-loop diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 17a88cc1d..b2bf156db 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -519,61 +519,49 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, MMF_proj, label='MMF map projection:', rc=rc) call LDT_verify(rc,"MMF map projection not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%neighbor%fillradius,label='FDEPTH neighborhood radius:', rc=rc) - call LDT_verify(rc,"FDEPTH neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%filltype, label='FDEPTH fill option:', rc=rc) call LDT_verify(rc,"FDEPTH fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillradius,label='FDEPTH fill radius:', rc=rc) call LDT_verify(rc,"FDEPTH fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%fillvalue, label='FDEPTH fill value:' , rc=rc) call LDT_verify(rc,"FDEPTH fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%gap_fill%watervalue,label='FDEPTH water value:', DEFAULT= 100., rc=rc) - call LDT_verify(rc,"FDEPTH water value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_FDEPTH%water_value, label='FDEPTH water value:', DEFAULT= 100., rc=rc) + call LDT_verify(rc,"Suitable FDEPTH parameter value in lakes/waterbodies not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%neighbor%fillradius,label='RECHCLIM neighborhood radius:', rc=rc) - call LDT_verify(rc,"RECHCLIM neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%filltype, label='RECHCLIM fill option:',rc=rc) call LDT_verify(rc,"RECHCLIM fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillradius,label='RECHCLIM fill radius:',rc=rc) call LDT_verify(rc,"RECHCLIM fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%fillvalue, label='RECHCLIM fill value:' ,rc=rc) call LDT_verify(rc,"RECHCLIM fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%gap_fill%watervalue,label='RECHCLIM water value:',DEFAULT=0., rc=rc) - call LDT_verify(rc,"RECHCLIM water value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%water_value, label='RECHCLIM water value:', DEFAULT= 0., rc=rc) + call LDT_verify(rc,"Suitable RECHCLIM parameter value in lakes/waterbodies not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%neighbor%fillradius,label='RIVERBED neighborhood radius:', rc=rc) - call LDT_verify(rc,"RIVERBED neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc) call LDT_verify(rc,"RIVERBED fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc) call LDT_verify(rc,"RIVERBED fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc) call LDT_verify(rc,"RIVERBED fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%watervalue,label='RIVERBED water value:',DEFAULT=-100., rc=rc) - call LDT_verify(rc,"RIVERBED water value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%water_value, label='RIVERBED water value:', DEFAULT= -100., rc=rc) + call LDT_verify(rc,"Suitable RIVERBED parameter value in lakes/waterbodies not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%neighbor%fillradius,label='EQWTD neighborhood radius:', rc=rc) - call LDT_verify(rc,"EQWTD neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%filltype, label='EQWTD fill option:',rc=rc) call LDT_verify(rc,"EQWTD fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillradius,label='EQWTD fill radius:',rc=rc) call LDT_verify(rc,"EQWTD fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%fillvalue, label='EQWTD fill value:' ,rc=rc) call LDT_verify(rc,"EQWTD fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%gap_fill%watervalue,label='EQWTD water value:',DEFAULT = 0., rc=rc) - call LDT_verify(rc,"EQWTD fill value not defined." ) + call ESMF_ConfigGetAttribute(LDT_config, MBR_WTD%water_value, label='EQWTD water value:', DEFAULT= 0., rc=rc) + call LDT_verify(rc,"Suitable EQWTD parameter value in lakes/waterbodies not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%neighbor%fillradius,label='HGT_M neighborhood radius:', rc=rc) - call LDT_verify(rc,"HGT_M neighborhood radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%filltype, label='HGT_M fill option:',rc=rc) call LDT_verify(rc,"HGT_M fill option not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillradius,label='HGT_M fill radius:',rc=rc) call LDT_verify(rc,"HGT_M fill radius not defined.") call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%fillvalue, label='HGT_M fill value:' ,rc=rc) call LDT_verify(rc,"HGT_M fill value not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_HGT%gap_fill%watervalue,label='HGT_M water value:',DEFAULT=-100.,rc=rc) - call LDT_verify(rc,"HGT_M fill value not defined." ) - + do n = 1,LDT_rc%nnest allocate (Noah_struc(n)%fdepth%value (LDT_rc%lnc(n),LDT_rc%lnr(n),Noah_struc(n)%fdepth%num_bins )) @@ -601,9 +589,13 @@ subroutine NoahParms_init (flag) call MBR_RIVERBED%mr (n, trim(Noah_struc(n)%mmf_riverbed_dir), Noah_struc(n)%riverbed%value, Noah_struc(n)%mmf_transform, Noah_struc(n)%riverbed%short_name) call MBR_WTD%mr (n, trim(Noah_struc(n)%mmf_eqwtd_dir ), Noah_struc(n)%eqwtd%value , Noah_struc(n)%mmf_transform, Noah_struc(n)%eqwtd%short_name ) call MBR_HGT%mr (n, trim(Noah_struc(n)%mmf_hgtm_dir ), Noah_struc(n)%hgtm%value , Noah_struc(n)%mmf_transform, Noah_struc(n)%hgtm%short_name ) + + ! Ensure RIVERBED value in LAKES and WATER grid cells is same as MMF_HGTM + where (Noah_struc(n)%riverbed%value == MBR_RIVERBED%water_value) + Noah_struc(n)%riverbed%value = Noah_struc(n)%hgtm%value + endwhere - ! write areaXY - + ! write areaXY call cell_area (n,Noah_struc(n)%areaxy%value) end do diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 3cee6c156..4e922405d 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -65,8 +65,8 @@ module MMF_groundwater type, public, extends (MMF_mapping) :: MMF_BCsReader type(LDT_fillopts), public :: gap_fill - type(LDT_fillopts), public :: neighbor type(geogrid), public :: gp + real, public :: water_value contains @@ -127,10 +127,6 @@ SUBROUTINE mmf_init (MBR, nest, project, DATADIR, map) else MBR%gp%DE = .false. endif - - ! For WPS's two-step gap filling, first we attempt fill using averaged value from the immedeate neighborhood. - MBR%neighbor%filltype = 'average' - MBR%neighbor%fillvalue = LDT_rc%udef ! Verify NX_MMF, MY_MMF match with dx, dy if ((NINT (360./dx) /= NX_MMF) .OR. (NINT (180./dy) /= NY_MMF)) then @@ -277,35 +273,29 @@ SUBROUTINE mmf_data_reader (MBR, nest, datadir, lisout, mmf_transform, short_nam call regrid_to_lisgrid (nest, garray, lisout) - ! fill gaps - nbins = size (lisout, 3) - - !Average from the nerighborhood - ! ----------------------------- - call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & - mmf_transform, & - nbins, & - lisout, LDT_rc%udef, & - LDT_LSMparam_struc(nest)%landmask2%value, & - MBR%neighbor%filltype, MBR%neighbor%fillvalue, & - MBR%neighbor%fillradius ) - - ! Search and fill -also fill lakes - ! -------------------------------- + ! Search and fill gaps + ! -------------------- write(LDT_logunit,*) "Checking/filling mask values for: ", & trim(short_name) write(fill_logunit,*) "Checking/filling mask values for: ", & trim(short_name) + call LDT_contIndivParam_Fill( nest, LDT_rc%lnc(nest), LDT_rc%lnr(nest), & mmf_transform, & nbins, & - lisout, MBR%gap_fill%watervalue, & + lisout, LDT_rc%udef, & LDT_LSMparam_struc(nest)%landmask2%value, & MBR%gap_fill%filltype, MBR%gap_fill%fillvalue, & - MBR%gap_fill%fillradius ) - + MBR%gap_fill%fillradius, leave_good_data = .true. ) + + if (trim (short_name) /= "MMF_HGTM") then + ! fill suitable parameter values in lakes/water bodies + where (lisout == LDT_rc%udef) + lisout = MBR%water_value + end where + endif deallocate (tarray, garray) contains From 5113fdaf04998b92eb004fd79a4774d73734f9a1 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Thu, 23 Jun 2022 14:33:07 -0400 Subject: [PATCH 053/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 48 +++++++++++-------------------------- 1 file changed, 14 insertions(+), 34 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 40cebbb1e..0ee912522 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2441,88 +2441,72 @@ MMF map projection: latlon MMF spatial transform: average .... -`FDEPTH neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. - `FDEPTH fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). -`FDEPTH fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. +`FDEPTH fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). `FDEPTH fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. -`FDEPTH water value:` indicates the parameter value to be used on lakes or water grid cells. +`FDEPTH water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable FDEPTH value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. .Example _ldt.config_ entry .... -# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = 100. -FDEPTH neighborhood radius: 1 FDEPTH fill option: neighbor -FDEPTH fill radius: 3. +FDEPTH fill radius: 0. FDEPTH fill value: 100. FDEPTH water value: 100. .... -`RECHCLIM neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. `RECHCLIM fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). -`RECHCLIM fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. +`RECHCLIM fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). `RECHCLIM fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. -`RECHCLIM water value:` indicates the parameter value to be used on lakes or water grid cells. +`RECHCLIM water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable RECHCLIM value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. .Example _ldt.config_ entry .... -# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing = -1. -RECHCLIM neighborhood radius: 1 RECHCLIM fill option: neighbor -RECHCLIM fill radius: 3. -RECHCLIM fill value: -1. +RECHCLIM fill radius: 0. +RECHCLIM fill value: 0. RECHCLIM water value: 0. .... -`RIVERBED neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. - `RIVERBED fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). `RIVERBED fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. `RIVERBED fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. -`RIVERBED water value:` indicates the parameter value to be used on lakes or water grid cells. +`RIVERBED water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable RIVERBED value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. Note that this will be overwritten by MMF_HGTM values at the location if an acceptable MMF_GHTM available at the location. .Example _ldt.config_ entry .... -# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. -RIVERBED neighborhood radius: 1 RIVERBED fill option: neighbor -RIVERBED fill radius: 3. -RIVERBED fill value: 0. +RIVERBED fill radius: 0. +RIVERBED fill value: -100. RIVERBED water value: -100. .... -`EQWTD neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. - `EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). `EQWTD fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. `EQWTD fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. -`EQWTD water value:` indicates the parameter value to be used on lakes or water grid cells. +`EQWTD water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable EQWTD value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. .Example _ldt.config_ entry .... -# WPS interp_option = default:average_gcell(1.0)+average_4pt+search ; fill_missing=0. -EQWTD neighborhood radius: 1 EQWTD fill option: neighbor -EQWTD fill radius: 3. +EQWTD fill radius: 0. EQWTD fill value: 0. EQWTD water value: 0. .... -`HGT_M neighborhood radius:` First LDT attempts to fill any gaps using the average of the valid values from 8 neighboring model grid cells. `HGT_M fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). @@ -2530,16 +2514,12 @@ EQWTD water value: 0. `HGT_M fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. -`HGT_M water value:` indicates the parameter value to be used on lakes or water grid cells. .Example _ldt.config_ entry .... -# WPS interp_option = gmted2010_30s:average_gcell(4.0)+four_pt+average_4pt ; fill_missing=0. -HGT_M neighborhood radius: 0 HGT_M fill option: neighbor -HGT_M fill radius: 3. -HGT_M fill value: 0. -HGT_M water value: -100. +HGT_M fill radius: 0. +HGT_M fill value: 10. .... If selecting the Community Land Model (4.5 version), the following config entires are also required. From 0af5c546b1191910e0369bc9564c29ecc3d0ee85 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Fri, 24 Jun 2022 07:21:10 -0400 Subject: [PATCH 054/328] Update ldt.config.adoc --- ldt/configs/ldt.config.adoc | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 0ee912522..949b82410 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2470,8 +2470,8 @@ FDEPTH water value: 100. .... RECHCLIM fill option: neighbor RECHCLIM fill radius: 0. -RECHCLIM fill value: 0. -RECHCLIM water value: 0. +RECHCLIM fill value: -1. +RECHCLIM water value: -1. .... @@ -2487,8 +2487,8 @@ RECHCLIM water value: 0. .... RIVERBED fill option: neighbor RIVERBED fill radius: 0. -RIVERBED fill value: -100. -RIVERBED water value: -100. +RIVERBED fill value: 0. +RIVERBED water value: 0. .... `EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). @@ -2519,7 +2519,7 @@ EQWTD water value: 0. .... HGT_M fill option: neighbor HGT_M fill radius: 0. -HGT_M fill value: 10. +HGT_M fill value: 0. .... If selecting the Community Land Model (4.5 version), the following config entires are also required. From c87ff80b32f2389ecc1c0613c1eec9697130649d Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 21 Jul 2022 13:36:38 -0400 Subject: [PATCH 055/328] Corrected LISF version and copyright block. --- ldt/params/Noah/module_MMF_groundwater.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 4e922405d..6e1291483 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.4 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2022 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- From f97680c484c47ab956c483ad7a8db5adc362ede7 Mon Sep 17 00:00:00 2001 From: "Sujay V. Kumar" Date: Thu, 4 Aug 2022 18:33:34 -0400 Subject: [PATCH 056/328] Changes the lat/lon fields in LIS output from 2d to 1d With this change, the lat/lon fields will be dimensioned as: float lat(north_south); float lon(east_west); Resolves #1178 --- lis/core/LIS_historyMod.F90 | 223 ++++++++++++++++++++++++++---------- 1 file changed, 163 insertions(+), 60 deletions(-) diff --git a/lis/core/LIS_historyMod.F90 b/lis/core/LIS_historyMod.F90 index 11b753f85..c3de1f724 100644 --- a/lis/core/LIS_historyMod.F90 +++ b/lis/core/LIS_historyMod.F90 @@ -2079,15 +2079,15 @@ subroutine writeNetcdfOutput(n, group, ftn, ftn_stats, outInterval, & endif ! LIS output is always writing output for a single time - call LIS_verify(nf90_def_dim(ftn,'time',1,tdimID),& + call LIS_verify(nf90_def_dim(ftn,'time',NF90_UNLIMITED,tdimID),& 'nf90_def_dim for time failed in LIS_historyMod') call LIS_verify(nf90_put_att(ftn,NF90_GLOBAL,"missing_value", LIS_rc%udef),& 'nf90_put_att for missing_value failed in LIS_historyMod') call defineNETCDFheaderVar(n,ftn,dimID, xlat,& - non_model_fields = .true. ) + non_model_fields = 1 ) call defineNETCDFheaderVar(n,ftn,dimID, xlong, & - non_model_fields = .true. ) + non_model_fields = 2 ) ! defining time field call LIS_verify(nf90_def_var(ftn,'time',& @@ -2259,8 +2259,8 @@ subroutine writeNetcdfOutput(n, group, ftn, ftn_stats, outInterval, & xlat%modelOutput(1,t,1) = LIS_domain(n)%grid(index1)%lat xlong%modelOutput(1,t,1) = LIS_domain(n)%grid(index1)%lon enddo - call writeSingleNETCDFvar(ftn,ftn_stats,n,xlat,non_model_fields = .true.) - call writeSingleNETCDFvar(ftn,ftn_stats,n,xlong, non_model_fields = .true.) + call writeSingleNETCDFvar(ftn,ftn_stats,n,xlat,non_model_fields =1) + call writeSingleNETCDFvar(ftn,ftn_stats,n,xlong, non_model_fields = 2) if(LIS_masterproc) then call LIS_verify(nf90_put_var(ftn,xtimeID,0.0),& @@ -2443,15 +2443,15 @@ subroutine writeRoutingNetcdfOutput(n, group, ftn, ftn_stats, outInterval, & endif ! LIS output is always writing output for a single time - call LIS_verify(nf90_def_dim(ftn,'time',1,tdimID),& + call LIS_verify(nf90_def_dim(ftn,'time',NF90_UNLIMITED,tdimID),& 'nf90_def_dim for time failed in LIS_historyMod') call LIS_verify(nf90_put_att(ftn,NF90_GLOBAL,"missing_value", LIS_rc%udef),& 'nf90_put_att for missing_value failed in LIS_historyMod') call defineNETCDFheaderVar(n,ftn,dimID, xlat,& - non_model_fields = .true. ) + non_model_fields = 1 ) call defineNETCDFheaderVar(n,ftn,dimID, xlong, & - non_model_fields = .true. ) + non_model_fields = 2 ) ! defining time field call LIS_verify(nf90_def_var(ftn,'time',& @@ -2621,9 +2621,9 @@ subroutine writeRoutingNetcdfOutput(n, group, ftn, ftn_stats, outInterval, & enddo call writeSingleRoutingNETCDFvar(ftn,ftn_stats,n,xlat,& - non_model_fields = .true.) + non_model_fields = 1) call writeSingleRoutingNETCDFvar(ftn,ftn_stats,n,xlong, & - non_model_fields = .true.) + non_model_fields = 2) if(LIS_masterproc) then call LIS_verify(nf90_put_var(ftn,xtimeID,0.0),& @@ -2673,7 +2673,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) integer :: n integer :: ftn type(LIS_metadataEntry), pointer :: dataEntry - logical, optional :: non_model_fields + integer, optional :: non_model_fields integer :: dimID(4) ! ! !DESCRIPTION: @@ -2700,7 +2700,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) ! call to check if the return value is valid or not. ! \end{description} !EOP - logical :: nmodel_status + integer :: nmodel_status integer :: data_index integer :: shuffle, deflate, deflate_level character*100 :: short_name @@ -2713,7 +2713,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) #if(defined USE_NETCDF3 || defined USE_NETCDF4) - nmodel_status = .false. + nmodel_status = 0 if(present(non_model_fields)) then nmodel_status = non_model_fields endif @@ -2912,7 +2912,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) endif else - if(.not.nmodel_status) then + if(nmodel_status==0) then if(dataEntry%timeAvgOpt.eq.0) then short_name = trim(dataEntry%short_name)//'_inst' elseif(dataEntry%timeAvgOpt.eq.1) then @@ -3202,7 +3202,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) endif else - if(.not.nmodel_status) then + if(nmodel_status==0) then if(dataEntry%timeAvgOpt.eq.0) then short_name = trim(dataEntry%short_name)//'_inst' elseif(dataEntry%timeAvgOpt.eq.1) then @@ -3270,11 +3270,25 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) #endif endif else ! 1 vertical level - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(1:2), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1:2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + endif #if(defined USE_NETCDF4) call LIS_verify(nf90_def_var_fill(ftn,& dataEntry%varId_def, & @@ -3411,11 +3425,25 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) !EMK END else ! 1 vertical level - call LIS_verify(nf90_def_var(ftn,trim(dataEntry%short_name)//'_tavg',& - nf90_float,& - dimids = dimID(1:3), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(dataEntry%short_name)//& - 'failed in defineNETCDFheadervar') + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(dataEntry%short_name)//'_tavg',& + nf90_float,& + dimids = dimID(1:3), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(dataEntry%short_name)//& + 'failed in defineNETCDFheadervar') + endif #if(defined USE_NETCDF4) call LIS_verify(nf90_def_var_fill(ftn,& @@ -3489,7 +3517,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) endif else - if(.not.nmodel_status) then + if(nmodel_status==0) then if(dataEntry%timeAvgOpt.eq.0) then short_name = trim(dataEntry%short_name)//'_inst' elseif(dataEntry%timeAvgOpt.eq.1) then @@ -3557,18 +3585,32 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) #endif endif else - if(.not.nmodel_status) then + if(nmodel_status==0) then call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& dimids = dimID(1:3), varID=dataEntry%varId_def),& 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') else - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(1:2), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1:2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + endif endif #if(defined USE_NETCDF4) call LIS_verify(nf90_def_var_fill(ftn,& @@ -3764,7 +3806,7 @@ subroutine writeSingleNETCDFvar(ftn,ftn_stats,n,dataEntry,& integer, intent(in) :: ftn integer, intent(in) :: ftn_stats type(LIS_metadataEntry), pointer :: dataEntry - logical, optional :: non_model_fields + integer, optional :: non_model_fields ! ! !DESCRIPTION: ! This routine writes a single variable to a NETCDF file @@ -3785,19 +3827,19 @@ subroutine writeSingleNETCDFvar(ftn,ftn_stats,n,dataEntry,& ! \end{description} !EOP integer :: i,k,m,t - logical :: nmodel_status + integer :: nmodel_status - nmodel_status = .false. + nmodel_status = 0 if(present(non_model_fields)) then nmodel_status = non_model_fields endif if(dataEntry%selectOpt.eq.1) then - if(.not.nmodel_status) then + if(nmodel_status==0) then do t=1,LIS_rc%ntiles(n) - if(nmodel_status) then + if(nmodel_status==0) then m = 1 else m = LIS_domain(n)%tile(t)%sftype @@ -3884,7 +3926,7 @@ subroutine writeSingleRoutingNETCDFvar(ftn,ftn_stats,n,dataEntry,& integer, intent(in) :: ftn integer, intent(in) :: ftn_stats type(LIS_metadataEntry), pointer :: dataEntry - logical, optional :: non_model_fields + integer, optional :: non_model_fields ! ! !DESCRIPTION: ! This routine writes a single variable to a NETCDF file @@ -3905,16 +3947,16 @@ subroutine writeSingleRoutingNETCDFvar(ftn,ftn_stats,n,dataEntry,& ! \end{description} !EOP integer :: i,k,t - logical :: nmodel_status + integer :: nmodel_status - nmodel_status = .false. + nmodel_status = 0 if(present(non_model_fields)) then nmodel_status = non_model_fields endif if(dataEntry%selectOpt.eq.1) then - if(.not.nmodel_status) then + if(nmodel_status==0) then do t=1,LIS_rc%nroutinggrid(n)*LIS_rc%nensem(n) do k=1,dataEntry%vlevels @@ -4552,7 +4594,7 @@ subroutine LIS_closeHeader_restart(ftn,n,m,dimID, rstInterval) "vmax",0.0),& 'nf90_put_att failed for xlong:vmax') !defining time field - call LIS_verify(nf90_def_dim(ftn,'time',1,tdimID),& + call LIS_verify(nf90_def_dim(ftn,'time',NF90_UNLIMITED,tdimID),& 'nf90_def_dim failed for time') call LIS_verify(nf90_def_var(ftn,'time',& @@ -6522,7 +6564,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& real, intent(in) :: var(LIS_rc%ntiles(n)) character (len=*) :: mvar integer, intent(in) :: form - logical, intent(in) :: nmodel_status + integer, intent(in) :: nmodel_status integer, intent(in), optional :: dim1 ! ! !DESCRIPTION: @@ -6562,6 +6604,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& real, allocatable :: var1(:) real, allocatable :: var1_ens(:,:) real, allocatable :: gtmp(:,:) + real, allocatable :: gtmplat(:),gtmplon(:) real, allocatable :: gtmp_ens(:,:,:) real, allocatable :: gtmp1(:) real, allocatable :: gtmp1_ens(:,:) @@ -6601,7 +6644,8 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& endif ! Write output in 2d grid space: - elseif(LIS_rc%wopt.eq."2d gridspace") then + elseif(LIS_rc%wopt.eq."2d gridspace") then + allocate(var1(LIS_rc%ngrid(n))) if(LIS_masterproc) then allocate(gtmp(LIS_rc%gnc(n),LIS_rc%gnr(n))) @@ -6656,13 +6700,42 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo enddo - if(PRESENT(dim1)) then - iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) - else - iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) - endif + if(nmodel_status.eq.1) then ! lat + allocate(gtmplat(LIS_rc%gnr(n))) + gtmplat = LIS_rc%udef + + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gtmplat(r) = gtmp(c,r) + enddo + enddo + + iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& + (/LIS_rc%gnr(n)/)) + deallocate(gtmplat) + + elseif(nmodel_status.eq.2) then !lon + allocate(gtmplon(LIS_rc%gnc(n))) + gtmplon = LIS_rc%udef + + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gtmplon(c) = gtmp(c,r) + enddo + enddo + + iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& + (/LIS_rc%gnc(n)/)) + deallocate(gtmplon) + else + if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) + else + iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + endif + endif if(ftn_stats.ne.-1) then if ( LIS_rc%sout ) then call stats(gtmp,LIS_rc%udef,LIS_rc%gnc(n)*LIS_rc%gnr(n),& @@ -6683,7 +6756,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& elseif(LIS_rc%wopt.eq."2d ensemble gridspace") then ! Non-model output field status (T=non-model; F=model-based): - if(nmodel_status) then ! non-model output field status + if(nmodel_status.ne.0) then ! non-model output field status allocate(var1(LIS_rc%ngrid(n))) if(LIS_masterproc) then allocate(gtmp(LIS_rc%gnc(n),LIS_rc%gnr(n))) @@ -6738,12 +6811,42 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo enddo - if(PRESENT(dim1)) then - iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) - else - iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + + if(nmodel_status.eq.1) then ! lat + allocate(gtmplat(LIS_rc%gnr(n))) + gtmplat = LIS_rc%udef + + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gtmplat(r) = gtmp(c,r) + enddo + enddo + + iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& + (/LIS_rc%gnr(n)/)) + deallocate(gtmplat) + + elseif(nmodel_status.eq.2) then !lon + allocate(gtmplon(LIS_rc%gnc(n))) + gtmplon = LIS_rc%udef + + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gtmplon(c) = gtmp(c,r) + enddo + enddo + + iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& + (/LIS_rc%gnc(n)/)) + deallocate(gtmplon) + else + if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) + else + iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + endif endif if(ftn_stats.ne.-1) then if ( LIS_rc%sout ) then @@ -6887,7 +6990,7 @@ subroutine writeroutingvar_netcdf_real(ftn,ftn_stats, n, var,varid, mvar,& real, intent(in) :: var(LIS_rc%nroutinggrid(n)*LIS_rc%nensem(n)) character (len=*) :: mvar integer, intent(in) :: form - logical, intent(in) :: nmodel_status + integer, intent(in) :: nmodel_status integer, intent(in), optional :: dim1 ! ! !DESCRIPTION: @@ -7017,7 +7120,7 @@ subroutine writeroutingvar_netcdf_real(ftn,ftn_stats, n, var,varid, mvar,& elseif(LIS_rc%wopt.eq."2d ensemble gridspace") then ! Non-model output field status (T=non-model; F=model-based): - if(nmodel_status) then ! non-model output field status + if(nmodel_status.ne.0) then ! non-model output field status allocate(var1(LIS_rc%nroutinggrid(n))) if(LIS_masterproc) then allocate(gtmp(LIS_rc%gnc(n),LIS_rc%gnr(n))) From 1673f1b9a9c6126e00fa05222b5cc2c67197612e Mon Sep 17 00:00:00 2001 From: Shahryar Khalique Ahmad Date: Tue, 16 Aug 2022 07:46:14 -0400 Subject: [PATCH 057/328] Add dynamic LC support --- ldt/core/LDT_LMLCMod.F90 | 4 +- ldt/core/LDT_paramProcMod.F90 | 2 +- ldt/core/LDT_paramTileInputMod.F90 | 4 +- ldt/params/landcover/read_MCD12Q1_lc.F90 | 310 ++++++++++++++++++++++ ldt/params/mask/read_maskfile.F90 | 5 + ldt/params/mask/read_maskfile_MCD12Q1.F90 | 56 ++++ ldt/plugins/LDT_param_pluginMod.F90 | 20 +- ldt/plugins/LDT_pluginIndices.F90 | 6 +- 8 files changed, 383 insertions(+), 24 deletions(-) create mode 100755 ldt/params/landcover/read_MCD12Q1_lc.F90 create mode 100644 ldt/params/mask/read_maskfile_MCD12Q1.F90 diff --git a/ldt/core/LDT_LMLCMod.F90 b/ldt/core/LDT_LMLCMod.F90 index 23c97950d..47fa0cbc6 100644 --- a/ldt/core/LDT_LMLCMod.F90 +++ b/ldt/core/LDT_LMLCMod.F90 @@ -203,7 +203,9 @@ subroutine LMLC_init_LIS() ! Don't need to read in "Native" grid extents/resolution, just for LIS inputs: do n=1,LDT_rc%nnest if( index(LDT_LSMparam_struc(n)%landcover%source,"Native").eq.0 .and. & - index(LDT_LSMparam_struc(n)%landcover%source,"CONSTANT").eq.0 ) then + index(LDT_LSMparam_struc(n)%landcover%source,"CONSTANT").eq.0 .and.& + index(LDT_LSMparam_struc(n)%landcover%source,"MCD12Q1").eq.0) then + call LDT_readDomainConfigSpecs("Landcover", LDT_rc%lc_proj, LDT_rc%lc_gridDesc) if( LDT_rc%lc_proj == "latlon" ) then call LDT_gridOptChecks( n, "Landcover", & diff --git a/ldt/core/LDT_paramProcMod.F90 b/ldt/core/LDT_paramProcMod.F90 index 61af05562..7eedcc948 100644 --- a/ldt/core/LDT_paramProcMod.F90 +++ b/ldt/core/LDT_paramProcMod.F90 @@ -2475,7 +2475,7 @@ subroutine setLandcoverCategories(n,source) LDT_LSMparam_struc(n)%landcover%standard_name = & "AVHRR UMD landcover map" - case( "MODIS_Native", "MODIS_LIS" ) + case( "MODIS_Native", "MODIS_LIS", "MCD12Q1" ) LDT_rc%lc_type(n) = "IGBPNCEP" LDT_LSMparam_struc(n)%landcover%num_bins = 20 LDT_LSMparam_struc(n)%landcover%standard_name = & diff --git a/ldt/core/LDT_paramTileInputMod.F90 b/ldt/core/LDT_paramTileInputMod.F90 index c5ede7371..b55f0bacb 100644 --- a/ldt/core/LDT_paramTileInputMod.F90 +++ b/ldt/core/LDT_paramTileInputMod.F90 @@ -109,7 +109,9 @@ subroutine param_index_fgrdcalc( n, param_proj, spatial_transform, & if( t == water_class ) then fgrd(c,r,t) = 0. else - if(varcnt(c,r,t)+1 > LDT_rc%udef) fgrd(c,r,t) = varcnt(c,r,t)/isum + if(varcnt(c,r,t)+1 > LDT_rc%udef) then + fgrd(c,r,t) = varcnt(c,r,t)/isum + endif endif endif diff --git a/ldt/params/landcover/read_MCD12Q1_lc.F90 b/ldt/params/landcover/read_MCD12Q1_lc.F90 new file mode 100755 index 000000000..448f16f13 --- /dev/null +++ b/ldt/params/landcover/read_MCD12Q1_lc.F90 @@ -0,0 +1,310 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LDT_misc.h" +!BOP +! +! !ROUTINE: read_MCD12Q1_lc +! \label{read_MCD12Q1_lc} +! +! !REVISION HISTORY: +! 03 June 2022: Sujay Kumar; Initial Specification +! +! !INTERFACE: +subroutine read_MCD12Q1_lc(n, num_types, fgrd, maskarray ) + +! !USES: + use LDT_coreMod, only : LDT_rc + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_verify, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_index_fgrdcalc +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + use netcdf +#endif + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(inout) :: num_types + real, intent(inout) :: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, intent(inout) :: maskarray(LDT_rc%lnc(n),LDT_rc%lnr(n)) +! +! !DESCRIPTION: +! This subroutine reads the MODIS Terra+Aqua landcover data and returns the +! distribution of vegetation in each grid cell, in a lat/lon +! projection. Also, the landmask is either generated and/or +! read in this routine. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of nest +! \item[fgrd] +! fraction of grid covered by each vegetation type +! \item[maskarray] +! landmask for the region of interest +! \end{description} +!EOP +! +! IGBP-NCEP landcover version: + integer, parameter :: IN_cols_igbpncep = 86400 + integer, parameter :: IN_rows_igbpncep = 43200 + real, parameter :: IN_xres = 1.0/240.0 + real, parameter :: IN_yres = 1.0/240.0 +! character*1 :: read_igbpncep_veg(IN_cols_igbpncep,IN_rows_igbpncep) + integer, allocatable :: read_igbpncep_veg(:,:) + + integer :: ftn, ierr, ios1, lcid + logical :: file_exists + integer :: i, t, c, r, line + integer :: input_cols, input_rows + integer :: glpnc, glpnr ! Parameter (global) total columns and rows + integer :: subpnc, subpnr ! Parameter subsetted columns and rows + integer :: mi ! Total number of input param grid array points + integer :: mo ! Total number of output LIS grid array points + real :: param_gridDesc(20) ! Input parameter grid desc array + real :: subparam_gridDesc(20) ! Subsetted parameter grid desc array + integer, allocatable :: lat_line(:,:), lon_line(:,:) + real, allocatable :: gi(:) ! Input parameter 1d grid + logical*1,allocatable :: li(:) ! Input logical mask (to match gi) + real :: go1(LDT_rc%lnc(n)*LDT_rc%lnr(n)) ! Output lis 1d grid + logical*1 :: lo1(LDT_rc%lnc(n)*LDT_rc%lnr(n)) ! Output logical mask (to match go) + real :: go2(LDT_rc%lnc(n)*LDT_rc%lnr(n), LDT_rc%nt) ! Output lis 1d grid + logical*1 :: lo2(LDT_rc%lnc(n)*LDT_rc%lnr(n), LDT_rc%nt) ! Output logical mask (to match go) + + real, allocatable :: subset_veg(:,:) ! Read input parameter + real :: vegcnt(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real :: vegtype(LDT_rc%lnc(n),LDT_rc%lnr(n)) + +!__________________________________________________________________ + + num_types = 20 + +!- Check if land cover file exists: + inquire( file=trim(LDT_rc%vfile(n)), exist=file_exists ) + if(.not. file_exists) then + write(LDT_logunit,*)"[ERR] The landcover map: ",trim(LDT_rc%vfile(n))," does not exist." + write(LDT_logunit,*)" Program stopping ..." + call LDT_endrun + endif + + write(LDT_logunit,*) "[INFO] Reading landcover file: ",trim(LDT_rc%vfile(n)) + +!- Open LDT land cover file: + select case ( LDT_rc%lc_type(n) ) + + case ( "IGBPNCEP" ) + + !- Assign additional land cover types, including generic water points: + LDT_rc%wetlandclass = 11 + LDT_rc%urbanclass = 13 + LDT_rc%snowclass = 15 + LDT_rc%glacierclass = 15 + LDT_rc%bareclass = 16 + LDT_rc%waterclass = 17 + + input_cols = IN_cols_igbpncep + input_rows = IN_rows_igbpncep + + !- Set parameter grid array inputs: + param_gridDesc(1) = 0. ! Latlon + param_gridDesc(2) = input_cols + param_gridDesc(3) = input_rows + param_gridDesc(4) = -90.0 + (IN_yres/2) ! LL lat + param_gridDesc(5) = -180.0 + (IN_xres/2) ! LL lon + param_gridDesc(6) = 128 + param_gridDesc(7) = 90.0 - (IN_yres/2) ! UR lat + param_gridDesc(8) = 180.0 - (IN_xres/2) ! UR lon + param_gridDesc(9) = IN_xres ! dx: 0.0083333 + param_gridDesc(10) = IN_yres ! dy: 0.0083333 + param_gridDesc(20) = 64 + +! -------------------------------- +! case ( "IGBP" ) +! case ( "UMD" ) +! case ( "PFT" ) + +!- Other landcover classifications associated with MODIS landcover: + case default ! Non-supported options + write(LDT_logunit,*) "[ERR] The native MODIS map with land classification: ",& + trim(LDT_rc%lc_type(n)),", is not yet supported." + write(LDT_logunit,*) " -- Please select: IGBPNCEP " + write(LDT_logunit,*) " Program stopping ..." + call LDT_endrun + + end select + +! ------------------------------------------------------------------- +! PREPARE SUBSETTED PARAMETER GRID FOR READING IN NEEDED DATA +! ------------------------------------------------------------------- + +!- Map Parameter Grid Info to LIS Target Grid/Projection Info -- + subparam_gridDesc = 0. + call LDT_RunDomainPts( n, LDT_rc%lc_proj, param_gridDesc(:), & + glpnc, glpnr, subpnc, subpnr, subparam_gridDesc, lat_line, lon_line ) + + + ! Open file: +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + ierr = nf90_open(path=trim(LDT_rc%vfile(n)),mode=NF90_NOWRITE,ncid=ftn) + call LDT_verify(ierr,'error opening MCD12Q1 landcover data') + + ierr = nf90_inq_varid(ftn,'LC_Type1',lcId) + call LDT_verify(ierr, 'nf90_inq_varid failed for LC_Type1in read_MCD12Q1_lc') + allocate( read_igbpncep_veg(subpnc,subpnr)) + + ierr = nf90_get_var(ftn,lcId, read_igbpncep_veg,& + count=(/subpnc,subpnr/), & + start=(/lon_line(1,1),lat_line(1,1)/)) + call LDT_verify(ierr, 'nf90_get_var failed for LC_Type1') + + ierr = nf90_close(ftn) + call LDT_verify(ierr) +#endif + + write(LDT_logunit,*) "[INFO] Done reading ", trim(LDT_rc%vfile(n)) + +! ------------------------------------------------------------------- + vegcnt = 0. + vegtype = float(LDT_rc%waterclass) + maskarray= 0.0 + fgrd = 0.0 + + allocate( subset_veg(subpnc, subpnr) ) + subset_veg = LDT_rc%waterclass + +!- Subset parameter read-in array: + line = 0 + do r = 1, subpnr + do c = 1, subpnc + if(read_igbpncep_veg(c,r).ne.255) then + subset_veg(c,r) = real(read_igbpncep_veg(c,r)) + else + subset_veg(c,r) = real(LDT_rc%waterclass) + endif + enddo + enddo + +! print*, subparam_gridDesc(1:10) +! open(100,file='test.bin',form='unformatted') +! write(100) subset_veg +! close(100) +! stop + +! ------------------------------------------------------------------- + + deallocate( read_igbpncep_veg ) +! ------------------------------------------------------------------- +! AGGREGATING FINE-SCALE GRIDS TO COARSER LIS OUTPUT GRID +! ------------------------------------------------------------------- + mi = subpnc*subpnr + allocate( gi(mi), li(mi) ) + gi = float(LDT_rc%waterclass) + li = .false. + mo = LDT_rc%lnc(n)*LDT_rc%lnr(n) + lo1 = .false.; lo2 = .false. + +!- Assign 2-D array to 1-D for aggregation routines: + i = 0 + do r = 1, subpnr + do c = 1, subpnc; i = i + 1 + gi(i) = subset_veg(c,r) + if( gi(i) .ne. LDT_rc%udef ) li(i) = .true. + enddo + enddo + +!- Aggregation/Spatial Transform Section: + select case ( LDT_rc%lc_gridtransform(n) ) + + !- (a) Estimate NON-TILED dominant land cover types (vegtype): + case( "neighbor", "mode" ) + + !- Transform parameter from original grid to LIS output grid: + call LDT_transform_paramgrid(n, LDT_rc%lc_gridtransform(n), & + subparam_gridDesc, mi, 1, gi, li, mo, go1, lo1 ) + + !- Convert 1D vegcnt to 2D grid arrays: + i = 0 + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + i = i + 1 + vegtype(c,r) = go1(i) + enddo + enddo + + !- (b) Estimate TILED land cover files (vegcnt): + case( "tile" ) + + !- Transform parameter from original grid to LIS output grid: + call LDT_transform_paramgrid(n, LDT_rc%lc_gridtransform(n), & + subparam_gridDesc, mi, LDT_rc%nt, gi, li, mo, go2, lo2 ) + + !- Convert 1D vegcnt to 2D grid arrays: + i = 0 + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + i = i + 1 + do t = 1, LDT_rc%nt + vegcnt(c,r,t) = go2(i,t) + end do + enddo + enddo + + end select ! End vegtype/cnt aggregation method + deallocate( gi, li ) + +! ........................................................................ + +!- Bring 2-D Vegtype to 3-D Vegcnt tile space: + if ( LDT_rc%lc_gridtransform(n) == "none" .or. & ! -- NON-TILED SURFACES + LDT_rc%lc_gridtransform(n) == "neighbor" .or. & + LDT_rc%lc_gridtransform(n) == "mode" ) then + + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + if ( vegtype(c,r) .le. 0 ) then + vegtype(c,r) = float(LDT_rc%waterclass) + endif + if ( (nint(vegtype(c,r)) .ne. LDT_rc%waterclass ) .and. & + (nint(vegtype(c,r)) .ne. LDT_rc%udef)) then + vegcnt(c,r,NINT(vegtype(c,r))) = 1.0 + endif + enddo + end do + endif ! End NON-TILED vegetation option + +!- Estimate fraction of grid (fgrid) represented by vegetation type:: + call param_index_fgrdcalc( n, LDT_rc%lc_proj, LDT_rc%lc_gridtransform(n), & + LDT_rc%waterclass, LDT_rc%nt, vegcnt, fgrd ) + + +! ------------------------------------------------------------------- +! CREATE OR READ-IN (OR IMPOSE) LAND MASK FILE AND CREATE +! SURFACE MAP +! ------------------------------------------------------------------- + +!- "READ-IN" land mask file, if user-specified: + if( LDT_rc%mask_type(n) == "readin" ) then + + call read_maskfile( n, vegtype, fgrd, maskarray ) + +!- "CREATE" land mask and surface type fields (user-specified): + elseif( LDT_rc%mask_type(n) == "create" ) then + + call create_maskfile( n, LDT_rc%nt, LDT_rc%lc_gridtransform(n), & + vegtype, vegcnt, maskarray ) + + end if + deallocate( subset_veg ) + + +end subroutine read_MCD12Q1_lc diff --git a/ldt/params/mask/read_maskfile.F90 b/ldt/params/mask/read_maskfile.F90 index bbea2716e..d3c1a11b1 100755 --- a/ldt/params/mask/read_maskfile.F90 +++ b/ldt/params/mask/read_maskfile.F90 @@ -100,6 +100,11 @@ subroutine read_maskfile(n, vegtype, fgrd, localmask ) call LDT_endrun endif + if(LDT_rc%mask_source(n) =="MCD12Q1") then + call read_maskfile_MCD12Q1(n,vegtype, fgrd, localmask) + return + endif + ! ------------------------------------------------------------------- ! PREPARE SUBSETTED PARAMETER GRID FOR READING IN NEEDED DATA ! ------------------------------------------------------------------- diff --git a/ldt/params/mask/read_maskfile_MCD12Q1.F90 b/ldt/params/mask/read_maskfile_MCD12Q1.F90 new file mode 100644 index 000000000..43e4f6d58 --- /dev/null +++ b/ldt/params/mask/read_maskfile_MCD12Q1.F90 @@ -0,0 +1,56 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +! +! SUBROUTINE: MCD12Q1 +! +! REVISION HISTORY: +! 03 June 2022: Sujay Kumar; Initial Specification +! +! DESCRIPTION: +! Source code for reading and interpolating land mask data in netCDF format +! produced from MCD12Q1 land use data. The input maskfile is expected to be +! at the same exact grid and resolution of the LDT target grid. +! No spatial transformation is performed. +!------------------------------------------------------------------------------ + +#include "LDT_misc.h" + subroutine read_maskfile_MCD12Q1(n,vegtype, fgrd, localmask) + + use LDT_coreMod + use LDT_logMod +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + use netcdf +#endif + + implicit none + + integer, intent(in) :: n + real, intent(in) :: vegtype(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real, intent(in) :: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, intent(out) :: localmask(LDT_rc%lnc(n),LDT_rc%lnr(n)) + + integer :: ftn, ierr,maskId + +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + ierr = nf90_open(path=trim(LDT_rc%mfile(n)),mode=NF90_NOWRITE,ncid=ftn) + call LDT_verify(ierr,'error opening MCD12Q1 landmask data') + + ierr = nf90_inq_varid(ftn,'LANDMASK',maskId) + call LDT_verify(ierr, 'nf90_inq_varid failed for LANDMASK in read_maskfile_MCD12Q1') + + ierr = nf90_get_var(ftn,maskId, localmask) + call LDT_verify(ierr, 'nf90_get_var failed for LANDMASK in read_maskfile_MCD12Q1') + + ierr = nf90_close(ftn) + call LDT_verify(ierr) +#endif + + + end subroutine read_maskfile_MCD12Q1 diff --git a/ldt/plugins/LDT_param_pluginMod.F90 b/ldt/plugins/LDT_param_pluginMod.F90 index 8b41ec458..39ff0fee6 100644 --- a/ldt/plugins/LDT_param_pluginMod.F90 +++ b/ldt/plugins/LDT_param_pluginMod.F90 @@ -25,7 +25,7 @@ module LDT_param_pluginMod ! 01 Mar 2020: Yeosang Yoon - Added MERIT DEM ! 29 Jun 2020: Mahdi Navari - Glacier fraction added ! 12 Apr 2021: Wanshu Nie - groundwater irrigation ratio added -! 28 Jun 2022: Eric Kemp - Added NAFPA background precipitation +! !EOP use LDT_pluginIndices @@ -77,12 +77,8 @@ subroutine LDT_LSMparam_plugin use Mosaic_parmsMod use RUC_parmsMod use JULES50_parmsMod - use Crocus_parmsMod + use Crocus_parmsMod - external :: registerlsmparamprocinit - external :: registerlsmparamprocwriteheader - external :: registerlsmparamprocwritedata - ! Noah 2.7.1 LSM: call registerlsmparamprocinit(trim(LDT_noah271Id)//char(0),& NoahParms_init) @@ -374,6 +370,7 @@ subroutine LDT_landcover_plugin external set_MODISNative_lc_attribs external read_MODISNative_lc + external read_MCD12Q1_lc external read_MODISNative_PFT external read_UKMO_IGBP_PFT external read_UM_ancillary @@ -421,6 +418,7 @@ subroutine LDT_landcover_plugin ! MODIS-IGBP/NCEP (LIS-based): call registerreadlc(trim(LDT_modislcLISId)//char(0), read_MODIS_lc) + call registerreadlc(trim(LDT_mcd12q1Id)//char(0), read_MCD12Q1_lc) ! USGS (Native): call registerreadlc(trim(LDT_usgslcNATId)//char(0), read_USGSNative_lc) @@ -1183,14 +1181,10 @@ end subroutine LDT_alb_plugin ! !INTERFACE: subroutine LDT_climate_plugin !EOP - use LDT_NAFPA_back_climpptMod, only: LDT_read_NAFPA_back_gfs_climppt, & - LDT_read_NAFPA_back_galwem_climppt external read_PRISM_climppt external read_WorldClim_climppt external read_NLDAS_climppt - external :: registerreadclimppt - ! !USES: !- Precipitation downscaling: call registerreadclimppt(trim(LDT_prismpptId)//char(0),& @@ -1199,12 +1193,6 @@ subroutine LDT_climate_plugin call registerreadclimppt(trim(LDT_worldclimpptId)//char(0),& read_WorldClim_climppt) - call registerreadclimppt(trim(LDT_nafpabackgfspptId)//char(0),& - LDT_read_NAFPA_back_gfs_climppt) - - call registerreadclimppt(trim(LDT_nafpabackgalwempptId)//char(0),& - LDT_read_NAFPA_back_galwem_climppt) - !- Temperature downscaling: end subroutine LDT_climate_plugin diff --git a/ldt/plugins/LDT_pluginIndices.F90 b/ldt/plugins/LDT_pluginIndices.F90 index c81ba0b9c..aff814f89 100644 --- a/ldt/plugins/LDT_pluginIndices.F90 +++ b/ldt/plugins/LDT_pluginIndices.F90 @@ -25,7 +25,6 @@ module LDT_pluginIndices ! 23 Oct 2008: Sujay Kumar -- Initial Specification ! 17 Jul 2012: KR Arsenault -- Updated entries with capitalization rules ! 01 Mar 2020: Yeosang Yoon -- Added MERIT DEM -! 28 Jun 2022: Eric Kemp -- Added NAFPA background precipitation ! !EOP PRIVATE @@ -218,6 +217,7 @@ module LDT_pluginIndices character*50, public, parameter :: LDT_usgslcNATId = "USGS_Native" character*50, public, parameter :: LDT_modislcLISId = "MODIS_LIS" character*50, public, parameter :: LDT_modislcNATId = "MODIS_Native" + character*50, public, parameter :: LDT_mcd12q1Id = "MCD12Q1" character*50, public, parameter :: LDT_modislcPFTId = "MODIS_Native_PFT" character*50, public, parameter :: LDT_ukmoigbpPFTId = "UKMO_IGBP_Native_PFT" character*50, public, parameter :: LDT_UM_ancillaryId = "UM_Native_Ancillary" @@ -343,10 +343,6 @@ module LDT_pluginIndices !- PPT: character*50, public, parameter :: LDT_prismpptId = "PRISM" character*50, public, parameter :: LDT_worldclimpptId = "WORLDCLIM" - character*50, public, parameter :: LDT_nafpabackgfspptId = "NAFPA_BACK_GFS" - character*50, public, parameter :: LDT_nafpabackgalwempptId = & - "NAFPA_BACK_GALWEM" - !- TMIN: character*50, public, parameter :: LDT_prismtminId = "PRISM" character*50, public, parameter :: LDT_worldclimtminId = "WORLDCLIM" From 2468b56b5c1b4603de150a03511bc91465fc78f4 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Wed, 24 Aug 2022 15:15:05 -0400 Subject: [PATCH 058/328] Incorporate SnowModel and MicroMet model code - Implemented Glen Liston's SnowModel Code, MicroMet routines, and interface with NoahMP401. - Several new features are included, and the model is incorporated in the new subLSM layer, which Crocus v8.1 snow model is also found in. This code commit supports and addresses LISF GitHub issue #813 and #814; https://github.com/NASA-LIS/LISF/issues/813 https://github.com/NASA-LIS/LISF/issues/814 Test case will be submitted next and made available for full LDT and LIS-SnowModel testing for the pull request. --- ldt/configs/ldt.config.adoc | 25 + ldt/core/LDT_LMLCMod.F90 | 31 + ldt/core/LDT_PRIV_rcMod.F90 | 1 + ldt/core/LDT_fileIOMod.F90 | 59 +- ldt/core/LDT_paramOptCheckMod.F90 | 16 + ldt/core/LDT_paramProcMod.F90 | 12 + ldt/make/Filepath | 2 +- ldt/params/SnowModel/SnowModel_parmsMod.F90 | 328 ++ .../SnowModel/read_SMGradsBin_topoveg.F90 | 114 + .../landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 | 231 + ldt/params/landcover/read_NALCMS_SM_lc.F90 | 150 + ldt/params/topo/read_NED_SM_aspect.F90 | 171 + ldt/params/topo/read_NED_SM_curvature.F90 | 180 + ldt/params/topo/read_NED_SM_elev.F90 | 106 + ldt/params/topo/read_NED_SM_slope.F90 | 164 + ldt/params/topo/setTopoParmsFullnames.F90 | 12 + ldt/plugins/LDT_param_pluginMod.F90 | 29 +- ldt/plugins/LDT_pluginIndices.F90 | 4 + lis/configs/MODEL_OUTPUT_LIST.TBL.adoc | 22 + lis/configs/lis.config.adoc | 120 + lis/core/LIS_PRIV_tileMod.F90 | 2 +- lis/core/LIS_domainMod.F90 | 129 +- lis/core/LIS_histDataMod.F90 | 275 +- lis/core/LIS_metforcingMod.F90 | 29 +- lis/core/LIS_microMetCorrection.F90 | 898 +++- lis/core/LIS_sublsm_FTable.c | 74 + lis/core/LIS_topoMod.F90 | 114 +- lis/make/default.cfg | 9 +- lis/plugins/LIS_pluginIndices.F90 | 7 +- lis/plugins/LIS_sublsm_pluginMod.F90 | 132 +- .../land/noahmp.4.0.1/NoahMP401_readcrd.F90 | 3 + .../noahmp401_getSnowModelexport.F90 | 75 + .../noahmp401_setSnowModelimport.F90 | 68 + .../phys/module_sf_noahmplsm_401.F90 | 2 +- .../cplLSM/Snowmodel_getLSMexport.F90 | 68 + .../cplLSM/Snowmodel_setLSMimport.F90 | 77 + .../land/subLSM/snowmodel/micromet_module.F90 | 430 ++ .../snowmodel/physics/dataassim_user.f90 | 1958 ++++++++ .../subLSM/snowmodel/physics/enbal_code.f90 | 808 +++ .../snowmodel/physics/micromet_code.f90 | 3553 ++++++++++++++ .../subLSM/snowmodel/physics/outputs_user.f90 | 483 ++ .../snowmodel/physics/preprocess_code.f90 | 4328 +++++++++++++++++ .../snowmodel/physics/readparam_code.f90 | 2043 ++++++++ .../snowmodel/physics/snowmodel_inc.f90 | 60 + .../snowmodel/physics/snowmodel_vars.f90 | 393 ++ .../snowmodel/physics/snowpack_code.f90 | 3211 ++++++++++++ .../snowmodel/physics/snowtran_code.f90 | 4059 ++++++++++++++++ .../subLSM/snowmodel/snowmodel_coldstart.F90 | 135 + .../subLSM/snowmodel/snowmodel_dynsetup.F90 | 37 + .../land/subLSM/snowmodel/snowmodel_f2t.F90 | 244 + .../subLSM/snowmodel/snowmodel_finalize.F90 | 44 + .../subLSM/snowmodel/snowmodel_lsmMod.F90 | 615 +++ .../land/subLSM/snowmodel/snowmodel_main.F90 | 750 +++ .../subLSM/snowmodel/snowmodel_module.F90 | 145 + .../subLSM/snowmodel/snowmodel_readconfig.F90 | 150 + .../subLSM/snowmodel/snowmodel_readrst.F90 | 240 + .../land/subLSM/snowmodel/snowmodel_reset.F90 | 65 + .../land/subLSM/snowmodel/snowmodel_setup.F90 | 224 + .../subLSM/snowmodel/snowmodel_writerst.F90 | 343 ++ 59 files changed, 27887 insertions(+), 170 deletions(-) create mode 100644 ldt/params/SnowModel/SnowModel_parmsMod.F90 create mode 100644 ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 create mode 100644 ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 create mode 100644 ldt/params/landcover/read_NALCMS_SM_lc.F90 create mode 100644 ldt/params/topo/read_NED_SM_aspect.F90 create mode 100644 ldt/params/topo/read_NED_SM_curvature.F90 create mode 100644 ldt/params/topo/read_NED_SM_elev.F90 create mode 100644 ldt/params/topo/read_NED_SM_slope.F90 create mode 100644 lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 create mode 100755 lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/dataassim_user.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/enbal_code.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/micromet_code.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/outputs_user.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/preprocess_code.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/readparam_code.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_inc.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_vars.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/snowpack_code.f90 create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/physics/snowtran_code.f90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8c0695d5e..17a5ee5b7 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -93,6 +93,7 @@ Surface model types: "LSM" |Mosaic |Mosaic |HySSIB |HySSIB |CLSMF2.5 |Catchment, Fortuna 2.5 +|SnowModel |SnowModel |SAC.3.5.6 |Sacramento |SNOW17 |Snow17 |RDHM.3.5.6 |Sacramento+snow17 @@ -772,6 +773,8 @@ endif::devonly[] |VIC412 |Variable Infiltration Capacity model, v4.1.2, UMD land cover. |ISA |Impervious Surface Area (ISA) landcover dataset. |CLM45 |CLM-4.5 landcover dataset. +|NALCMS_SM |SnowModel-based NALCMS landcover dataset. +|NALCMS_SM_IGBPNCEP |SnowModel-based NALCMS landcover dataset with IGBPNCEP-mapped classes. |CONSTANT |Ability to set a constant landcover type for a set classification. |=== @@ -1720,6 +1723,7 @@ Current options include: |SRTM_LIS |Similar dataset as to the above one but processed by LISF-team. |CONSTANT |User can set a constant elevation, slope or aspect class. |MERIT_1K |The MERIT elevation map, but processed by LISF-team to have a resolution '`0.008333`'. See: http://hydro.iis.u-tokyo.ac.jp/~yamadai/MERIT_DEM/index.html +|NED_SM | SnowModel-based National Elevation Dataset (NED) topographic fields. |=== .Example _ldt.config_ entry @@ -2452,6 +2456,27 @@ CLM45 resolution (dx): 1.25 CLM45 resolution (dy): 0.9424060 .... +If selecting Glen Liston's SnowModel, the following config entires are required. + +`Snowmodel topo-veg data source:` specifies which pre-processed SnowModel parameters and file format type to be read in. Currently, only the "`Grads_binary`" option is available. + +`Snowmodel topo-veg map:` specifies the directory-file location of the pre-processed SnowModel topographic and vegetation class parameters. + +`Snowmodel topo-veg spatial transform:` specifies the type of grid transform for preprocessed SnowModel topographic and vegetation class parameters. Currently, this option is not yet supported and user option is only "`none`" at this time. + +`Snowmodel topo-veg map projection:` specifies the SnowModel parameter file projection. Currently, SnowModel parameter projection needs to be set to the same as the LIS domain projection, for now. SnowModel parameters are best provided either on a Lambert projection (in LIS) and supports some equal-area projection grids, like UTM, which is available in LIS. Future support for more options will be added. + +`Snowmodel topo-veg fill option:` specifies the type of fill option used with SnowModel parameters. Currently, this feature is not supported, and will be in future versions. + +.Example _ldt.config_ entry +.... +Snowmodel topo-veg data source: "Grads_binary" +Snowmodel topo-veg map: ../SnowModel_Inputs/uppertuo_100m/topo_vege.gdat +Snowmodel topo-veg spatial transform: "none" +Snowmodel topo-veg map projection: lambert +Snowmodel topo-veg fill option: none +.... + Potential Evapotranspiration (PET) maps `PET directory:` specifies the source of the monthly climatology based PET files. The climatology data files have the following naming convention: /..1gd4r. The tag should be represent the month (such as JAN, FEB, MAR, etc.). The file header can be anything (such as avhrr_pet_1KM). Currently, this parameter is used only with the RDHM-SAC model. diff --git a/ldt/core/LDT_LMLCMod.F90 b/ldt/core/LDT_LMLCMod.F90 index 23c97950d..a11b94610 100644 --- a/ldt/core/LDT_LMLCMod.F90 +++ b/ldt/core/LDT_LMLCMod.F90 @@ -182,6 +182,13 @@ subroutine LMLC_init_LIS() end if enddo + ! Option to assign all landmask and domainmask points to land: + ! 0 - "off"; 1 - "on", where all points are set to 1 + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%allmaskland,& + label="Set all land and domain masks to 1:",& + default=0,rc=rc) + call LDT_verify(rc,'Set all land and domain masks to 1: not defined') + !-- Landcover dataset file and option inputs: call ESMF_ConfigFindLabel(LDT_config,"Landcover file:",rc=rc) @@ -878,6 +885,12 @@ subroutine LMLC_writeHeader_LIS(n,ftn,dimID) case( "UMD" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_LANDCATS", & 13)) + case( "NALCMS_SM" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_LANDCATS", & + 24)) + case( "NALCMS_SM_IGBPNCEP" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_LANDCATS", & + 20)) case( "Bondville" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_LANDCATS", & 20)) @@ -934,6 +947,13 @@ subroutine LMLC_writeHeader_LIS(n,ftn,dimID) case ( "CLM45" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & 36)) + case ( "NALCMS_SM" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & + 24)) + case ( "NALCMS_SM_IGBPNCEP" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & + 17)) +! 20)) case ( "Bondville" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & 17)) @@ -950,6 +970,8 @@ subroutine LMLC_writeHeader_LIS(n,ftn,dimID) write(LDT_logunit,*) ' -- MOSAIC ' write(LDT_logunit,*) ' -- ISA ' write(LDT_logunit,*) ' -- CLM45 ' + write(LDT_logunit,*) ' -- NALCMS_SM ' + write(LDT_logunit,*) ' -- NALCMS_SM_IGBPNCEP ' write(LDT_logunit,*) ' -- CONSTANT ' write(LDT_logunit,*) ' ... program stopping. ' call LDT_endrun @@ -1107,6 +1129,13 @@ subroutine LMLC_writeHeader_LISHydro(n,ftn,dimID, flag) case ( "ISA" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & 13)) + case ( "NALCMS_SM" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & + 24)) + case ( "NALCMS_SM_IGBPNCEP" ) + call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & + 17)) +! 20)) case ( "CONSTANT" ) call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMVEGTYPES", & LDT_LSMparam_struc(n)%landcover%num_bins)) @@ -1119,6 +1148,8 @@ subroutine LMLC_writeHeader_LISHydro(n,ftn,dimID, flag) write(LDT_logunit,*) ' -- USGS ' write(LDT_logunit,*) ' -- MOSAIC ' write(LDT_logunit,*) ' -- ISA ' + write(LDT_logunit,*) ' -- NALCMS_SM ' + write(LDT_logunit,*) ' -- NALCMS_SM_IGBPNCEP ' write(LDT_logunit,*) ' -- CONSTANT ' write(LDT_logunit,*) ' ... program stopping. ' call LDT_endrun diff --git a/ldt/core/LDT_PRIV_rcMod.F90 b/ldt/core/LDT_PRIV_rcMod.F90 index e79513fcc..8cbf4bdb6 100644 --- a/ldt/core/LDT_PRIV_rcMod.F90 +++ b/ldt/core/LDT_PRIV_rcMod.F90 @@ -45,6 +45,7 @@ module LDT_PRIV_rcMod integer :: add_buffer ! KA integer :: x_buffer integer :: y_buffer + integer :: allmaskland ! KA: Temporary for NoahMP+SM coupling ! -- Land surface input parameters: integer :: max_model_types diff --git a/ldt/core/LDT_fileIOMod.F90 b/ldt/core/LDT_fileIOMod.F90 index b4c4aad2f..096b3a383 100644 --- a/ldt/core/LDT_fileIOMod.F90 +++ b/ldt/core/LDT_fileIOMod.F90 @@ -725,7 +725,64 @@ subroutine LDT_readDomainConfigSpecs(segment_name, param_proj, domain_info) domain_info(i,11) = 64 domain_info(i,20) = 64 enddo - + +! -- Added Lambert parameter domain (KRA) + + case ( "lambert" ) + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" lower left lat:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,4),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' lower left lat:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" lower left lon:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,5),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' lower left lon:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" true lat1:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,10),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' true lat1:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" true lat2:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,7),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' true lat2:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" standard lon:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,11),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' standard lon:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" resolution:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,8),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' resolution:') + domain_info(i,9) = domain_info(i,8) ! set dx = dy for now + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" x-dimension size:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,2),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' x-dimension size:') + enddo + + call ESMF_ConfigFindLabel(LDT_config,trim(segment_name)//" y-dimension size:",rc=rc) + do i=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,domain_info(i,3),rc=rc) + call LDT_verify(rc,'please specify '//trim(segment_name)//' y-dimension size:') + enddo + + do i=1,LDT_rc%nnest + domain_info(i,6) = 8.0 + enddo + ! --- case ( "gaussian" ) diff --git a/ldt/core/LDT_paramOptCheckMod.F90 b/ldt/core/LDT_paramOptCheckMod.F90 index 41e17df70..dc5355255 100644 --- a/ldt/core/LDT_paramOptCheckMod.F90 +++ b/ldt/core/LDT_paramOptCheckMod.F90 @@ -336,6 +336,20 @@ subroutine LDT_LMLCOptChecks( param_name, lc_type, nt, spatial_transform ) write(LDT_logunit,*) " Stopping ..." call LDT_endrun endif + case( "NALCMS_SM" ) + if( nt .lt. 24 .or. nt .ge. 25 ) then + write(LDT_logunit,*) "Param_Check: NALCMS_SM has a minimum of 24 types (includes water)." + write(LDT_logunit,*) " Value is currently at: ",nt + write(LDT_logunit,*) " Stopping ..." + call LDT_endrun + endif + case( "NALCMS_SM_IGBPNCEP" ) + if( nt .lt. 20 .or. nt .ge. 21 ) then + write(LDT_logunit,*) "Param_Check: NALCMS_SM_IGBPNCEP has a minimum of 20 types (includes water)." + write(LDT_logunit,*) " Value is currently at: ",nt + write(LDT_logunit,*) " Stopping ..." + call LDT_endrun + endif #if 0 case( "CONSTANT" ) if( nt .lt. 2 ) then @@ -356,6 +370,8 @@ subroutine LDT_LMLCOptChecks( param_name, lc_type, nt, spatial_transform ) write(LDT_logunit,*) " -- MOSAIC " write(LDT_logunit,*) " -- ISA " write(LDT_logunit,*) " -- CLM45 " + write(LDT_logunit,*) " -- NALCMS_SM " + write(LDT_logunit,*) " -- NALCMS_SM_IGBPNCEP " write(LDT_logunit,*) " -- CONSTANT " write(LDT_logunit,*) " Stopping ..." call LDT_endrun diff --git a/ldt/core/LDT_paramProcMod.F90 b/ldt/core/LDT_paramProcMod.F90 index 61af05562..c4c635f77 100644 --- a/ldt/core/LDT_paramProcMod.F90 +++ b/ldt/core/LDT_paramProcMod.F90 @@ -2536,6 +2536,18 @@ subroutine setLandcoverCategories(n,source) LDT_LSMparam_struc(n)%landcover%standard_name = & "CLM-4.5 PFT and landunits landcover map" + case( "NALCMS_SM" ) + LDT_rc%lc_type(n) = "NALCMS_SM" + LDT_LSMparam_struc(n)%landcover%num_bins = 24 + LDT_LSMparam_struc(n)%landcover%standard_name = & + "SnowModel-mapped NALCMS landcover classes map" + + case( "NALCMS_SM_IGBPNCEP" ) + LDT_rc%lc_type(n) = "NALCMS_SM_IGBPNCEP" + LDT_LSMparam_struc(n)%landcover%num_bins = 20 + LDT_LSMparam_struc(n)%landcover%standard_name = & + "NALCMS/SnowModel landcover classes mapped to IGBP/NCEP" + case( "CONSTANT" ) LDT_LSMparam_struc(n)%landcover%num_bins = 13 LDT_LSMparam_struc(n)%landcover%standard_name = & diff --git a/ldt/make/Filepath b/ldt/make/Filepath index 182375bc9..8babcd396 100644 --- a/ldt/make/Filepath +++ b/ldt/make/Filepath @@ -1 +1 @@ -dirs := . ../main ../core ../interp ../plugins ../lib/bil ../lib/xmrg ../params/mask ../params/landcover ../params/soils ../params/topo ../params/albedo ../params/gfrac ../params/LAISAI ../params/slopetype ../params/tbot ../params/pet ../params/climateparms ../params/crop_parms ../params/irrigation ../params/catchment ../params/CLM2 ../params/GeoWRSI ../params/FLAKE ../params/HYMAP ../params/JULES ../params/Mosaic ../params/Noah ../params/RDHM ../params/RUC ../params/SACHTET ../params/Snow17 ../params/SiB2 ../params/VIC ../params/glacier ../runmodes/ANNproc ../runmodes/DApreproc ../runmodes/LSMparamproc ../runmodes/EnsRstpreproc ../runmodes/NUWRFpreproc ../runmodes/Metforcproc ../runmodes/MetTimeDScale ../runmodes/climoRstproc ../runmodes/rstTransformProc ../runmodes/StatDscaleMetForc ../runmodes/OPTUEproc/ ../domains/latlon ../domains/gaussian ../domains/hrap ../domains/lambert ../domains/polar ../domains/merc ../domains/easev2 ../DAobs/MCD15A2H_LAI ../DAobs/LISlsmSMobs ../DAobs/synthetic_sm ../DAobs/NASA_AMSRE_sm ../DAobs/LPRM_AMSREsm ../DAobs/LPRMvod ../DAobs/ESACCI_sm ../DAobs/WindSat_sm ../DAobs/GRACE_tws ../DAobs/GRACEQL_tws ../DAobs/SMOPS ../DAobs/ASCAT_TUW ../DAobs/SMOS_L2sm ../DAobs/SMOS_NESDIS ../DAobs/GCOMW_AMSR2L3snd ../DAobs/GCOMW_AMSR2L3sm ../DAobs/Aquarius_L2sm ../DAobs/simGRACE_JPL ../DAobs/SMMR_SNWD ../DAobs/SSMI_SNWD ../DAobs/ANSA_SNWD ../DAobs/NASA_SMAPsm ../DAobs/SMOS_NRTNN_L2sm ../DAobs/NASA_SMAPvod ../DAobs/GLASSlai ../DAobs/THySM ../RESTRICTED/usaf/usaf ../metforcing/agrradps ../metforcing/cmap ../metforcing/cmorph ../metforcing/ecmwf ../metforcing/gdas ../metforcing/geos5fcst ../metforcing/gfs ../metforcing/gldas ../metforcing/gswp1 ../metforcing/gswp2 ../metforcing/merra2 ../metforcing/era5 ../metforcing/nam242 ../metforcing/narr ../metforcing/princeton ../metforcing/nldas2 ../metforcing/WRFoutv2 ../metforcing/WRFAKdom ../metforcing/stg2 ../metforcing/stg4 ../metforcing/3B42RTV7 ../metforcing/3B42V6 ../metforcing/3B42V7 ../metforcing/RFE2Daily ../metforcing/RFE2gdas ../metforcing/chirps2 ../MetforcScale ../ANNdata/LISlsmSM ../ANNdata/synthetic_sm ../ANNdata/LPRM_AMSREsm ../ANNdata/MODIS_LST ../ANNdata/MOD10A1 ../ANNdata/GHCNsnwd ../ANNdata/GCOMW_AMSR2_TB ../statDscale/BayesianMerging ../statDscale/Climo ../params/CLM45 ../USAFSI ../runmodes/USAFSI ../runmodes/LISHydropreproc ../params/Crocus ../runmodes/obsSim ../obsSim/NatureRun/LISout/ ../obsSim/OSSEmask/LISout/ ../obsSim/OSSEmask/AMSR2/ ../obsSim/OSSEmask/TSMM/ ../obsSim/OSSEmask/MODIS/ ../obsSim/OSSEmask/Sentinel1A/ +dirs := . ../main ../core ../interp ../plugins ../lib/bil ../lib/xmrg ../params/mask ../params/landcover ../params/soils ../params/topo ../params/albedo ../params/gfrac ../params/LAISAI ../params/slopetype ../params/tbot ../params/pet ../params/climateparms ../params/crop_parms ../params/irrigation ../params/catchment ../params/CLM2 ../params/GeoWRSI ../params/FLAKE ../params/HYMAP ../params/JULES ../params/Mosaic ../params/Noah ../params/RDHM ../params/RUC ../params/SACHTET ../params/Snow17 ../params/SnowModel ../params/SiB2 ../params/VIC ../params/glacier ../runmodes/ANNproc ../runmodes/DApreproc ../runmodes/LSMparamproc ../runmodes/EnsRstpreproc ../runmodes/NUWRFpreproc ../runmodes/Metforcproc ../runmodes/MetTimeDScale ../runmodes/climoRstproc ../runmodes/rstTransformProc ../runmodes/StatDscaleMetForc ../runmodes/OPTUEproc/ ../domains/latlon ../domains/gaussian ../domains/hrap ../domains/lambert ../domains/polar ../domains/merc ../domains/easev2 ../DAobs/MCD15A2H_LAI ../DAobs/LISlsmSMobs ../DAobs/synthetic_sm ../DAobs/NASA_AMSRE_sm ../DAobs/LPRM_AMSREsm ../DAobs/LPRMvod ../DAobs/ESACCI_sm ../DAobs/WindSat_sm ../DAobs/GRACE_tws ../DAobs/GRACEQL_tws ../DAobs/SMOPS ../DAobs/ASCAT_TUW ../DAobs/SMOS_L2sm ../DAobs/SMOS_NESDIS ../DAobs/GCOMW_AMSR2L3snd ../DAobs/GCOMW_AMSR2L3sm ../DAobs/Aquarius_L2sm ../DAobs/simGRACE_JPL ../DAobs/SMMR_SNWD ../DAobs/SSMI_SNWD ../DAobs/ANSA_SNWD ../DAobs/NASA_SMAPsm ../DAobs/SMOS_NRTNN_L2sm ../DAobs/NASA_SMAPvod ../DAobs/GLASSlai ../DAobs/THySM ../RESTRICTED/usaf/usaf ../metforcing/agrradps ../metforcing/cmap ../metforcing/cmorph ../metforcing/ecmwf ../metforcing/gdas ../metforcing/geos5fcst ../metforcing/gfs ../metforcing/gldas ../metforcing/gswp1 ../metforcing/gswp2 ../metforcing/merra2 ../metforcing/era5 ../metforcing/nam242 ../metforcing/narr ../metforcing/princeton ../metforcing/nldas2 ../metforcing/WRFoutv2 ../metforcing/WRFAKdom ../metforcing/stg2 ../metforcing/stg4 ../metforcing/3B42RTV7 ../metforcing/3B42V6 ../metforcing/3B42V7 ../metforcing/RFE2Daily ../metforcing/RFE2gdas ../metforcing/chirps2 ../MetforcScale ../ANNdata/LISlsmSM ../ANNdata/synthetic_sm ../ANNdata/LPRM_AMSREsm ../ANNdata/MODIS_LST ../ANNdata/MOD10A1 ../ANNdata/GHCNsnwd ../ANNdata/GCOMW_AMSR2_TB ../statDscale/BayesianMerging ../statDscale/Climo ../params/CLM45 ../USAFSI ../runmodes/USAFSI ../runmodes/LISHydropreproc ../params/Crocus ../runmodes/obsSim ../obsSim/NatureRun/LISout/ ../obsSim/OSSEmask/LISout/ ../obsSim/OSSEmask/AMSR2/ ../obsSim/OSSEmask/TSMM/ ../obsSim/OSSEmask/MODIS/ ../obsSim/OSSEmask/Sentinel1A/ diff --git a/ldt/params/SnowModel/SnowModel_parmsMod.F90 b/ldt/params/SnowModel/SnowModel_parmsMod.F90 new file mode 100644 index 000000000..f462f481f --- /dev/null +++ b/ldt/params/SnowModel/SnowModel_parmsMod.F90 @@ -0,0 +1,328 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LDT_misc.h" +module SnowModel_parmsMod +!BOP +! +! !MODULE: SnowModel_parmsMod +! +! !DESCRIPTION: +! The code in this file implements routines to read SnowModel parameter +! data. +! \subsubsection{Overview} +! This routines in this module provides routines to read the +! SnowModel parameter file data. +! +! !REVISION HISTORY: +! +! 16 July 2020: K. Arsenault: SnowModel model parameters +! +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + use ESMF + use LDT_coreMod + use LDT_historyMod + use LDT_paramDataMod + use LDT_logMod + use LDT_paramMaskCheckMod + + implicit none + + PRIVATE +!------------------------------------------------------------------------------ +! !PUBLIC MEMBER FUNCTIONS: +!------------------------------------------------------------------------------ + public :: SnowModelparms_init !allocates memory for required structures + public :: SnowModelparms_writeHeader + public :: SnowModelparms_writeData + +!------------------------------------------------------------------------------ +! !PUBLIC TYPES: +!------------------------------------------------------------------------------ + public :: SnowModel_struc + + type, public :: sm_type_dec + +! - SnowModel-specific: + integer :: Nveg + + real :: topoveg_gridDesc(20) + character(140) :: topoveg_file + character(50) :: topoveg_gridtransform + character(50) :: topoveg_proj + + type(LDT_paramEntry) :: sm ! SnowModel parameters (collective) + type(LDT_paramEntry) :: sm_topo ! SnowModel-specific topo map + type(LDT_paramEntry) :: sm_vege ! SnowModel-specific veg map + + end type sm_type_dec + + type(sm_type_dec), allocatable :: SnowModel_struc(:) + +contains + +!BOP +! +! !ROUTINE: SnowModelparms_init +! \label{SnowModelparms_init} +! +! !INTERFACE: + subroutine SnowModelparms_init + +! !USES: + use LDT_logMod, only : LDT_verify, LDT_endrun, & + LDT_getNextUnitNumber, LDT_releaseUnitNumber +! +! !DESCRIPTION: +! +! Glen Liston's SnowModel model parameters. +! +! The routines invoked are: +! \begin{description} +! \item[smParmssetup](\ref{smParmssetup}) \newline +! calls the registry to invoke the SnowModel Parms setup methods. +! \end{description} +! +!EOP + implicit none + integer :: n + integer :: c,r,m,k + integer :: rc + integer :: file_status + logical :: file_exists + logical :: sm_select + logical :: check_data + character*50 :: topoveg_proj + + type(LDT_fillopts) :: topoveg + +! integer :: veg_tiling_scheme ! 0=SnowModel, 1=LIS + + ! _____________________________________________________________________ + + allocate(SnowModel_struc(LDT_rc%nnest)) + + sm_select = .false. + do n=1,LDT_rc%nnest + ! - SnowModel parameters: + call set_param_attribs(SnowModel_struc(n)%sm,"SnowModel") + if( SnowModel_struc(n)%sm%selectOpt == 1 ) then + sm_select = .true. + + call set_param_attribs(SnowModel_struc(n)%sm_topo,"SMTOPO",& + units="m", & + full_name="SnowModel topography") + + call set_param_attribs(SnowModel_struc(n)%sm_vege,"SMVEG",& + units="-", & + full_name="SnowModel landcover classes") + endif + enddo + + if( sm_select ) then + write(LDT_logunit,*)" - - - - - - - - - - SnowModel LSM Parameters - - - - - - - - - - - - -" + write(LDT_logunit,*)"[INFO] SnowModel Model Parameters are available for" + write(LDT_logunit,*)" specific landcover, landmask and topographic maps" + endif + + ! SnowModel specific topo-vege input parameter file + ! (Typically a Grads binary file read in the preprocess.f routine) + check_data = .false. + + call ESMF_ConfigFindLabel(LDT_config,"Snowmodel topo-veg data source:",rc=rc) + do n=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,SnowModel_struc(n)%sm_topo%source,rc=rc) + call LDT_verify(rc,"Snowmodel topo-veg data source: not defined") + + if( SnowModel_struc(n)%sm_topo%source.eq."none" ) then + SnowModel_struc(n)%sm_topo%selectOpt = 0 + SnowModel_struc(n)%sm_vege%selectOpt = 0 + endif + if( SnowModel_struc(n)%sm_topo%selectOpt.eq.1 ) then + check_data = .true. + allocate(SnowModel_struc(n)%sm_topo%value(& + LDT_rc%lnc(n),LDT_rc%lnr(n),& + SnowModel_struc(n)%sm_topo%num_bins)) + allocate(SnowModel_struc(n)%sm_vege%value(& + LDT_rc%lnc(n),LDT_rc%lnr(n),& + SnowModel_struc(n)%sm_vege%num_bins)) + endif + enddo + + if(check_data) then + write(LDT_logunit,*)"[INFO] SnowModel Topo-Vege Fields " + + call ESMF_ConfigFindLabel(LDT_config,"Snowmodel topo-veg map:",rc=rc) + do n=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,SnowModel_struc(n)%topoveg_file,rc=rc) + enddo + call ESMF_ConfigGetAttribute(LDT_config,topoveg_proj,& + label="Snowmodel topo-veg map projection:",rc=rc) + call LDT_verify(rc,'Snowmodel topo-veg map projection: option not specified in the config file') + SnowModel_struc(:)%topoveg_proj = topoveg_proj + + ! SnowModel parameter projection check: + do n=1,LDT_rc%nnest + if( LDT_rc%lis_map_proj(n) .ne. SnowModel_struc(n)%topoveg_proj ) then + write(LDT_logunit,*)"[ERR] SnowModel parameter projection should be set " + write(LDT_logunit,*)" the same as the LIS domain projection, for now. " + write(LDT_logunit,*)" Future options will be provided to process input " + write(LDT_logunit,*)" SnowModel parameters for LIS model runs." + call LDT_endrun + endif + enddo + + call ESMF_ConfigFindLabel(LDT_config,"Snowmodel topo-veg spatial transform:",rc=rc) + do n=1,LDT_rc%nnest + call ESMF_ConfigGetAttribute(LDT_config,SnowModel_struc(n)%topoveg_gridtransform,& + rc=rc) + call LDT_verify(rc,'Snowmodel topo-veg spatial transform: option not specified in the config file') + enddo + do n=1,LDT_rc%nnest + if( SnowModel_struc(n)%topoveg_gridtransform .ne. "none" ) then + write(LDT_logunit,*)"[ERR] Currently, spatial grid transform of SnowModel parameter" + write(LDT_logunit,*)" is not supported but will be in future versions." + call LDT_endrun + endif + enddo + + ! Read in SnowModel topo-veg "fill" options: + topoveg%filltype = "none" + call ESMF_ConfigGetAttribute(LDT_config, topoveg%filltype, & + label="Snowmodel topo-veg fill option:",rc=rc) + call LDT_verify(rc,"Snowmodel topo-veg fill option: option not specified in the config file") + + if( topoveg%filltype == "neighbor" ) then + call ESMF_ConfigGetAttribute(LDT_config, topoveg%fillradius, & + label="Snowmodel topo-veg fill radius:",rc=rc) + call LDT_verify(rc,"Snowmodel topo-veg fill radius: option not specified in the config file") + + call ESMF_ConfigGetAttribute(LDT_config, topoveg%fillvalue, & + label="Snowmodel topo-veg fill value:",rc=rc) + call LDT_verify(rc,"Snowmodel topo-veg fill value: option not specified in the config file") + + elseif( topoveg%filltype == "none" ) then + write(LDT_logunit,*) " -- 'NONE' Parameter-Mask Agreement Option Selected for Snowmodel topo-veg" + else + write(LDT_logunit,*) "[ERR] Fill option for Snowmodel topo-veg is not valid: ",& + trim(topoveg%filltype) + write(LDT_logunit,*) " Please select one of these: none or neighbor " + call LDT_endrun + end if + + ! Read in topo-veg map (used in original SnowModel): + do n=1,LDT_rc%nnest + select case ( SnowModel_struc(n)%sm_topo%source ) + + case ( "Grads_binary" ) + call read_SMGradsBin_topoveg(n,& + SnowModel_struc(n)%sm_topo%value, & + SnowModel_struc(n)%sm_vege%value ) + +! case ( "CONSTANT" ) +! call read_CONSTANT_topoveg(n,& +! SnowModel_struc(n)%topoveg%value) + + case default + write(LDT_logunit,*) "[ERR] SnowModel Topo-veg data source has not been selected." + write(LDT_logunit,*) " Your SnowModel LSM will not run without this parameter set." + write(LDT_logunit,*) " Please select one of the following: " + write(LDT_logunit,*) " -- Grads_binary | Native | none " + call LDT_endrun + end select + + end do + + endif + + + end subroutine SnowModelparms_init + + + subroutine SnowModelparms_writeHeader(n,ftn,dimID) + + integer :: n + integer :: ftn + integer :: dimID(3) + + if( SnowModel_struc(n)%sm%selectOpt == 1 ) then + + call LDT_writeNETCDFdataHeader(n,ftn,dimID,& + SnowModel_struc(n)%sm_topo) + + call LDT_writeNETCDFdataHeader(n,ftn,dimID,& + SnowModel_struc(n)%sm_vege) + + endif + + + end subroutine SnowModelparms_writeHeader + + subroutine SnowModelparms_writeData(n,ftn) + + integer :: n + integer :: ftn + + if( SnowModel_struc(n)%sm%selectOpt == 1 ) then + call LDT_writeNETCDFdata(n,ftn,SnowModel_struc(n)%sm_topo) + call LDT_writeNETCDFdata(n,ftn,SnowModel_struc(n)%sm_vege) + endif + + end subroutine SnowModelparms_writeData + +!BOP +! !ROUTINE: set_param_attribs +! \label{set_param_attribs} +! +! !INTERFACE: + subroutine set_param_attribs(paramEntry, short_name, & + units, full_name ) + +! !DESCRIPTION: +! This routine reads over the parameter attribute entries +! in the param_attribs.txt file. +! +! !USES: + type(LDT_paramEntry),intent(inout) :: paramEntry + character(len=*), intent(in) :: short_name + character(len=*), optional :: units + character(len=*), optional :: full_name + + character(20) :: unit_temp + character(100):: name_temp +! ____________________________________________________ + + + if(present(units)) then + unit_temp = units + else + unit_temp = "none" + endif + if(present(full_name)) then + name_temp = full_name + else + name_temp = trim(short_name) + endif + + paramEntry%short_name = trim(short_name) + paramEntry%vlevels = 1 + paramEntry%selectOpt = 1 + paramEntry%source = "SnowModel" + paramEntry%units = unit_temp + paramEntry%num_times = 1 + paramEntry%num_bins = 1 + paramEntry%standard_name = trim(name_temp) + + end subroutine set_param_attribs + +end module SnowModel_parmsMod + diff --git a/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 b/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 new file mode 100644 index 000000000..bee9a6ced --- /dev/null +++ b/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 @@ -0,0 +1,114 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_SMGradsBin_topoveg +! \label{read_SMGradsBin_topoveg} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 16Dec2021: Kristi Arsenault; Added parallel read of parameters +! +! !INTERFACE: +subroutine read_SMGradsBin_topoveg(n, array1, array2) + +! !USES: + use LDT_coreMod + use LDT_paramDataMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use SnowModel_parmsMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n ! Input nest index + real, intent(inout) :: array1(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + real, intent(inout) :: array2(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + +! !DESCRIPTION: +! This subroutine retrieves SnowModel's topo-veg data and reprojects +! it to the latlon projection. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[array1] +! output field with the retrieved topo data +! \item[array2] +! output field with the retrieved vege data +! \end{description} +!EOP + + integer :: ftn + integer :: c, r + logical :: file_exists + real, allocatable :: read_topomap(:,:) ! Read input parameters + real, allocatable :: read_vegmap(:,:) + +! ____________________________________________________________________________________ + + array1 = LDT_rc%udef + array2 = LDT_rc%udef + + inquire(file=trim(SnowModel_struc(n)%topoveg_file), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "SnowModel topo-veg map, ",& + trim(SnowModel_struc(n)%topoveg_file),", not found." + call LDT_endrun + endif + select case ( SnowModel_struc(n)%topoveg_gridtransform ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading Grads_binary topoveg file: ",& + trim(SnowModel_struc(n)%topoveg_file) + case default + write(LDT_logunit,*) "[ERR] Since the Topo-Veg field involves discrete data values," + write(LDT_logunit,*) " Please check your entries for this parameter." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=SnowModel_struc(n)%topoveg_file, & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + +! Original code from Snowmodel's preprocess.f +! open (unit=37,file=topoveg_fname, & +! form='unformatted',access='direct',recl=4*nx*ny) +! read (37,rec=1) ((topo_land(i,j),i=1,nx),j=1,ny) + + ! Read in topographic map + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + array1(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n),1) = & + read_topomap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + deallocate(read_topomap) + + ! Read in vegetation type map + allocate(read_vegmap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=2) ((read_vegmap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + array2(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n),1) = & + read_vegmap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + deallocate(read_vegmap) + + call LDT_releaseUnitNumber(ftn) + + ! Set landmask all to "=1" since SnowModel expects to have a land/water type + ! at each point in the domain: + LDT_LSMparam_struc(n)%landmask%value = 1 + LDT_LSMparam_struc(n)%dommask%value = 1 + + write(LDT_logunit, *) "[INFO] Done reading Grads_binary topo-veg file" + +end subroutine read_SMGradsBin_topoveg diff --git a/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 b/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 new file mode 100644 index 000000000..6757937bb --- /dev/null +++ b/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 @@ -0,0 +1,231 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NALCMS_SM_IGBPNCEP_lc +! \label{read_NALCMS_SM_IGBPNCEP_lc} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 03Jan2022 Kristi Arsenault; Added SM NALCMS landcover as separate field +! 13Jul2022 Kristi Arsenault; Added SM NALCMS landcover with IGBP-NCEP classes +! +! !INTERFACE: +subroutine read_NALCMS_SM_IGBPNCEP_lc( n, num_types, fgrd, maskarray ) + +! !USES: + use LDT_coreMod + use LDT_paramDataMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_index_fgrdcalc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(inout) :: num_types + real, intent(inout):: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, intent(inout):: maskarray(LDT_rc%lnc(n),LDT_rc%lnr(n)) + +! !DESCRIPTION: +! This subroutine reads in SnowModel's NALCMS landcover-derived +! SM vegtype classes and converts to the IGBP/NCEP-modified classes +! for use by Noah and NoahMP LSMs. +! +! Final mapped IGBP-NCEP classes include, +! (A) New IGBP_MODIS_BU+tundra Landcover Class Legend: +! 1 Evergreen Needleleaf Forest +! 2 Evergreen Broadleaf Forest +! 3 Deciduous Needleleaf Forest +! 4 Deciduous Broadleaf Forest +! 5 Mixed Forests +! 6 Closed Shrublands +! 7 Open Shrublands +! 8 Woody Savannas +! 9 Savannas +! 10 Grasslands +! 11 Permanent Wetland +! 12 Croplands +! 13 Urban and Built-Up +! 14 Cropland/Natural Vegetation Mosaic +! 15 Snow and Ice +! 16 Barren or Sparsely Vegetated +! 17 Ocean +! 18 Wooded Tundra +! 19 Mixed Tundra +! 20 Bare Ground Tundra +! _________________________ +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[num_types] +! number of bins (or bands) +! \item[fgrd] +! output grid fractions for landcover bins (or bands) +! \item[maskarray] +! landcover average for each bin (or band) +!EOP + + integer :: ftn + integer :: c, r, t + logical :: file_exists + real :: vegtype(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: vegtype2(LDT_rc%lnc(n),LDT_rc%lnr(n)) ! Mapped IGBP/NCEP classes + real :: vegcnt(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, allocatable :: read_topomap(:,:) ! Read input parameters + real, allocatable :: read_vegmap(:,:) ! Read input parameters +! ____________________________________________________________________________________ + + ! Assign additional land cover types, including generic water points: + LDT_rc%wetlandclass = 11 + LDT_rc%urbanclass = 13 + LDT_rc%snowclass = 15 + LDT_rc%glacierclass = 15 + LDT_rc%bareclass = 16 + LDT_rc%waterclass = 17 + + vegcnt = 0. + vegtype = float(LDT_rc%waterclass) + vegtype2 = float(LDT_rc%waterclass) + maskarray= 0.0 + fgrd = 0.0 + + inquire(file=trim(LDT_rc%vfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] The SM-based NALCMS landcover map: ",& + trim(LDT_rc%vfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%lc_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NALCMS (SnowModel-based) landcover file: ",& + trim(LDT_rc%vfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NALCMS (SnowModel-based) landcover reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%vfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + ! Read in topographic map + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + deallocate(read_topomap) + + ! Read in landcover map + allocate(read_vegmap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=2) ((read_vegmap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + vegtype(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n)) = & + read_vegmap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + deallocate(read_vegmap) + + write(LDT_logunit,*) "[INFO] SnowModel-NALCMS: Mapping SnowModel classes to IGBP-NCEP" + + ! Transform 2D landcover field to 3D + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + + ! Map SnowModel classes to the IGBP/NCEP-modified classes: + ! SnowModel Classes ==>> IGBP/NCEP-modified classes + if ( vegtype(c,r) == 1.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 2.0 ) vegtype2(c,r) = 4.0 + if ( vegtype(c,r) == 3.0 ) vegtype2(c,r) = 5.0 +! if ( vegtype(c,r) == 4.0 ) vegtype2(c,r) = 1.0 +! if ( vegtype(c,r) == 5.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 6.0 ) vegtype2(c,r) = 6.0 +! if ( vegtype(c,r) == 7.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 8.0 ) vegtype2(c,r) = 7.0 +! if ( vegtype(c,r) == 9.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 10.0 ) vegtype2(c,r) = 18.0 +! if ( vegtype(c,r) == 11.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 12.0 ) vegtype2(c,r) = 10.0 +! if ( vegtype(c,r) == 13.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 14.0 ) vegtype2(c,r) = 19.0 +! if ( vegtype(c,r) == 15.0 ) vegtype2(c,r) = 1.0 +! if ( vegtype(c,r) == 16.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 17.0 ) vegtype2(c,r) = 11.0 + if ( vegtype(c,r) == 18.0 ) vegtype2(c,r) = 16.0 + if ( vegtype(c,r) == 19.0 ) vegtype2(c,r) = 17.0 + if ( vegtype(c,r) == 20.0 ) vegtype2(c,r) = 15.0 + if ( vegtype(c,r) == 21.0 ) vegtype2(c,r) = 13.0 + if ( vegtype(c,r) == 22.0 ) vegtype2(c,r) = 12.0 +! if ( vegtype(c,r) == 23.0 ) vegtype2(c,r) = 1.0 + if ( vegtype(c,r) == 24.0 ) vegtype2(c,r) = 17.0 + + if( vegtype(c,r) == 4.0 .or. & + vegtype(c,r) == 5.0 .or. & + vegtype(c,r) == 7.0 .or. & + vegtype(c,r) == 9.0 .or. & + vegtype(c,r) == 11.0 .or. & + vegtype(c,r) == 13.0 .or. & + vegtype(c,r) == 15.0 .or. & + vegtype(c,r) == 16.0 .or. & + vegtype(c,r) == 23.0 ) then + + print *, "[WARN] We have SM class vegtypes in this domain that are " + print *, " not mapped to an IGBP/NCEP class !!! " + print *, c, r, vegtype(c,r) + endif + + if( vegtype2(c,r) .le. 0 ) then + vegtype2(c,r) = float(LDT_rc%waterclass) + endif + if( (nint(vegtype2(c,r)) .ne. LDT_rc%waterclass ) .and. & + (nint(vegtype2(c,r)) .ne. LDT_rc%udef)) then + vegcnt(c,r,NINT(vegtype2(c,r))) = 1.0 + endif + enddo + end do + + ! Estimate fraction of grid (fgrid) represented by vegetation type:: + call param_index_fgrdcalc( n, LDT_rc%lc_proj, LDT_rc%lc_gridtransform(n), & + LDT_rc%waterclass, LDT_rc%nt, vegcnt, fgrd ) + +! ------------------------------------------------------------------- +! CREATE OR READ-IN (OR IMPOSE) LAND MASK FILE AND CREATE +! SURFACE MAP +! ------------------------------------------------------------------- + + ! "READ-IN" land mask file, if user-specified: + if( LDT_rc%mask_type(n) == "readin" ) then + write(LDT_logunit,*) "[WARN] The SnowModel-based NALCMS landcover map reader " + write(LDT_logunit,*) " has not been tested with reading in and imposing an" + write(LDT_logunit,*) " outside landmask at this time. Please use with caution." + call read_maskfile( n, vegtype2, fgrd, maskarray ) + + ! "CREATE" land mask and surface type fields (user-specified): + elseif( LDT_rc%mask_type(n) == "create" ) then + call create_maskfile( n, LDT_rc%nt, LDT_rc%lc_gridtransform(n), & + vegtype2, vegcnt, maskarray ) + end if + + ! Temporary option added for NoahMP401+SM coupling: (KRA) + if( LDT_rc%allmaskland == 1 ) then + LDT_LSMparam_struc(n)%landmask%value = 1 + LDT_LSMparam_struc(n)%dommask%value = 1 + endif + ! Temporary option (KRA) + +! -- + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NALCMS landcover file" + +end subroutine read_NALCMS_SM_IGBPNCEP_lc diff --git a/ldt/params/landcover/read_NALCMS_SM_lc.F90 b/ldt/params/landcover/read_NALCMS_SM_lc.F90 new file mode 100644 index 000000000..5fec3a1d3 --- /dev/null +++ b/ldt/params/landcover/read_NALCMS_SM_lc.F90 @@ -0,0 +1,150 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NALCMS_SM_lc +! \label{read_NALCMS_SM_lc} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 03Jan2022 Kristi Arsenault; Added SM NALCMS landcover as separate field +! +! !INTERFACE: +subroutine read_NALCMS_SM_lc( n, num_types, fgrd, maskarray ) + +! !USES: + use LDT_coreMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_index_fgrdcalc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(inout) :: num_types + real, intent(inout):: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, intent(inout):: maskarray(LDT_rc%lnc(n),LDT_rc%lnr(n)) + +! !DESCRIPTION: +! This subroutine retrieves SnowModel's NALCMS landcover data files. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[num_types] +! number of bins (or bands) +! \item[fgrd] +! output grid fractions for landcover bins (or bands) +! \item[maskarray] +! landcover average for each bin (or band) +!EOP + + integer :: ftn + integer :: c, r, t + logical :: file_exists + real :: vegtype(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: vegcnt(LDT_rc%lnc(n),LDT_rc%lnr(n),LDT_rc%nt) + real, allocatable :: read_topomap(:,:) ! Read input parameters + real, allocatable :: read_vegmap(:,:) ! Read input parameters + +! ____________________________________________________________________________________ + + ! Assign additional land cover types, including generic water points: + LDT_rc%wetlandclass = 9 + LDT_rc%urbanclass = 21 + LDT_rc%snowclass = 19 + LDT_rc%glacierclass = 20 + LDT_rc%bareclass = 18 + LDT_rc%waterclass = 24 + + vegcnt = 0. + vegtype = float(LDT_rc%waterclass) + maskarray= 0.0 + fgrd = 0.0 + + inquire(file=trim(LDT_rc%vfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] The landcover map: ",& + trim(LDT_rc%vfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%lc_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NALCMS (SnowModel-based) landcover file: ",& + trim(LDT_rc%vfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NALCMS (SnowModel-based) landcover reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%vfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + ! Read in topographic map + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + deallocate(read_topomap) + + ! Read in landcover map + allocate(read_vegmap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + read(ftn,rec=2) ((read_vegmap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + vegtype(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n)) = & + read_vegmap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + deallocate(read_vegmap) + + ! Transform 2D landcover field to 3D + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + if( vegtype(c,r) .le. 0 ) then + vegtype(c,r) = float(LDT_rc%waterclass) + endif + if( (nint(vegtype(c,r)) .ne. LDT_rc%waterclass ) .and. & + (nint(vegtype(c,r)) .ne. LDT_rc%udef)) then + vegcnt(c,r,NINT(vegtype(c,r))) = 1.0 + endif + enddo + end do + + ! Estimate fraction of grid (fgrid) represented by vegetation type:: + call param_index_fgrdcalc( n, LDT_rc%lc_proj, LDT_rc%lc_gridtransform(n), & + LDT_rc%waterclass, LDT_rc%nt, vegcnt, fgrd ) + +! ------------------------------------------------------------------- +! CREATE OR READ-IN (OR IMPOSE) LAND MASK FILE AND CREATE +! SURFACE MAP +! ------------------------------------------------------------------- + + ! "READ-IN" land mask file, if user-specified: + if( LDT_rc%mask_type(n) == "readin" ) then + write(LDT_logunit,*) "[WARN] The SnowModel-based NALCMS landcover map reader " + write(LDT_logunit,*) " has not been tested with reading in and imposing an" + write(LDT_logunit,*) " outside landmask at this time. Please use with caution." + call read_maskfile( n, vegtype, fgrd, maskarray ) + + ! "CREATE" land mask and surface type fields (user-specified): + elseif( LDT_rc%mask_type(n) == "create" ) then + call create_maskfile( n, LDT_rc%nt, LDT_rc%lc_gridtransform(n), & + vegtype, vegcnt, maskarray ) + end if + +! -- + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NALCMS landcover file" + +end subroutine read_NALCMS_SM_lc diff --git a/ldt/params/topo/read_NED_SM_aspect.F90 b/ldt/params/topo/read_NED_SM_aspect.F90 new file mode 100644 index 000000000..2e29f5293 --- /dev/null +++ b/ldt/params/topo/read_NED_SM_aspect.F90 @@ -0,0 +1,171 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NED_SM_aspect +! \label{read_NED_SM_aspect} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 28Dec2021: Kristi Arsenault; Added SM NED aspect as separate field +! +! !INTERFACE: +subroutine read_NED_SM_aspect( n, num_bins, fgrd, aspectave ) + +! !USES: + use LDT_coreMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_1dbin_areacalc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: num_bins + real, intent(out):: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + real, intent(out):: aspectave(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + +! !DESCRIPTION: +! This subroutine retrieves SnowModel's NED elevation data files. +! The code in this routine is from Glen Liston's MicroMet code +! described in Liston and Elder (2006) MicroMet paper. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[num_bins] +! number of bins (or bands) +! \item[fgrd] +! output grid fractions for aspect bins (or bands) +! \item[aspectave] +! aspect average for each bin (or band) +!EOP + + integer :: ftn + integer :: c, r, t + logical :: file_exists + real, allocatable :: read_topomap(:,:) ! Read input parameters + real :: elev(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: aspect(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + +! For aspect calculation: + integer :: i,j + real :: pi, rad2deg + real :: deltax,deltay,deltaxy + real :: dzdx(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: dzdy(LDT_rc%lnc(n),LDT_rc%lnr(n)) +! ____________________________________________________________________________________ + + elev = 0. + aspect = 0. + fgrd = 0. + aspectave = 0. + + inquire(file=trim(LDT_rc%elevfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] Elevation/aspect map ",& + trim(LDT_rc%elevfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%topo_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NED (SnowModel-based) aspect file: ",& + trim(LDT_rc%elevfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NED (SnowModel-based) aspect reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%elevfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + + ! Read in topographic map + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + elev(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n)) = & + read_topomap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + + deallocate(read_topomap) + + ! From MicroMet calculations: + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + + ! Compute the average grid increment. + deltax = LDT_rc%topo_gridDesc(n,8) * 1000. ! Convert to meters + deltay = LDT_rc%topo_gridDesc(n,9) * 1000. ! Convert to meters + deltaxy = 0.5 * (deltax + deltay) + + ! Find dzdx. + do j=1,LDT_rc%lnr(n) ! ny + dzdx(1,j) = (elev(2,j) - elev(1,j)) / deltax + do i=2,LDT_rc%lnc(n)-1 ! nx + dzdx(i,j) = (elev(i+1,j) - elev(i-1,j)) / (2.0 * deltax) + enddo + dzdx(LDT_rc%lnc(n),j) = (elev(LDT_rc%lnc(n),j) - elev(LDT_rc%lnc(n)-1,j)) / deltax + enddo + + ! Find dzdy. + do i=1,LDT_rc%lnc(n) !nx + dzdy(i,1) = (elev(i,2) - elev(i,1)) / deltay + do j=2,LDT_rc%lnr(n)-1 ! ny + dzdy(i,j) = (elev(i,j+1) - elev(i,j-1)) / (2.0 * deltay) + enddo + dzdy(i,LDT_rc%lnr(n)) = (elev(i,LDT_rc%lnr(n)) - elev(i,LDT_rc%lnr(n)-1)) / deltay + enddo + + ! Calculate the terrain aspect and azimuth. + do i=1,LDT_rc%lnc(n) + do j=1,LDT_rc%lnr(n) + + ! Some compilers will not allow dzdx and dzdy to both be 0.0 in + ! the atan2 computation. + !if (abs(dzdx(i,j)).lt.1e-10) dzdx(i,j) = 1e-10 + if (abs(dzdy(i,j)).lt.1e-10) then + dzdy(i,j) = 1e-10 + endif + + ! Compute the slope azimuth, making sure that north has zero + ! azimuth. Also note that for the Ryan wind rotation, the + ! azimuth values must range from 0 to 360. +! slope_az(i,j) = rad2deg * & + aspect(i,j,1) = rad2deg * & + (3.0 / 2.0 * pi - atan2(dzdy(i,j),dzdx(i,j))) +! if (slope_az(i,j).ge.360.0) then +! slope_az(i,j) = slope_az(i,j) - 360.0 + if (aspect(i,j,1).ge.360.0) then + aspect(i,j,1) = aspect(i,j,1) - 360.0 + endif + + enddo + enddo + + + ! Transform 2D aspect field to 3D + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + do t = 1, num_bins + ! Single aspect layer, write to first bin: + if( t == 1 ) then + fgrd(c,r,t) = 1.0 + aspectave(c,r,t) = aspect(c,r,1) + endif + end do + enddo + enddo + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NED aspect file" + +end subroutine read_NED_SM_aspect diff --git a/ldt/params/topo/read_NED_SM_curvature.F90 b/ldt/params/topo/read_NED_SM_curvature.F90 new file mode 100644 index 000000000..75a9fff7f --- /dev/null +++ b/ldt/params/topo/read_NED_SM_curvature.F90 @@ -0,0 +1,180 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NED_SM_curvature +! \label{read_NED_SM_curvature} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 28Dec2021: Kristi Arsenault; Added SM NED curvature as separate field +! +! !INTERFACE: +subroutine read_NED_SM_curvature( n, curv ) + +! !USES: + use LDT_coreMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_1dbin_areacalc +#if ( defined SPMD ) + use mpi +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + real, intent(out):: curv(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + +! !DESCRIPTION: +! +! This subroutine retrieves SnowModel's NED elevation data files. +! The code in this routine is from Glen Liston's MicroMet code +! described in Liston and Elder (2006) MicroMet paper. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[curv] +! curvature average +!EOP + + integer :: ftn + integer :: c, r, t + integer :: ierr + logical :: file_exists + real, allocatable :: read_topomap(:,:) ! Read input parameters + real :: elev(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: curvature(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + +! For curvature calculation: + integer :: i, j + real :: pi, rad2deg + real :: deltax,deltay,deltaxy + real :: curve_max, curve_max_all + integer :: inc + +! The curvature is used as part of the wind model. Define a length +! scale that the curvature calculation will be performed on. This +! has units of meters, and should be approximately one-half the +! wavelength of the topographic features within the domain. +!!! (recommended default value: curve_len_scale = 500.0) + real, parameter :: curve_len_scale = 300.0 + +! ____________________________________________________________________________________ + + elev = 0. + curvature = 0. + curv = 0. + + inquire(file=trim(LDT_rc%elevfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] Elevation/curvature map ",& + trim(LDT_rc%elevfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%topo_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NED (SnowModel-based) curvature file: ",& + trim(LDT_rc%elevfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NED (SnowModel-based) curvature reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%elevfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + + ! Read in topographic map + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + elev(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n)) = & + read_topomap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + + deallocate(read_topomap) + + ! From MicroMet calculations: + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + + ! Compute the average grid increment. + deltax = LDT_rc%topo_gridDesc(n,8) * 1000. ! Convert to meters + deltay = LDT_rc%topo_gridDesc(n,9) * 1000. ! Convert to meters + deltaxy = 0.5 * (deltax + deltay) + + ! Convert the length scale to an appropriate grid increment. + inc = max(1,nint(curve_len_scale/deltaxy)) + + ! Compute the curvature. + do i=1,LDT_rc%lnc(n) ! nx + do j=1,LDT_rc%lnr(n) ! ny + + curvature(i,j,1) = (4.0 * elev(i,j) - & + elev(max(1,i-inc),max(1,j-inc)) - & + elev(min(LDT_rc%lnc(n),i+inc),min(LDT_rc%lnr(n),j+inc)) - & + elev(min(LDT_rc%lnc(n),i+inc),max(1,j-inc)) - & + elev(max(1,i-inc),min(LDT_rc%lnr(n),j+inc))) / & + (sqrt(2.0) * 16.0 * real(inc) * deltaxy) + & + (4.0 * elev(i,j) - & + elev(min(LDT_rc%lnc(n),i+inc),j) - elev(max(1,i-inc),j) - & + elev(i,min(LDT_rc%lnr(n),j+inc)) - elev(i,max(1,j-inc))) / & + (16.0 * real(inc) * deltaxy) + enddo + enddo + + ! Scale the curvature such that the max abs(curvature) has a value + ! of abs(0.5). Include a 1 mm curvature in curve_max to prevent + ! divisions by zero in flat terrain where the curvature is zero. + curve_max = 0.0 + 0.001 + do j=1,LDT_rc%lnr(n) + do i=1,LDT_rc%lnc(n) + curve_max = max(curve_max,abs(curvature(i,j,1))) + enddo + enddo + +#if (defined SPMD) + call MPI_Barrier(MPI_COMM_WORLD, ierr) + call MPI_ALLREDUCE(curve_max, curve_max_all, 1,& + MPI_REAL, MPI_MAX,& + mpi_comm_world, ierr) + curve_max = curve_max_all +#endif + + do j=1,LDT_rc%lnr(n) + do i=1,LDT_rc%lnc(n) + curvature(i,j,1) = curvature(i,j,1) / (2.0 * curve_max) + enddo + enddo + + curv = curvature + +#if 0 + ! Transform 2D curvature field to 3D + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + do t = 1, num_bins + ! Single curvature layer, write to first bin: + if( t == 1 ) then + fgrd(c,r,t) = 1.0 + curvave(c,r,t) = curvature(c,r,1) + endif + end do + enddo + enddo +#endif + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NED curvature file" + +end subroutine read_NED_SM_curvature diff --git a/ldt/params/topo/read_NED_SM_elev.F90 b/ldt/params/topo/read_NED_SM_elev.F90 new file mode 100644 index 000000000..3c6299e77 --- /dev/null +++ b/ldt/params/topo/read_NED_SM_elev.F90 @@ -0,0 +1,106 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NED_SM_elev +! \label{read_NED_SM_elev} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 20Dec2021: Kristi Arsenault; Added SM NED elevation as separate field +! +! !INTERFACE: +subroutine read_NED_SM_elev( n, num_bins, fgrd, elevave ) + +! !USES: + use LDT_coreMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_1dbin_areacalc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: num_bins + real, intent(out):: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + real, intent(out):: elevave(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + +! !DESCRIPTION: +! This subroutine retrieves SnowModel's NED elevation data files. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[num_bins] +! number of bins (or bands) +! \item[fgrd] +! output grid fractions for elevation bins (or bands) +! \item[elevave] +! elevation average for each bin (or band) +!EOP + + integer :: ftn + integer :: c, r, t + logical :: file_exists + real :: elev(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + real, allocatable :: read_topomap(:,:) ! Read input parameters + +! ____________________________________________________________________________________ + + elev = 0. + fgrd = 0. + elevave = 0. + + inquire(file=trim(LDT_rc%elevfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] Elevation map ",& + trim(LDT_rc%elevfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%topo_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NED (SnowModel-based) elevation file: ",& + trim(LDT_rc%elevfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NED (SnowModel-based) elevation reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%elevfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + + ! Read in topographic map + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + elev(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n),1) = & + read_topomap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + deallocate(read_topomap) + + ! Transform 2D elevation field to 3D + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + do t = 1, num_bins + ! Single elevation layer, write to first bin: + if( t == 1 ) then + fgrd(c,r,t) = 1.0 + elevave(c,r,t) = elev(c,r,1) + endif + end do + enddo + enddo + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NED elevation file" + +end subroutine read_NED_SM_elev diff --git a/ldt/params/topo/read_NED_SM_slope.F90 b/ldt/params/topo/read_NED_SM_slope.F90 new file mode 100644 index 000000000..3132195f2 --- /dev/null +++ b/ldt/params/topo/read_NED_SM_slope.F90 @@ -0,0 +1,164 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: read_NED_SM_slope +! \label{read_NED_SM_slope} +! +! !REVISION HISTORY: +! 16Jul2020: Kristi Arsenault; Added SnowModel topo-veg reader +! 20Dec2021: Kristi Arsenault; Added SM NED slope as separate field +! +! !INTERFACE: +subroutine read_NED_SM_slope( n, num_bins, fgrd, slopeave ) + +! !USES: + use LDT_coreMod + use LDT_logMod, only : LDT_logunit, LDT_getNextUnitNumber, & + LDT_releaseUnitNumber, LDT_endrun + use LDT_gridmappingMod + use LDT_fileIOMod + use LDT_paramTileInputMod, only: param_1dbin_areacalc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: num_bins + real, intent(out):: fgrd(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + real, intent(out):: slopeave(LDT_rc%lnc(n),LDT_rc%lnr(n),num_bins) + +! !DESCRIPTION: +! This subroutine retrieves SnowModel's NED slope data files. +! The code in this routine is from Glen Liston's MicroMet code +! described in Liston and Elder (2006) MicroMet paper. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[num_bins] +! number of bins (or bands) +! \item[fgrd] +! output grid fractions for slope bins (or bands) +! \item[slopeave] +! slope average for each bin (or band) +!EOP + + integer :: ftn + integer :: c, r, t + logical :: file_exists + real, allocatable :: read_topomap(:,:) ! Read input parameters +! real :: elev(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + real :: elev(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: slope(LDT_rc%lnc(n),LDT_rc%lnr(n),1) + +! For slope calculation: + integer :: i,j + real :: pi, rad2deg + real :: deltax,deltay,deltaxy + real :: dzdx(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: dzdy(LDT_rc%lnc(n),LDT_rc%lnr(n)) +! ____________________________________________________________________________________ + + elev = 0. + slope = 0. + fgrd = 0. + slopeave = 0. + + inquire(file=trim(LDT_rc%elevfile(n)), exist=file_exists) + if(.not.file_exists) then + write(LDT_logunit,*) "[ERR] Elevation/slope map ",& + trim(LDT_rc%elevfile(n))," not found." + call LDT_endrun + endif + + select case ( LDT_rc%topo_gridtransform(n) ) + case( "none" ) + write(LDT_logunit,*) "[INFO] Reading NED (SnowModel-based) slope file: ",& + trim(LDT_rc%elevfile(n)) + case default + write(LDT_logunit,*) "[ERR] This NED (SnowModel-based) slope reader currently" + write(LDT_logunit,*) " only supports domains the same as the set LIS run domain." + call LDT_endrun + end select + + ftn = LDT_getNextUnitNumber() + open( ftn, file=LDT_rc%elevfile(n), & + form="unformatted", access='direct',status='old', & + recl=4*LDT_rc%gnc(n)*LDT_rc%gnr(n) ) + + allocate(read_topomap(LDT_rc%gnc(n),LDT_rc%gnr(n))) + + ! Read in topographic map + read(ftn,rec=1) ((read_topomap(c,r),c=1,LDT_rc%gnc(n)),r=1,LDT_rc%gnr(n)) + + elev(1:LDT_rc%lnc(n),1:LDT_rc%lnr(n)) = & + read_topomap((LDT_ews_halo_ind(n,LDT_localPet+1)):(LDT_ewe_halo_ind(n,LDT_localPet+1)),& + (LDT_nss_halo_ind(n,LDT_localPet+1)):(LDT_nse_halo_ind(n,LDT_localPet+1))) + + deallocate(read_topomap) + + + ! From MicroMet calculations: + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + + ! Compute the average grid increment. + deltax = LDT_rc%topo_gridDesc(n,8) * 1000. ! Convert to meters + deltay = LDT_rc%topo_gridDesc(n,9) * 1000. ! Convert to meters + deltaxy = 0.5 * (deltax + deltay) + + ! Find dzdx. + do j=1,LDT_rc%lnr(n) ! ny + dzdx(1,j) = (elev(2,j) - elev(1,j)) / deltax + do i=2,LDT_rc%lnc(n)-1 ! nx + dzdx(i,j) = (elev(i+1,j) - elev(i-1,j)) / (2.0 * deltax) + enddo + dzdx(LDT_rc%lnc(n),j) = (elev(LDT_rc%lnc(n),j) - elev(LDT_rc%lnc(n)-1,j)) / deltax + enddo + + ! Find dzdy. + do i=1,LDT_rc%lnc(n) !nx + dzdy(i,1) = (elev(i,2) - elev(i,1)) / deltay + do j=2,LDT_rc%lnr(n)-1 ! ny + dzdy(i,j) = (elev(i,j+1) - elev(i,j-1)) / (2.0 * deltay) + enddo + dzdy(i,LDT_rc%lnr(n)) = (elev(i,LDT_rc%lnr(n)) - elev(i,LDT_rc%lnr(n)-1)) / deltay + enddo + + ! Calculate the terrain slope and azimuth. + do i=1,LDT_rc%lnc(n) + do j=1,LDT_rc%lnr(n) + + ! Some compilers will not allow dzdx and dzdy to both be 0.0 in + ! the atan2 computation. + !if (abs(dzdx(i,j)).lt.1e-10) dzdx(i,j) = 1e-10 + if (abs(dzdy(i,j)).lt.1e-10) then + dzdy(i,j) = 1e-10 + endif + + ! Compute the slope of the terrain. +! terrain_slope(i,j) = rad2deg * & + slope(i,j,1) = rad2deg * & + atan(sqrt(dzdx(i,j)*dzdx(i,j) + dzdy(i,j)*dzdy(i,j))) + enddo + enddo + + ! Transform 2D slope field to 3D + do r=1,LDT_rc%lnr(n) + do c=1,LDT_rc%lnc(n) + do t = 1, num_bins + ! Single slope layer, write to first bin: + if( t == 1 ) then + fgrd(c,r,t) = 1.0 + slopeave(c,r,t) = slope(c,r,1) + endif + end do + enddo + enddo + + call LDT_releaseUnitNumber(ftn) + write(LDT_logunit, *) "[INFO] Done reading SnowModel-based NED slope file" + +end subroutine read_NED_SM_slope diff --git a/ldt/params/topo/setTopoParmsFullnames.F90 b/ldt/params/topo/setTopoParmsFullnames.F90 index 44087e3e4..f2b8c4c4d 100644 --- a/ldt/params/topo/setTopoParmsFullnames.F90 +++ b/ldt/params/topo/setTopoParmsFullnames.F90 @@ -70,6 +70,9 @@ subroutine setTopoParmsFullnames(n,datatype,source) case( "MERIT_1K" ) LDT_LSMparam_struc(n)%elevation%standard_name =& "MERIT '1K' elevation" + case( "NED_SM" ) + LDT_LSMparam_struc(n)%elevation%standard_name =& + "SnowModel-based NED elevation" end select case( "slope" ) @@ -95,6 +98,9 @@ subroutine setTopoParmsFullnames(n,datatype,source) case( "MERIT_1K" ) LDT_LSMparam_struc(n)%slope%standard_name =& "MERIT '1K' slope" + case( "NED_SM" ) + LDT_LSMparam_struc(n)%slope%standard_name =& + "SnowModel-based NED-derived slope" end select case( "aspect" ) @@ -120,6 +126,9 @@ subroutine setTopoParmsFullnames(n,datatype,source) case( "MERIT_1K" ) LDT_LSMparam_struc(n)%aspect%standard_name =& "MERIT '1K' aspect" + case( "NED_SM" ) + LDT_LSMparam_struc(n)%aspect%standard_name =& + "SnowModel-based NED-derived aspect" end select case( "curvature" ) @@ -127,6 +136,9 @@ subroutine setTopoParmsFullnames(n,datatype,source) case( "GTOPO30_LIS" ) LDT_LSMparam_struc(n)%curvature%standard_name =& "GTOPO30 (LIS-based) curvature" + case( "NED_SM" ) + LDT_LSMparam_struc(n)%curvature%standard_name =& + "SnowModel-based NED-derived curvature" end select case default diff --git a/ldt/plugins/LDT_param_pluginMod.F90 b/ldt/plugins/LDT_param_pluginMod.F90 index 8b41ec458..7318e1cc6 100644 --- a/ldt/plugins/LDT_param_pluginMod.F90 +++ b/ldt/plugins/LDT_param_pluginMod.F90 @@ -78,6 +78,7 @@ subroutine LDT_LSMparam_plugin use RUC_parmsMod use JULES50_parmsMod use Crocus_parmsMod + use SnowModel_parmsMod external :: registerlsmparamprocinit external :: registerlsmparamprocwriteheader @@ -244,7 +245,7 @@ subroutine LDT_LSMparam_plugin call registerlsmparamprocwritedata(trim(LDT_jules50Id)//char(0),& JULES50Parms_writeData) - !Crocus 8.1 : + ! Crocus 8.1 : call registerlsmparamprocinit(trim(LDT_Crocus81Id)//char(0),& CrocusParms_init) call registerlsmparamprocwriteheader(trim(LDT_Crocus81Id)//char(0),& @@ -252,6 +253,14 @@ subroutine LDT_LSMparam_plugin call registerlsmparamprocwritedata(trim(LDT_Crocus81Id)//char(0),& CrocusParms_writeData) + ! SnowModel LSM: + call registerlsmparamprocinit(trim(LDT_snowmodelId)//char(0),& + SnowModelParms_init) + call registerlsmparamprocwriteheader(trim(LDT_snowmodelId)//char(0),& + SnowModelParms_writeHeader) + call registerlsmparamprocwritedata(trim(LDT_snowmodelId)//char(0),& + SnowModelParms_writeData) + end subroutine LDT_LSMparam_plugin !BOP @@ -387,6 +396,8 @@ subroutine LDT_landcover_plugin external read_CONSTANT_lc external read_SACHTET356_lc external read_CLM45_lc + external read_NALCMS_SM_lc + external read_NALCMS_SM_IGBPNCEP_lc external read_regmask_gis external read_regmask_wrsi @@ -442,6 +453,11 @@ subroutine LDT_landcover_plugin ! CLM-4.5 Landcover: call registerreadlc(trim(LDT_clm45lcId)//char(0), read_CLM45_lc) + ! SnowModel-based NALCMS Landcover: + call registerreadlc(trim(LDT_nalcmsSMlcId)//char(0), read_NALCMS_SM_lc) + ! NALCMS/SnowModel-mapped to IGBP/NCEP Landcover: + call registerreadlc(trim(LDT_nalcmsSMIGBPlcId)//char(0), read_NALCMS_SM_IGBPNCEP_lc) + ! Constant Landcover: call registerreadlc(trim(LDT_constId)//char(0), read_CONSTANT_lc) @@ -551,6 +567,11 @@ subroutine LDT_topo_plugin external read_MERIT1K_slope external read_MERIT1K_aspect + external read_NED_SM_elev + external read_NED_SM_slope + external read_NED_SM_aspect + external read_NED_SM_curvature + !- GTOPO30: call registerreadelev(trim(LDT_gtopoLISId)//char(0),read_GTOPO30_elev) call registerreadelev(trim(LDT_gtopoGFSId)//char(0),read_GTOPO30_GFS_elev) @@ -577,6 +598,12 @@ subroutine LDT_topo_plugin call registerreadslope(trim(LDT_merit1KId)//char(0),read_MERIT1K_slope) call registerreadaspect(trim(LDT_merit1KId)//char(0),read_MERIT1K_aspect) +!- NED (SnowModel file version) elevation: + call registerreadelev(trim(LDT_nedSMId)//char(0),read_NED_SM_elev) + call registerreadslope(trim(LDT_nedSMId)//char(0),read_NED_SM_slope) + call registerreadaspect(trim(LDT_nedSMId)//char(0),read_NED_SM_aspect) + call registerreadcurv(trim(LDT_nedSMId)//char(0),read_NED_SM_curvature) + end subroutine LDT_topo_plugin diff --git a/ldt/plugins/LDT_pluginIndices.F90 b/ldt/plugins/LDT_pluginIndices.F90 index c81ba0b9c..3cdf9b34e 100644 --- a/ldt/plugins/LDT_pluginIndices.F90 +++ b/ldt/plugins/LDT_pluginIndices.F90 @@ -208,6 +208,7 @@ module LDT_pluginIndices ! Snow models and data !------------------------------------------------------------------------- character*50, public, parameter :: LDT_Crocus81Id = "Crocus8.1" ! this is SURFEX version comes from surf_version.F90 + character*50, public, parameter :: LDT_snowmodelId = "SnowModel" !------------------------------------------------------------------------- ! Landcover sources @@ -227,6 +228,8 @@ module LDT_pluginIndices character*50, public, parameter :: LDT_vic411lcId = "VIC411" character*50, public, parameter :: LDT_vic412lcId = "VIC412" character*50, public, parameter :: LDT_clm45lcId = "CLM45" + character*50, public, parameter :: LDT_nalcmsSMlcId = "NALCMS_SM" + character*50, public, parameter :: LDT_nalcmsSMIGBPlcId = "NALCMS_SM_IGBPNCEP" character*50, public, parameter :: LDT_constId = "CONSTANT" !------------------------------------------------------------------------- @@ -255,6 +258,7 @@ module LDT_pluginIndices character*50, public, parameter :: LDT_srtmLISId = "SRTM_LIS" character*50, public, parameter :: LDT_srtmNATId = "SRTM_Native" character*50, public, parameter :: LDT_merit1KId = "MERIT_1K" + character*50, public, parameter :: LDT_nedSMId = "NED_SM" !------------------------------------------------------------------------- ! Soils sources diff --git a/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc b/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc index c643ac3dd..385ea8f72 100644 --- a/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc +++ b/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc @@ -414,5 +414,27 @@ mleaf: 1 kg/m2 - 0 0 0 2 0 1 # leaf biomass for each hru s0_avg: 1 mm - 0 0 0 1 0 1 # water storage in the surface soil layer ss_avg: 1 mm - 0 0 0 1 0 1 # water content of the shallow soil store sd_avg: 1 mm - 0 0 0 1 0 1 # water content of the deep soil store + +# SnowModel-specific fields: +SM_SWE: 1 m - 0 0 0 1 65 1000 # Snow Water Equivalent (kg/m2) +SM_SnowDepth: 1 m - 0 0 0 1 66 1000 # Snow depth (m) +SM_SnowDensity: 1 kg/m3 - 0 0 0 1 900 10 # Snow density (kg/m3) +SM_Snowcover: 0 - - 0 0 0 1 238 100 # Snow cover (-) +SM_SLiqFrac: 0 - - 0 0 0 1 185 1000 # Fraction of SWE in the liquid phase +SM_SWEVeg: 0 kg/m2 - 1 0 0 1 139 1000 # SWE intercepted by vegetation (kg/m2) +SM_Albedo: 1 - - 1 0 0 1 84 100 # Surface albedo (-) +SM_SAlbedo: 0 - - 0 0 0 1 184 1000 # Albedo of the snow-covered area (-) +# Other fields -- summed output: +SM_Qs: 0 m OUT 3 0 0 1 235 10000 # Surface runoff from snowpack / top-soil (m/timestep) +SM_Qsm: 0 m S2L 3 0 0 1 99 10000 # Snowmelt (kg/m2s) +SM_SubSnow: 0 m - 3 0 0 1 198 1000 # Snow sublimation (m) +SM_Snowf: 1 m DN 3 0 0 1 161 10000 # Snowfall rate (m/timestep) +SM_Rainf: 1 m DN 3 0 0 1 162 10000 # Rainfall rate (m/timestep) +SM_TotalPrecip: 1 m DN 3 0 0 1 61 10000 # Total precipitation rate (m/timestep) +# SnowModel-modified forcings: +SM_SWdown: 1 W/m2 DN 1 0 0 1 204 10 # SnowModel-modified SWdown +SM_LWdown: 1 W/m2 DN 1 0 0 1 205 10 # SnowModel-modified LWdown +SM_NWind: 1 m/s N 1 0 0 1 34 10 # SnowModel-modified NWind +SM_EWind: 1 m/s E 1 0 0 1 33 10 # SnowModel-modified EWind .... diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index da68534f4..7dc74d6a9 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -189,6 +189,33 @@ Land surface model: Noah.2.7.1 .... +`Number of subLSMs:` specifies the number of sub-level LSMs +or specialized models that may interface with other LSMs in LIS. +Entry here can be set to 1 with having a surface model type +specified, such as "LSM", and set to 1. + +.Example _lis.config_ entry +.... +Number of subLSMs: 1 +.... + +`subLSM models:` specifies the sub-level land surface model to run. +Acceptable values are: + +|==== +|Value | Description + +|none | template lsm +|Crocus8.1 | Crocus version 8.1 snow model +|SnowModel | Glen Liston's SnowModel snow model +|==== + +.Example _lis.config_ entry +.... +subLSM models: "Crocus8.1" +.... + + `Lake model:` specifies the lake model to run. Acceptable values are: @@ -368,6 +395,8 @@ Acceptable values are: |"`none`" | Do not apply topographic correction for forcing |"`lapse-rate`" | Use lapse rate correction for forcing |"`slope-aspect`" | Apply slope-aspect correction for forcing +|"`lapse-rate and slope-aspect`" | Apply both lapse-rate and slope-aspect corrections +|"`micromet`" | Apply Glen Liston's MicroMet corrections to forcing fields |==== .Example _lis.config_ entry @@ -9416,6 +9445,97 @@ AWRAL600 initial sd: 0.5 0.5 AWRAL600 initial mleaf: 0.67 0.2 .... + +[[ssec_sublsm,Sublevel land surface models]] +=== Sublevel land surface models + + +[[sssec_sublsm_snowmodel,SnowModel]] +==== SnowModel, Liston + +`SnowModel model timestep:` specifies the timestep for the run. + +See Section <> for a description +of how to specify a time interval. + +`SnowModel restart output interval:` defines the restart +writing interval for Glen Liston's SnowModel model. The typical +value used in the LIS runs is 24 hours (1da). + +See Section <> for a description +of how to specify a time interval. + +`SnowModel restart file:` specifies the SnowModel active +restart file. + +`SnowModel restart file format:` specifies the restart file +format for SnowModel. + +`SnowModel parameter file:` specifies the main SnowModel-specific +input and option parameter configuration file, which is needed +to run SnowModel. + +`SnowModel parameters source option:` specifies if SnowModel will +read in its native binary parameter files from within the SnowModel +code or what is preprocessed in LDT. LDT option supports parallel runs +Acceptable values are: + +|==== +|Value | Description + +|SnowModel | Use SnowModel built-in routines to read in +|LDT | Use the LIS SnowModel main driver to load parameters from LDT. +|==== + +`SnowModel MicroMet input source:` specifies if SnowModel will +read in its own specifically formatted binary or ASCII table forcing +files, or if LIS meteorological forcing fields will be passed in, +with the option to turn on MicroMet topographic-downscaling options +on the LIS metforcing layer side. To turn on "micromet" option in LIS, +set Topographic correction method (met forcing) to micromet. +Acceptable values are: + +|==== +|Value | Description + +|SnowModel | Readin specific SnowModel forcing files +|LIS | LIS-based meteorological forcing fields +|==== + +`Write out SnowModel forcing file fields:` specifies if you +want to write out SnowModel forcing fields generated by reading +in SnowModel-specific forcing files. This option is mainly +used when SnowModel MicroMet input source is set to SnowModel +and you run SnowModel in offline subLSM mode (no other LSMs or models +run with this submodel). Selecting 1 activates this option, and +0 indicates off. + +`SnowModel number of snow layers:` specifies the number of snow +layers that would be allowed to build within the SnowModel runtime. +This option is currently set to 1 within LIS, and must also be +activated and increased by setting the multiple layer snow model +scheme in the SnowModel option parameter file (snowmodel.par). + +`SnowModel initial snow water equivalent:` specifies the initial +snow water equivalent (SWE) value. This is currently set to +default values found in the coldstart mode for model restart reads, +based on a SnowModel initialization approach. + +.Example _lis.config_ entry +.... +SnowModel model timestep: 1hr +SnowModel restart file: ./none +SnowModel restart output interval: 1mo +SnowModel restart file format: "netcdf" +SnowModel parameter file: ./snowmodel.par +SnowModel parameters source option: LDT +SnowModel MicroMet input source: LIS +Write out SnowModel forcing file fields: 1 +SnowModel number of snow layers: 1 +SnowModel initial snow water equivalent: 0.0 +.... + + [[ssec_lakes,Lake models]] === Lake models diff --git a/lis/core/LIS_PRIV_tileMod.F90 b/lis/core/LIS_PRIV_tileMod.F90 index 01d364272..2b6f8fd0d 100644 --- a/lis/core/LIS_PRIV_tileMod.F90 +++ b/lis/core/LIS_PRIV_tileMod.F90 @@ -68,7 +68,7 @@ module LIS_PRIV_tileMod real :: elev real :: slope real :: aspect - real :: curv + real :: curvature integer :: tile_id integer :: d2g !local tile count to global tile count diff --git a/lis/core/LIS_domainMod.F90 b/lis/core/LIS_domainMod.F90 index f5a445970..26c34409a 100644 --- a/lis/core/LIS_domainMod.F90 +++ b/lis/core/LIS_domainMod.F90 @@ -52,6 +52,7 @@ module LIS_domainMod ! 17 Feb 2004 Sujay Kumar Initial Specification ! 24 Aug 2008 Sujay Kumar Implemented halo support ! 3 Aug 2012 Sujay Kumar Added support for flexible tiling +! 3 Mar 2022 Kristi Arsenault Added support for curvature tiles ! use ESMF use LIS_coreMod @@ -171,6 +172,10 @@ subroutine LIS_domain_init deallocate(LIS_topo(n)%aspect) deallocate(LIS_topo(n)%aspectfgrd) endif + if(LIS_rc%usecurvaturemap(n).ne."none") then + deallocate(LIS_topo(n)%curvature) + deallocate(LIS_topo(n)%curvfgrd) + endif enddo do n=1,LIS_rc%nnest @@ -881,6 +886,7 @@ subroutine make_domain() logical :: elev_selected logical :: slope_selected logical :: aspect_selected + logical :: curvature_selected do n=1,LIS_rc%nnest if(LIS_rc%usetexturemap(n).ne."none") then @@ -917,6 +923,13 @@ subroutine make_domain() else aspect_selected = .false. endif + + if(LIS_rc%usecurvaturemap(n).ne."none") then + curvature_selected = .true. + else + curvature_selected = .false. + endif + !----------------------------------------------------------------------- ! normalize the parameter data distributions !----------------------------------------------------------------------- @@ -957,8 +970,8 @@ subroutine make_domain() LIS_rc%aspect_minp, LIS_rc%aspect_maxt, LIS_topo(n)%aspectfgrd) endif - call create_tilespace(n,soilt_selected, soilf_selected, elev_selected, & - slope_selected, aspect_selected) + call create_tilespace(n, soilt_selected, soilf_selected, elev_selected, & + slope_selected, aspect_selected, curvature_selected) enddo end subroutine make_domain @@ -1268,7 +1281,7 @@ end subroutine calculate_domdistribution ! ! !INTERFACE: subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& - slope_selected, aspect_selected) + slope_selected, aspect_selected, curvature_selected) implicit none ! !ARGUMENTS: @@ -1278,6 +1291,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& logical, intent(in) :: elev_selected logical, intent(in) :: slope_selected logical, intent(in) :: aspect_selected + logical, intent(in) :: curvature_selected ! !DESCRIPTION: ! This routine creates the tilespace based on the specified dimensions @@ -1294,23 +1308,23 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& ! flag to indicate if soil texture based tiling is used ! \item[soilf\_selected] ! flag to indicate if soil fraction based tiling is used -! \item[soilf\_selected] -! flag to indicate if soil fraction based tiling is used ! \item[elev\_selected] ! flag to indicate if elevation based tiling is used ! \item[slope\_selected] ! flag to indicate if slope based tiling is used ! \item[aspect\_selected] ! flag to indicate if aspect based tiling is used +! \item[curvature\_selected] +! flag to indicate if curvature based tiling is used ! \end{description} !EOP real :: locallat, locallon integer :: c, r, t, m - integer :: iv, it, ie, is, ia + integer :: iv, it, ie, is, ia, ic integer :: vegt integer :: soilt real :: sand, clay, silt - real :: elev, slope, aspect + real :: elev, slope, aspect, curvature integer :: sf_index integer :: gnc, gnr integer :: kk @@ -1324,6 +1338,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& integer :: ntiles_elev integer :: ntiles_slope integer :: ntiles_aspect + integer :: ntiles_curvature integer :: ntiles_land_landmask integer :: gid real :: temp @@ -1331,6 +1346,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& integer :: elev_index integer :: slope_index integer :: aspect_index + integer :: curvature_index gnc = LIS_rc%lnc(n) @@ -1349,6 +1365,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& ntiles_elev = compute_ntiles_elev(n,c,r,elev_selected) ntiles_slope = compute_ntiles_slope(n,c,r,slope_selected) ntiles_aspect = compute_ntiles_aspect(n,c,r,aspect_selected) + ntiles_curvature = compute_ntiles_curvature(n,c,r,curvature_selected) if(soilf_selected) then LIS_rc%ntiles(n) = LIS_rc%ntiles(n)+& @@ -1364,7 +1381,6 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& ntiles_elev*& ntiles_slope*& ntiles_aspect - endif do t=1,LIS_rc%nsurfacetypes @@ -1531,6 +1547,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& ntiles_elev = compute_ntiles_elev(n,c,r,elev_selected) ntiles_slope = compute_ntiles_slope(n,c,r,slope_selected) ntiles_aspect = compute_ntiles_aspect(n,c,r,aspect_selected) + ntiles_curvature = compute_ntiles_curvature(n,c,r,curvature_selected) if(soilf_selected) then ntiles_soil = ntiles_soilf @@ -1564,6 +1581,8 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& do ia=1, ntiles_aspect call get_aspect_value(n,c,r,ia,aspect_selected,& aspect, aspect_index) + call get_curvature_value(n,c,r,ia,curvature_selected,& + curvature, curvature_index) kk = kk+1 @@ -1585,6 +1604,8 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& slope LIS_domain(n)%tile(kk)%aspect = & aspect + LIS_domain(n)%tile(kk)%curvature = & + curvature LIS_domain(n)%tile(kk)%fgrd = & LIS_LMLC(n)%landcover(c,r,vegt) @@ -1615,6 +1636,12 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& LIS_domain(n)%tile(kk)%fgrd*& LIS_topo(n)%aspectfgrd(c,r,aspect_index) endif + +! if(curvature_selected) then +! LIS_domain(n)%tile(kk)%fgrd=& +! LIS_domain(n)%tile(kk)%fgrd*& +! LIS_topo(n)%curvfgrd(c,r,curvature_index) +! endif if(sf_index.gt.0) then kk_sf(sf_index) = kk_sf(sf_index) + 1 @@ -1649,6 +1676,7 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& LIS_surface(n,sf_index)%tile(& kk_sf(sf_index))%fgrd=& LIS_LMLC(n)%landcover(c,r,vegt) + if(soilt_selected) then LIS_surface(n,sf_index)%tile(& kk_sf(sf_index))%fgrd = & @@ -1684,6 +1712,14 @@ subroutine create_tilespace(n,soilt_selected, soilf_selected, elev_selected,& kk_sf(sf_index))%fgrd * & LIS_topo(n)%aspectfgrd(c,r,aspect_index) endif + if(curvature_selected) then + LIS_surface(n,sf_index)%tile(& + kk_sf(sf_index))%fgrd = & + LIS_surface(n,sf_index)%tile(& + kk_sf(sf_index))%fgrd * & + LIS_topo(n)%curvfgrd(c,r,curvature_index) + endif + endif enddo @@ -2042,6 +2078,42 @@ function compute_ntiles_aspect(n,c,r,flag) end function compute_ntiles_aspect +!BOP +! +! !ROUTINE: compute_ntiles_curvature +! \label{compute_ntiles_curvature} +! +! !INTERFACE: + function compute_ntiles_curvature(n,c,r,flag) +! !ARGUMENTS: + integer :: n + integer :: c + integer :: r + logical :: flag +! +! !DESCRIPTION: +! This function computes the number of tiles based on the +! distribution of curvature tiles in a given grid cell +!EOP + integer :: kk + integer :: compute_ntiles_curvature + integer :: t + + kk = 0 + + if(flag) then +! do t=1,LIS_rc%ncurvbands + do t=1,1 + if(LIS_topo(n)%curvfgrd(c,r,t).gt.0.0) then + kk = kk + 1 + endif + enddo + endif + compute_ntiles_curvature = max(1,kk) + + end function compute_ntiles_curvature + + !BOP ! ! !ROUTINE: get_vegt_value @@ -2313,6 +2385,47 @@ subroutine get_aspect_value(n,c,r,i,aspect_selected,aspect,aspect_index) end subroutine get_aspect_value +!BOP +! !ROUTINE: get_curvature_value +! \label{get_curvature_value} +! +! !INTERFACE: + subroutine get_curvature_value(n,c,r,i,curvature_selected,curvature,curvature_index) +! !ARGUMENTS: + integer :: n + integer :: c + integer :: r + integer :: i + logical :: curvature_selected + real :: curvature + integer :: curvature_index +! +! !DESCRIPTION: +! This routine computes the curvature value for given tile number +! and grid cell. +!EOP + integer :: t + integer :: kk + + curvature = -1 + curvature = -1 + if(curvature_selected) then + kk = 0 +! do t=1, LIS_rc%naspectbands + do t=1, 1 + if(LIS_topo(n)%curvfgrd(c,r,t).gt.0.0) then + kk = kk + 1 + if(kk.eq.i) then + curvature = LIS_topo(n)%curvature(c,r,t) + curvature_index = t + return + endif + end if + enddo + endif + + end subroutine get_curvature_value + !BOP ! !ROUTINE: readDomainInput ! \label{readDomainInput} diff --git a/lis/core/LIS_histDataMod.F90 b/lis/core/LIS_histDataMod.F90 index bcdcc9537..9ce65558e 100644 --- a/lis/core/LIS_histDataMod.F90 +++ b/lis/core/LIS_histDataMod.F90 @@ -487,6 +487,26 @@ module LIS_histDataMod public :: LIS_MOC_SNOWSURFACEQ !public :: LIS_MOC_SNOWWIND_DIR +! SnowModel outputs: + public :: LIS_MOC_SWE_SM + public :: LIS_MOC_SNOWDEPTH_SM + public :: LIS_MOC_SNOWDENSITY_SM + public :: LIS_MOC_QSM_SM + public :: LIS_MOC_SUBSNOW_SM + public :: LIS_MOC_QS_SM + public :: LIS_MOC_TOTALPRECIP_SM + public :: LIS_MOC_RAINF_SM + public :: LIS_MOC_SNOWF_SM + public :: LIS_MOC_ALBEDO_SM + public :: LIS_MOC_ELEVATION_SM + public :: LIS_MOC_LANDCOVER_SM + + public :: LIS_MOC_SWDOWNFORC_SM + public :: LIS_MOC_LWDOWNFORC_SM + public :: LIS_MOC_EWINDFORC_SM + public :: LIS_MOC_NWINDFORC_SM +! ....... + integer :: LIS_MOC_SNOW_SOOT = -9999 integer :: LIS_MOC_GRND_SNOW = -9999 integer :: LIS_MOC_SURFT_SNOW = -9999 @@ -973,6 +993,25 @@ module LIS_histDataMod integer :: LIS_MOC_SNOWDELTAHEAT = -9999 integer :: LIS_MOC_SNOWSURFACEQ = -9999 +! SnowModel outputs: + integer :: LIS_MOC_SWE_SM = -9999 + integer :: LIS_MOC_SNOWDEPTH_SM = -9999 + integer :: LIS_MOC_SNOWDENSITY_SM = -9999 + integer :: LIS_MOC_QSM_SM = -9999 + integer :: LIS_MOC_SUBSNOW_SM = -9999 + integer :: LIS_MOC_QS_SM = -9999 + integer :: LIS_MOC_TOTALPRECIP_SM = -9999 + integer :: LIS_MOC_RAINF_SM = -9999 + integer :: LIS_MOC_SNOWF_SM = -9999 + integer :: LIS_MOC_ALBEDO_SM = -9999 + integer :: LIS_MOC_ELEVATION_SM = -9999 + integer :: LIS_MOC_LANDCOVER_SM = -9999 + integer :: LIS_MOC_SWDOWNFORC_SM = -9999 + integer :: LIS_MOC_LWDOWNFORC_SM = -9999 + integer :: LIS_MOC_EWINDFORC_SM = -9999 + integer :: LIS_MOC_NWINDFORC_SM = -9999 +! ....... + #if 0 ! SPECIAL CASE INDICES @@ -1481,7 +1520,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SNOWF,& LIS_histData(n)%head_lsm_list,& - n,2,ntiles,(/"kg/m2s","kg/m2 "/),& +! n,2,ntiles,(/"kg/m2s","kg/m2 "/),& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA 2,(/"UP","DN"/),2,1,1,& model_patch=.true.) endif @@ -1494,7 +1534,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_RAINF,& LIS_histData(n)%head_lsm_list,& - n,2,ntiles,(/"kg/m2s","kg/m2 "/),& +! n,2,ntiles,(/"kg/m2s","kg/m2 "/),& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA 2,(/"UP","DN"/),2,1,1,& model_patch=.true.) endif @@ -1533,7 +1574,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_QS,& LIS_histData(n)%head_lsm_list,& - n,2,ntiles,(/"kg/m2s","kg/m2 "/),& +! n,2,ntiles,(/"kg/m2s","kg/m2 "/),& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA 2,(/"IN ","OUT"/),2,1,1,& model_patch=.true.) endif @@ -1577,7 +1619,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_QSM,& LIS_histData(n)%head_lsm_list,& - n,2,ntiles,(/"kg/m2s","kg/m2 "/),& +! n,2,ntiles,(/"kg/m2s","kg/m2 "/),& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA 2,(/"S2L","L2S"/),2,1,1,& model_patch=.true.) endif @@ -2184,7 +2227,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SUBSNOW,& LIS_histData(n)%head_lsm_list,n,& - 5,ntiles,(/"kg/m2s","mm/hr ","W/m2 ","mm ", "kg/m2 "/),& +! 5,ntiles,(/"kg/m2s","mm/hr ","W/m2 ","mm ", "kg/m2 "/),& + 6,ntiles,(/"kg/m2s","mm/hr ","W/m2 ","mm ", "kg/m2 ","m "/),& ! KRA 1,(/"-"/),2,1,1,& model_patch=.true.) endif @@ -4164,7 +4208,8 @@ subroutine LIS_histDataInit(n, ntiles) if ( rc == 1 ) then call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_TOTALPRECIP,& LIS_histData(n)%head_lsm_list,& - n,2,ntiles,(/"kg/m2s","kg/m2 "/),& +! n,2,ntiles,(/"kg/m2s","kg/m2 "/),& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA 2,(/"UP","DN"/),2,1,1,& model_patch=.true.) endif @@ -5200,7 +5245,223 @@ subroutine LIS_histDataInit(n, ntiles) model_patch=.true.) endif -! snow model +!<-- SnowModel outputs --> +! integer :: LIS_MOC_SWE_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_SWE:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_SWE",& + "liquid_water_content_of_surface_snow",& + "snow water equivalent",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SWE_SM,& + LIS_histData(n)%head_lsm_list,& + n,2,ntiles,(/"kg/m2","m "/),1,(/"-"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_SNOWDEPTH_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_SnowDepth:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_SnowDepth",& + "snow_depth",& + "snow depth",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SNOWDEPTH_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"m ", "cm", "mm"/),1,(/"-"/),1,1,1,& + model_patch=.true.) + ! cm is added for VIC, Shugong Wang 02/20/2012 + endif + +! integer :: LIS_MOC_SNOWDENSITY_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_SnowDensity:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_SnowDensity",& + "snow_density_for_each_layer",& + "snow density for each layer",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SNOWDENSITY_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"kg/m3"/),1,(/"-"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_QSM_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Qsm:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Qsm",& + "snowmelt",& + "snowmelt",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_QSM_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA + 2,(/"S2L","L2S"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_QS_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Qs:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Qs",& + "surface_runoff_amount",& + "surface runoff",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_QS_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA + 2,(/"IN ","OUT"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_SUBSNOW_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_SubSnow:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_SubSnow",& + "snow_sublimation",& + "snow sublimation",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SUBSNOW,& + LIS_histData(n)%head_lsm_list,n,& + 6,ntiles,(/"kg/m2s","mm/hr ","W/m2 ","mm ", "kg/m2 ","m "/),& ! KRA + 1,(/"-"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_TOTALPRECIP_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_TotalPrecip:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_TotalPrecip",& + "total_precipitation_amount",& + "total precipitation amount",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_TOTALPRECIP_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA + 2,(/"UP","DN"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_RAINF_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Rainf:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Rainf",& + "precipitation_rate",& + "precipitation rate",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_RAINF_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA + 2,(/"UP","DN"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_SNOWF_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Snowf:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Snowf",& + "snowfall_rate",& + "snowfall rate",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SNOWF_SM,& + LIS_histData(n)%head_lsm_list,& + n,3,ntiles,(/"kg/m2s","kg/m2 ","m "/),& ! KRA + 2,(/"UP","DN"/),2,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_ALBEDO_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Albedo:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Albedo",& + "surface_albedo",& + "surface albedo",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_ALBEDO_SM,& + LIS_histData(n)%head_lsm_list,& + n,2,ntiles,(/"-","%"/),1,(/"-"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_ELEVATION_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Elevation:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list, & + "SM_Elevation",& + "elevation",& + "elevation",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_ELEVATION_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"m"/),1,(/"-"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_LANDCOVER_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_Landcover:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list,& + "SM_Landcover",& + "landcover",& + "landcover",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_LANDCOVER_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"-"/),1,(/"-"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_SWDOWNFORC_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_SWdown:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list,& + "SM_SWdown",& + "sm_swdown",& + "Snowmodel-modified shortwave radiation",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_SWDOWNFORC_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"W/m2"/),2,(/"UP", "DN"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_LWDOWNFORC_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_LWdown:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list,& + "SM_LWdown",& + "sm_lwdown",& + "Snowmodel-modified longwave radiation",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_LWDOWNFORC_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"W/m2"/),2,(/"UP", "DN"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_NWINDFORC_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_NWind:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list,& + "SM_NWind",& + "sm_nwind",& + "Snowmodel-modified N-S wind direction",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_NWINDFORC_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"m/s"/),2,(/"E", "N"/),1,1,1,& + model_patch=.true.) + endif + +! integer :: LIS_MOC_EWINDFORC_SM = -9999 + call ESMF_ConfigFindLabel(modelSpecConfig,"SM_EWind:",rc=rc) + call get_moc_attributes(modelSpecConfig, LIS_histData(n)%head_lsm_list,& + "SM_EWind",& + "sm_ewind",& + "Snowmodel-modified E-W wind direction",rc) + if ( rc == 1 ) then + call register_dataEntry(LIS_MOC_LSM_COUNT,LIS_MOC_EWINDFORC_SM,& + LIS_histData(n)%head_lsm_list,& + n,1,ntiles,(/"m/s"/),2,(/"E", "N"/),1,1,1,& + model_patch=.true.) + endif + +! ......... !<- RUC addition -> diff --git a/lis/core/LIS_metforcingMod.F90 b/lis/core/LIS_metforcingMod.F90 index 2af3e47e2..367a75ccd 100644 --- a/lis/core/LIS_metforcingMod.F90 +++ b/lis/core/LIS_metforcingMod.F90 @@ -1077,7 +1077,7 @@ subroutine LIS_get_met_forcing(n) ! \item[LIS\_slopeAspectCorrection](\ref{LIS_slopeAspectCorrection}) \newline ! method to apply slope aspect based topographical corrections ! \item[LIS\_microMetCorrection](\ref{LIS_microMetCorrection}) \newline -! method to apply topographical corrections (not currently supported) +! method to apply topographical corrections (updated with latest code) ! \end{description} !EOP @@ -1132,10 +1132,35 @@ subroutine LIS_get_met_forcing(n) call LIS_lapseRateCorrection(n, LIS_forc(n,m)%modelelev,& LIS_FORC_Base_State(n,m)) call LIS_slopeAspectCorrection(n, LIS_FORC_Base_State(n,m)) + + ! New MicroMet option: + elseif(LIS_rc%met_ecor(m).eq."micromet") then + + if( LIS_rc%useelevationmap(n) == "none" .or. & + LIS_rc%useslopemap(n) == "none" .or. & + LIS_rc%useaspectmap(n) == "none" .or. & + LIS_rc%usecurvaturemap(n) == "none" ) then + + write(LIS_logunit,*) "[ERR] 'micromet' turned on for" + write(LIS_logunit,*) "[ERR] the forcing dataset, ",trim(LIS_rc%metforc(m)),"," + write(LIS_logunit,*) "[ERR] ... Though NO LDT-generated topo fields read in ... " + write(LIS_logunit,*) "[ERR] This LIS run is ending ..." + call LIS_endrun + endif + + call LIS_MicroMetCorrection(n, LIS_forc(n,m)%modelelev,& + LIS_FORC_Base_State(n,m)) + + elseif( LIS_rc%met_ecor(m) .eq. "micromet and slope-aspect" ) then + write(LIS_logunit,*) "[ERR] Slope-aspect correction option not supported " + write(LIS_logunit,*) "[ERR] with micromet, since the micromet option accounts" + write(LIS_logunit,*) "[ERR] for slope, aspect and curvature corrections." + write(LIS_logunit,*) "[ERR] Please check lis.config.adoc for options." + call LIS_endrun end if enddo -!blending algorithms (overlay, forcing ensembles, bias correction..) + ! Blending algorithms (overlay, forcing ensembles, bias correction..) if(LIS_rc%metforc_blend_alg.eq."overlay") then ! simple overlays call overlayForcings(n) elseif(LIS_rc%metforc_blend_alg.eq."ensemble") then !forcing ensembles diff --git a/lis/core/LIS_microMetCorrection.F90 b/lis/core/LIS_microMetCorrection.F90 index 73d923cae..ab012027e 100644 --- a/lis/core/LIS_microMetCorrection.F90 +++ b/lis/core/LIS_microMetCorrection.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.3 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2020 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- @@ -14,120 +14,812 @@ ! !REVISION HISTORY: ! ! 21 Dec 2004: Sujay Kumar; Initial Specification +! 21 Jan 2021: Kristi Arsenault; Update to the code, based on SnowModel +! 22 Mar 2022: Kristi Arsenault; Completed code updates ! ! !INTERFACE: -subroutine LIS_microMetCorrection(nest) +subroutine LIS_microMetCorrection(n, modelelev, LIS_FORC_Base_State) ! !USES: - use LIS_logMod, only : LIS_logunit + use LIS_logMod + use ESMF + use LIS_mpiMod + use LIS_constantsMod + use LIS_coreMod + use LIS_FORC_AttributesMod implicit none ! !ARGUMENTS: - integer, intent(in) :: nest + integer, intent(in) :: n ! Nest index + real :: modelelev(LIS_rc%ngrid(n)) + type(ESMF_State) :: LIS_FORC_Base_State +! ! !DESCRIPTION: -! Corrects Temperature, Pressure, Humidity and Longwave Radiation -! values for topography (based on Liston et al; 2005) +! Uses the MicroMet topographic downscaling methods to correct +! temperature, pressure, humidity, shortwave +! and longwave radiation, and wind field redistribution, +! based on: ! -! WARNING: This routine is not currently implemented +! Ref: +! Liston, G. E., & Elder, K. (2006). A Meteorological Distribution System for High-Resolution +! Terrestrial Modeling (MicroMet), Journal of Hydrometeorology, 7(2), 217-234. +! https://journals.ametsoc.org/view/journals/hydr/7/2/jhm486_1.xml ! ! The arguments are: ! \begin{description} -! \item[nest] -! index of the nest +! \item[n] +! index of the n +! \item [modelelev] +! forcing elevation ! \end{description} !EOP -#if 0 - real, parameter ::a=611.21,b=22.452, c=240.97, pi = 3.14 - real, parameter :: grav = 9.81, rdry = 287., Sstar=1367.0 - real, parameter :: sigma = 5.67E-8 - integer :: t - real :: lapse(12),tdlapse(12) - real :: force_tmp,force_hum,force_prs,elevdiff - real :: force_pcp,force_swd, hcforce - real :: pcforce,Td,tcforce,tbar,e - real :: theta, omegas, thetad, wind, Ww,force_u, force_v - real :: sigma_c, zenith, dec,tau,mu,cosi, psi_dir,psi_dif - real :: lhour,czenith - real :: force_lwd, ea, epsilona,epsilonb - integer :: zone - real :: elev700, T700, Td700,Rh700,es - data lapse/0.0044,0.0059,0.0071,0.0078,0.0081,0.0082,0.0081,& - 0.0081,0.0077,0.0068,0.0055,0.0047/ - data tdlapse/0.00041,0.00042,0.00040,0.00039,0.00038,0.00036,& - 0.00033,0.00033,0.00036,0.00037,0.00040,0.00040/ - - do t=1,lis%ngrid(nest) - force_tmp = lisdom(nest)%grid(t)%forcing(1) - force_hum = lisdom(nest)%grid(t)%forcing(2) - force_v = lisdom(nest)%grid(t)%forcing(6) - force_u = lisdom(nest)%grid(t)%forcing(5) - force_swd = lisdom(nest)%grid(t)%forcing(3) - force_prs = lisdom(nest)%grid(t)%forcing(7) - force_pcp = lisdom(nest)%grid(t)%forcing(8) - elevdiff = lisdom(nest)%grid(t)%elev-modelelev(t) - tcforce = force_tmp-lapse(lis%mo)*elevdiff - tbar=(force_tmp+tcforce)/2. - - pcforce =force_prs/(exp((grav*elevdiff)/(rdry*tbar))) - e = force_hum*force_prs/(0.622+force_hum*0.378) - Td = c*log((e/a))/(b-log((e/a))) - Td = Td -tdlapse(lis%mo)*c*elevdiff/b - e = a*exp((b*Td)/(c+Td)) - hcforce = 0.622*e/(pcforce - 0.378*e) - theta = 3*pi/2-atan(force_v/force_u) - omegas = grid(t)%slope*cos(theta-grid(t)%aspect) - Ww = 1+0.5*omegas+0.5*grid(t)%curv - wind = Ww*sqrt(force_u*force_u + force_v*force_v) - thetad = -0.5*omegas*sin(2*(grid(t)%aspect-theta)) - force_u = -wind*sin(theta+thetad) - force_v = -wind*cos(theta+thetad) - force_pcp = force_pcp*((1+0.00035*elevdiff)/(1-0.00035*elevdiff)) - -! Longwave similar to agrmet implementation. - ea = e * 0.01 - epsilona = 0.70 + (5.95e-5 * ea * exp(1500 / tcforce)) - epsilonb = -0.792 + (3.161 * epsilona) - (1.573 * epsilona * epsilona) - force_lwd = epsilonb*5.67E-8*(tcforce)**4 - -!shortwave - elev700 = modelelev(t)+(70000-force_prs)/(1.29*9.8) -! elev700 = rdry*force_tmp*log(force_prs/70000)/grav -! elev700 = 5537.0986-modelelev(t) - elev700 = elev700-modelelev(t) - T700 = force_tmp-lapse(lis%mo)*elev700-273.16 - e = force_hum*force_prs/(0.622) - Td = c*log((e/a))/(b-log((e/a))) - Td700 = Td -tdlapse(lis%mo)*c*elev700/b - e = a*exp(b*Td700/(c+Td700)) - es = a*exp(b*T700/(c+T700)) - Rh700 = 100* e/es - sigma_c = 0.832*exp((Rh700-100)/41.6) - if(sigma_c > 1) sigma_c = 1.0 - call localtime(lis%gmt,lisdom(nest)%grid(t)%lon,lhour,zone) - call coszenith(lisdom(nest)%grid(t)%lon,lisdom(nest)%grid(t)%lat,lhour,zone,lis%doy,& - czenith,dec,tau) - zenith = acos(czenith) - mu = asin(cos(dec)*sin(tau)/sin(zenith)) - cosi = cos(lisdom(nest)%grid(t)%slope)*cos(zenith)+sin(lisdom(nest)%grid(t)%slope)*sin(zenith)*& - cos(mu-lisdom(nest)%grid(t)%aspect) -! psi_dir = (1-sigma_c)*(0.6-0.2*cos(zenith)) -! psi_dif = sigma_c*(0.3-0.1*cos(zenith)) - psi_dir = 0.85-0.65*sigma_c - psi_dif = 0.15+0.65*sigma_c -! force_swd = Sstar*(psi_dir*cosi+psi_dif*cos(zenith)) - force_swd = force_swd*(psi_dir*cos(grid(t)%slope)+psi_dir*& - sin(grid(t)%slope)*tan(zenith)*cos(mu-grid(t)%aspect)+& - psi_dif) - - lisdom(nest)%grid(t)%forcing(1) = tcforce - lisdom(nest)%grid(t)%forcing(2) = hcforce - lisdom(nest)%grid(t)%forcing(3) = force_swd - lisdom(nest)%grid(t)%forcing(4) = force_lwd - lisdom(nest)%grid(t)%forcing(7) = pcforce - lisdom(nest)%grid(t)%forcing(5) = force_u - lisdom(nest)%grid(t)%forcing(6) = force_v - lisdom(nest)%grid(t)%forcing(8) = force_pcp - enddo + + integer :: t, k, row, col, i, j, gindex, gid + real :: force_tmp, tcforce ! Input, corrected temperature + real :: force_hum, hcforce ! Input, corrected spec humidity + real :: force_prs, pcforce ! Input, corrected pressure + real :: force_lwd, lcforce ! Input, corrected LW down rad + real :: force_swd, scforce ! Input, corrected SW down rad + real :: force_pcp, pptforce ! Input, corrected precip + real :: force_u, uwcforce ! Input, corrected U-wind comp. + real :: force_v, vwcforce ! Input, corrected U-wind comp. + + real :: elevdiff, elevdiff2 + real :: Td, tbar, e, Tdcforce + + integer :: mbefore, mafter + real :: xlat, xlon, weight + real :: T_lapse_rate, Td_lapse_rate + real :: precip_lapse_rate, precip_lapse_rate_m, alfa + real :: theta, omegas, thetad, wind, Ww + real :: sigma_c, zenith, dec,tau,mu,cosi, psi_dir,psi_dif + real :: lhour,czenith + real :: ea, epsilona,epsilonb + real :: mee, mfe, ee, fe, ratio + real :: femiss,emiss + real :: elev700, T700, Td700, Rh700, es + real :: deg2rad, rad2deg + real :: wslope_max, wslopemax_glb, curve_max, curvemax_glb + real :: slope, aspect, curvature + real :: dirdiff, xmult + real :: deltax, deltay, deltaxy, inc, topo + +! B1=17.502 ==> over water, following Buck (1981) reference +! B2=22.452 ==> over ice + real, parameter :: A=611.21, B1=17.502, B2=22.452, C=240.97 + real, parameter :: grav = 9.81, rdry = 287., Sstar=1367.0 + real, parameter :: sigma = 5.67E-8 + real, parameter :: Tf = 273.16 + integer, parameter :: bb=2016 + + ! Cloud-cover parameters: + real, parameter :: topo_ref_cloud = 3000. + real, parameter :: press_ratio = 0.7 + real, parameter :: dx_walcek = 80.0 + real :: f_max, one_minus_RHe, f_1 + real :: delta_topo700, Td_700, Tair_700, rh_700 + real :: e_700, es_700, cloud_frac + + ! Longwave radiation parameters: + real, parameter :: Stef_Boltz = 5.6696e-8 + real, parameter :: alfa_lw = 1.083 + ! - Constants required for Iziomon et al. (2003). + real, parameter :: E1 = 200.0, X1 = 0.35, Y1 = 0.100, Z1 = 0.224 + real, parameter :: E2 = 1500.0, X2 = 0.43, Y2 = 0.115, Z2 = 0.320 + real, parameter :: E3 = 3000.0, X3 = 0.51, Y3 = 0.130, Z3 = 1.100 + ! - Assume the X and Y coefficients increase linearly to 3000 m, + ! and adjust Z to create a best fit to the CLPX data. + real :: Xs, Ys, Zs, emiss_cloud + + ! Shortwave radiation parameters: + real, parameter :: solar_const = 1370. + real, parameter :: days_yr = 365.25 + real, parameter :: Trop_Can = 0.41 + real, parameter :: solstice = 173. + real :: xhour, xxhour ! model decimal hour + real :: sol_dec, hr_angl, cos_Z, sin_Z, cos_i + real :: sun_azimuth, slope_az_S0 + real :: trans_direct, trans_diffuse + real :: Qsi_trans_dir, Qsi_trans_dif, Qsi_direct, Qsi_diffuse + + + ! Month parameters: + integer, parameter :: months = 12 + integer lastday(months) + data lastday/31,28,31,30,31,30,31,31,30,31,30,31/ + + ! MicroMet monthly lapse rates (Liston and Kelly, 2006): + real lapse_rate(months) + real lapse_rate_nohem(months) + real lapse_rate_sohem(months) + data lapse_rate_nohem /0.0044,0.0059,0.0071,0.0078,0.0081,0.0082,& + 0.0081,0.0081,0.0077,0.0068,0.0055,0.0047/ + data lapse_rate_sohem /0.0081,0.0081,0.0077,0.0068,0.0055,0.0047,& + 0.0044,0.0059,0.0071,0.0078,0.0081,0.0082/ + ! Atmospheric vapor pressure coeffs are in units of km-1 + ! Following Liston and Kelly (2006) + real am(months) + real am_nohem(months) + real am_sohem(months) + data am_nohem /0.41,0.42,0.40,0.39,0.38,0.36,& + 0.33,0.33,0.36,0.37,0.40,0.40/ + data am_sohem /0.33,0.33,0.36,0.37,0.40,0.40,& + 0.41,0.42,0.40,0.39,0.38,0.36/ + + ! The precipitation lapse rate units are in km-1. + real prec_lapse_rate(months) + real precip_lapse_rate_nohem(months) + real precip_lapse_rate_sohem(months) + data precip_lapse_rate_nohem /0.35,0.35,0.35,0.30,0.25,0.20,& + & 0.20,0.20,0.20,0.25,0.30,0.35/ + data precip_lapse_rate_sohem /0.20,0.20,0.20,0.25,0.30,0.35,& + & 0.35,0.35,0.35,0.30,0.25,0.20/ + + ! Avoid problems of zero (low) winds (for example, turbulence + ! theory, log wind profile, etc., says that we must have some + ! wind. Thus, some equations blow up when the wind speed gets + ! very small). This number defines the value that any wind speed + ! below this gets set to. From snowmodel.par file ... + real, parameter :: windspd_min = 0.1 + + ! The curvature and wind_slope values range between -0.5 and +0.5. + ! Valid slopewt and curvewt values are between 0 and 1, with + ! values of 0.5 giving approximately equal weight to slope and + ! curvature. Glen Liston suggests that slopewt and curvewt be set such + ! that slopewt + curvewt = 1.0. This will limit the total + ! wind weight to between 0.5 and 1.5 (but this is not required). + real, parameter :: slopewt = 0.58 + real, parameter :: curvewt = 0.42 + integer :: loops_windwt_smoother + + ! The curvature is used as part of the wind model. Define a length + ! scale that the curvature calculation will be performed on. This + ! has units of meters, and should be approximately one-half the + ! wavelength of the topographic features within the domain. + real, parameter :: curve_len_scale = 300.0 + + ! 2D wind fields to apply smoother: + real, allocatable :: windspd(:,:), winddir(:,:) + real, allocatable :: wind_slope(:,:), windwt(:,:) + real, allocatable :: curv2d(:,:) + + ! ESMF metforcing states: + integer :: status, ierr + type(ESMF_Field) :: tmpField, q2Field, lwdField, psurfField + type(ESMF_Field) :: swdField, pcpField, uField, vField + real, pointer :: tmp(:),q2(:),lwd(:),psurf(:) + real, pointer :: swd(:),pcp(:),uwind(:),vwind(:) + +! ............................................................. + + ! ESMF calls for primary metforcing fields + ! Temperature + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Tair%varname(1)),tmpField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for tmp in LIS_microMetCorrection') + + call ESMF_FieldGet(tmpField,localDE=0, farrayPtr=tmp,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for tmp in LIS_microMetCorrection') + + ! Surface pressure + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Psurf%varname(1)),psurfField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for psurf in LIS_microMetCorrection') + + call ESMF_FieldGet(psurfField,localDE=0, farrayPtr=psurf,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for psurf in LIS_microMetCorrection') + + ! Spec humidity + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Qair%varname(1)),q2Field,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for q2air in LIS_microMetCorrection') + + call ESMF_FieldGet(q2Field,localDE=0, farrayPtr=q2,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for q2air in LIS_microMetCorrection') + + ! LW down radiation + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_LWdown%varname(1)),lwdField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for lwdown in LIS_microMetCorrection') + + call ESMF_FieldGet(lwdField,localDE=0, farrayPtr=lwd,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for lwdown in LIS_microMetCorrection') + + ! SW down radiation + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_SWdown%varname(1)),swdField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for swdown in LIS_microMetCorrection') + + call ESMF_FieldGet(swdField,localDE=0, farrayPtr=swd,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for swdown in LIS_microMetCorrection') + + ! Total precip (or rainfall) + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Rainf%varname(1)),pcpField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for pcp in LIS_microMetCorrection') + + call ESMF_FieldGet(pcpField,localDE=0, farrayPtr=pcp,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for pcp in LIS_microMetCorrection') + + ! U-wind component: + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Wind_E%varname(1)),uField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for uwind in LIS_microMetCorrection') + + call ESMF_FieldGet(uField,localDE=0, farrayPtr=uwind,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for uwind in LIS_microMetCorrection') + + ! V-wind component: + call ESMF_StateGet(LIS_FORC_Base_State,& + trim(LIS_FORC_Wind_N%varname(1)),vField,& + rc=status) + call LIS_verify(status,'Error in ESMF_StateGet for vwind in LIS_microMetCorrection') + + call ESMF_FieldGet(vField,localDE=0, farrayPtr=vwind,rc=status) + call LIS_verify(status,'Error in ESMF_FieldGet for vwind in LIS_microMetCorrection') + +! ............................................................. + + ! For topographic wind distribution calculation + deg2rad = LIS_CONST_PI / 180.0 + rad2deg = 180.0 / LIS_CONST_PI + + ! Cloud cover fraction calculations (for LWdown and SWdown): + ! Walcek coefficients. + f_max = 78.0 + dx_walcek/15.5 + one_minus_RHe = 0.196 + (0.76-dx_walcek/2834.0) * (1.0 - press_ratio) + f_1 = f_max * (press_ratio - 0.1) / 0.6 / 100.0 + + ! Compute the solar declination angle (radians). + sol_dec = Trop_Can * cos(2.*LIS_CONST_PI * (real(LIS_rc%doy) - solstice)/days_yr) + + ! Find the month before and after the day in question. + ! - For monthly lapse rate selection. + if (LIS_rc%da.le.15) then + mbefore = LIS_rc%mo - 1 + if (mbefore.eq.0) mbefore = 12 + mafter = LIS_rc%mo + weight = (real(lastday(mbefore)) - 15. + real(LIS_rc%da)) / & + & real(lastday(mbefore)) + else + mbefore = LIS_rc%mo + mafter = LIS_rc%mo + 1 + if (mafter.eq.13) mafter = 1 + weight = (real(LIS_rc%da) - 15.) / real(lastday(mbefore)) + endif + +! --- + ! Loop over model-space tiles: + do t=1,LIS_rc%ntiles(n) + + gindex = LIS_domain(n)%tile(t)%index + xlat = LIS_domain(n)%grid(gindex)%lat + xlon = LIS_domain(n)%grid(gindex)%lon + slope = LIS_domain(n)%tile(t)%slope + aspect = LIS_domain(n)%tile(t)%aspect + curvature = LIS_domain(n)%tile(t)%curvature ! Now included in LDT output + + if(tmp(t).gt.0) then + force_tmp = tmp(t) + force_prs = psurf(t) + force_hum = q2(t) + force_pcp = pcp(t) + force_lwd = lwd(t) + force_swd = swd(t) + force_u = uwind(t) + force_v = vwind(t) + + ! Read-in lapse rate correction monthly values: + ! (from MicroMet code: get_lapse_rates routine) + ! Air, dewpoint temperature, and precipitation. + do k=1,months + if( xlat.lt.0.0 ) then ! Southern Hemisphere + lapse_rate(k) = lapse_rate_sohem(k) ! Temp + am(k) = am_sohem(k) ! Td + prec_lapse_rate(k) = precip_lapse_rate_sohem(k) ! Precip + else ! Northern Hemisphere + lapse_rate(k) = lapse_rate_nohem(k) + am(k) = am_nohem(k) + prec_lapse_rate(k) = precip_lapse_rate_nohem(k) + endif + enddo + + ! Define the temperature lapse rate (Kelvin/1000m). + T_lapse_rate = (- (weight * lapse_rate(mafter) + & + (1. - weight) * lapse_rate(mbefore))) + + ! Define the dew-point temperature lapse rate (deg C/m). + Td_lapse_rate = (- ((weight * am(mafter) + & + (1. - weight) * am(mbefore)) * C)) / (B1 * 1000.0) ! MicroMet + + ! Define the precipitation lapse rate (km-1). + precip_lapse_rate = weight * prec_lapse_rate(mafter) + & + (1. - weight) * prec_lapse_rate(mbefore) + + ! Calculate elev diff between hi-res elev and forcing elev + elevdiff = LIS_domain(n)%tile(t)%elev-& + modelelev(gindex) + ! --- + ! (1) T2air (tmp | tcforce) : Perform lapse-rate correction on temperature: + tcforce = force_tmp+(T_lapse_rate*elevdiff) + + ! --- + ! (2) Surface Pressure (psurf | pcforce) + ! Pressure - elevation change (from Cosgrove et. al (2003): + tbar=(force_tmp+tcforce)/2. + pcforce=force_prs/(exp((LIS_CONST_G*elevdiff)/(rdry*tbar))) + + ! --- + ! (3) Relative humidity (q2 | hcforce) + ! Perform lapse-rate correction on humidity fields: + ! Compute water vapor pressure from spec humidity and pressure + e = force_hum*force_prs / (0.622+0.378*force_hum) + + Td = C*log((e/A))/(B1-log((e/A))) + Tf ! matches MicroMet equation + Tdcforce = Td + (Td_lapse_rate*elevdiff) ! final corrected dewpoint temp + + ! Convert back to spec hum from Td (MicroMet) + e = A*exp((B1*(Tdcforce-Tf))/(C+(Tdcforce-Tf))) + hcforce = (0.622*e) / (pcforce - (0.378*e)) + + ! --- + ! (4) Precipitation (pcp | pptforce) + ! Use a precipitation "lapse rate", or adjust the precipitation on + ! the actual elevation grid. The reason the interpolated station elevations + ! are used as the topographic reference surface (instead of something + ! like sea level), is because precip adjustment factor is a non-linear + ! function of elevation difference. + ! + ! The adjustment factor that is used comes from: Thornton, P. E., + ! S. W. Running, and M. A. White, 1997: Generating surfaces of + ! daily meteorological variables over large regions of complex + ! terrain. J. Hydrology, 190, 214-251. + + ! Convert the precipitation "lapse rate" (km-1) to m-1. + precip_lapse_rate_m = precip_lapse_rate / 1000.0 + + ! Apply Glen Liston's original precipitation increase with + ! elevation scheme. Also, we could implement (in the future) + ! Ward van Pelt's scheme (see van Pelt et al. 2016). + ! Don't let the elevation difference be greater than some number + ! (like 1800 meters gives a factor of 4.4). If it is too large + ! you get huge precipitation adjustment, a divide by zero, or + ! even negative adjustments for high elevations). + + elevdiff2 = min(elevdiff,1800.0) + alfa = precip_lapse_rate_m * elevdiff2 + pptforce = force_pcp * (1.0 + alfa)/(1.0 - alfa) + pptforce = max(0.0,pptforce) ! Ensure no negative precip values + + ! --- + ! Incoming/Downward Radiation Fields: + ! --- + ! Cloud cover fraction calculations (for LWdown and SWdown): + delta_topo700 = topo_ref_cloud - LIS_domain(n)%tile(t)%elev + Td_700 = Tdcforce + Td_lapse_rate * delta_topo700 + Tair_700 = tcforce + T_lapse_rate * delta_topo700 + + ! Convert each Td to a gridded relative humidity (0-1). + e_700 = A * exp((B1 * (Td_700 - Tf))/(C + (Td_700 - Tf))) + es_700 = A * exp((B1 * (Tair_700 - Tf))/(C + (Tair_700 - Tf))) + rh_700 = e_700/es_700 + rh_700 = min(1.0,rh_700) + rh_700 = max(0.0,rh_700) + + ! Use this RH at 700 mb to define the cloud fraction (0-1). + cloud_frac = f_1 * exp((rh_700 - 1.0)/one_minus_RHe) + + ! --- + ! (5) Longwave radiation (lwd | lcforce) -- MicroMet: + ! Compute Qli following Iziomon et al. (2003). + if( LIS_domain(n)%tile(t)%elev.lt.E1 ) then + Xs = X1 + Ys = Y1 + Zs = Z1 + elseif( LIS_domain(n)%tile(t)%elev.gt.E2) then + Xs = X3 + Ys = Y3 + Zs = Z3 + else + Xs = X1 + (LIS_domain(n)%tile(t)%elev - E1) * (X3 - X1)/(E3 - E1) + Ys = Y1 + (LIS_domain(n)%tile(t)%elev - E1) * (Y3 - Y1)/(E3 - E1) + Zs = Z1 + (LIS_domain(n)%tile(t)%elev - E1) * (Z3 - Z1)/(E3 - E1) + endif + + emiss_cloud = alfa_lw * & + (1.0 - Xs * exp((- Ys) * e/tcforce)) * & + (1.0 + Zs * cloud_frac**2) + emiss_cloud = min(1.0,emiss_cloud) + + lcforce = emiss_cloud * Stef_Boltz * tcforce**4 +#if 0 + ! From Cogsrove et al. (2003) -- + ee = (force_hum*force_prs)/0.622 + fe = (hcforce*pcforce)/0.622 + mee = ee/100. + mfe = fe/100. + !---------------------------------------------------------------------- + ! correct for negative vapor pressure at very low temperatures at + ! high latitudes + !---------------------------------------------------------------------- + if (mee .le. 0) mee = 1e-08 + if (mfe .le. 0) mfe = 1e-08 + emiss = 1.08*(1-exp(-mee**(force_tmp/bb))) + femiss = 1.08*(1-exp(-mfe**(tcforce/bb))) + ratio = (femiss*(tcforce**4))/(emiss*(force_tmp**4)) + lcforce= force_lwd*ratio +#endif + + ! --- + ! (6) Shortwave radiation (swd | scforce) -- MicroMet: + ! "solar" routine from MicroMet calculates the "local" SWdown, and + ! only set up for radiation values for <= 3 hour model timestep. + + ! In solar radiation, adjust the time to correspond to the + ! local time at this longitude position. + xxhour = LIS_rc%hr + xlon / 15.0 + if (xxhour.ge.24.0) xxhour = xxhour - 24.0 + if (xxhour.lt.0.0) xxhour = xxhour + 24.0 + + ! Compute the sun's hour angle (radians). + hr_angl = (xxhour * 15.0 - 180.0) * deg2rad + + ! Compute cos_Z. Note that the sin of the solar elevation angle, + ! sin_alfa, is equal to the cosine of the solar zenith angle, + ! cos_Z. + cos_Z = sin(sol_dec) * sin(xlat * deg2rad) + & + cos(sol_dec) * cos(xlat * deg2rad) * cos(hr_angl) + cos_Z = max(0.0,cos_Z) + + ! Account for clouds, water vapor, pollution, etc. + trans_direct = (0.6 + 0.2 * cos_Z) * (1.0 - cloud_frac) + trans_diffuse = (0.3 + 0.1 * cos_Z) * cloud_frac + + ! Compute the solar radiation transmitted through the atmosphere. + Qsi_trans_dir = solar_const * trans_direct + Qsi_trans_dif = solar_const * trans_diffuse + + ! COMPUTE THE CORRECTIONS TO ALLOW FOR TOPOGRAPHIC SLOPE AND ASPECT. + ! The sine of the solar zenith angle. + sin_Z = sqrt(1.0 - cos_Z*cos_Z) + + ! Azimuth of the sun, with south having zero azimuth for the + ! northern hemisphere. + sun_azimuth = asin(max(-1.0,min(1.0,cos(sol_dec)*sin(hr_angl)/sin_Z))) + if (xlat.lt.0.0) then + sun_azimuth = - sun_azimuth + endif + + ! Make the corrections so that the angles below the local horizon + ! are still measured from the normal to the slope. + if (xlat.ge.0.0) then + if (hr_angl.lt.0.0) then + if (hr_angl.lt.sun_azimuth) sun_azimuth = - LIS_CONST_PI - sun_azimuth + elseif (hr_angl.gt.0.0) then + if (hr_angl.gt.sun_azimuth) sun_azimuth = LIS_CONST_PI - sun_azimuth + endif + endif + + ! Build, from the variable with north having zero azimuth, a + ! slope_azimuth value with south having zero azimuth. Also + ! make north have zero azimuth if in the southern hemsisphere. + if (xlat.ge.0.0) then + if( aspect.ge.180.0 ) then + slope_az_S0 = aspect - 180.0 + else + slope_az_S0 = aspect + 180.0 + endif + else + slope_az_S0 = aspect + endif + + ! Compute the angle between the normal to the slope and the angle + ! at which the direct solar radiation impinges on the sloping + ! terrain (radians). + cos_i = cos(slope * deg2rad) * cos_Z + & + sin(slope * deg2rad) * sin_Z * & + cos(sun_azimuth - slope_az_S0 * deg2rad) + + ! Adjust the topographic correction due to local slope so that + ! the correction is zero if the sun is below the local horizon + ! (i.e., the slope is in the shade) or if the sun is below the + ! global horizon. + if (cos_i.lt.0.0) cos_i = 0.0 + if (cos_Z.le.0.0) cos_i = 0.0 + + ! Adjust the solar radiation for slope, etc. + Qsi_direct = cos_i * Qsi_trans_dir + Qsi_diffuse = cos_Z * Qsi_trans_dif + + ! Combine the direct and diffuse solar components. + scforce = Qsi_direct + Qsi_diffuse + + ! ------------------------------------ + ! Convert back to LIS-model tile space: + tmp(t) = tcforce + psurf(t) = pcforce + q2(t) = hcforce + pcp(t) = pptforce + lwd(t) = lcforce + swd(t) = scforce + + endif + enddo + + ! --- + ! (7/8) Wind fields (uwind | uwcforce; vwind | vwcforce) + + ! Convert domain dx, dy into meters: + if( LIS_domain(n)%dx <= 1.) then ! Temp. solution for lat/lon dx,dy + deltax = LIS_domain(n)%dx*100000. + deltay = LIS_domain(n)%dy*100000. + else + deltax = LIS_domain(n)%dx*1000. + deltay = LIS_domain(n)%dy*1000. + endif + + ! Smooth the wind weighting factor to eliminate any sharp speed + ! increases resulting from the merging of the curve wt and the + ! slope wt. Define the number of times this is done to be a + ! function of the curvature length scale and the grid increment. + ! The first 0.5 here just means that half of the caclulated + ! number appears to be about right (additional loops with this + ! smoother does not change the results much). If there are + ! unwanted wave features in the snow distribution, this 0.5 + ! factor can be increased to 1.0 or more, to get rid of these + ! waves. Also see "loops_snowd_smoother" in snowtran_code.f90. + ! xmult = 0.5 | xmult = 1.5 + xmult = 1.0 ! Based on MicroMet code + + loops_windwt_smoother = nint(xmult * curve_len_scale / & + (0.5 * (deltax + deltay))) + + ! Set up the 2D wind fields needed: + allocate( windspd(LIS_rc%lnc(n),LIS_rc%lnr(n)),winddir(LIS_rc%lnc(n),LIS_rc%lnr(n)) ) + allocate( wind_slope(LIS_rc%lnc(n),LIS_rc%lnr(n)),windwt(LIS_rc%lnc(n),LIS_rc%lnr(n)) ) + allocate( curv2d(LIS_rc%lnc(n),LIS_rc%lnr(n)) ) + + windspd = LIS_rc%udef + winddir = LIS_rc%udef + wind_slope = LIS_rc%udef + windwt = LIS_rc%udef + curv2d = LIS_rc%udef + + ! Loop over model-space tiles and convert key wind fields to 2D: + do t=1,LIS_rc%ntiles(n) + col = LIS_domain(n)%tile(t)%col + row = LIS_domain(n)%tile(t)%row + + slope = LIS_domain(n)%tile(t)%slope + aspect = LIS_domain(n)%tile(t)%aspect + curvature = LIS_domain(n)%tile(t)%curvature ! Now included in LDT output + curv2d(col,row) = LIS_domain(n)%tile(t)%curvature + + ! Convert these u and v components to speed and directions. + if(tmp(t).gt.0) then + force_u = uwind(t) + force_v = vwind(t) + + ! Some compilers do not allow both u and v to be 0.0 in the atan2 computation. + if( abs(force_u).lt.1e-10 ) force_u = 1e-10 + winddir(col,row) = rad2deg * atan2(force_u,force_v) + if( winddir(col,row).ge.180.0 ) then + winddir(col,row) = winddir(col,row) - 180.0 + else + winddir(col,row) = winddir(col,row) + 180.0 + endif + windspd(col,row) = sqrt(force_u**2 + force_v**2) + + ! Modify the wind speed and direction according to simple wind-topography + ! From "topo_mod_winds" subroutine in micromet_code.f90. + ! + ! Compute the wind modification factor which is a function of + ! topography and wind direction following Liston and Sturm (1998). + + ! Compute the slope in the direction of the wind. + wind_slope(col,row) = deg2rad * slope * & + cos(deg2rad * (winddir(col,row) - aspect)) + + endif + enddo + + ! Scale the wind slope such that the max abs(wind slope) has a value + ! of abs(0.5). Include a 1 mm slope in slope_max to prevent + ! divisions by zero in flat terrain where the slope is zero. + wslope_max = 0.0 + 0.001 + do j=1,LIS_rc%lnr(n) + do i=1,LIS_rc%lnc(n) + wslope_max = max(wslope_max,abs(wind_slope(i,j))) + enddo + enddo + +! Search for global "max" of wslope_max value for all parallel subdomains: +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(wslope_max, wslopemax_glb, 1,& + MPI_REAL, MPI_MAX, LIS_mpi_comm, ierr) + wslope_max = wslopemax_glb #endif - write(LIS_logunit,*) 'This routine is not currently supported' +! ----- + + ! Apply global slope max to 2D wind_slope calculation: + do j=1,LIS_rc%lnr(n) + do i=1,LIS_rc%lnc(n) + + wind_slope(i,j) = wind_slope(i,j) / (2.0 * wslope_max) + + ! Calculate the wind speed and direction adjustments. The + ! curvature and wind_slope values range between -0.5 and +0.5. + ! Valid slopewt and curvewt values are between 0 and 1, with + ! values of 0.5 giving approximately equal weight to slope and + ! curvature. Glen Liston suggests that slopewt and curvewt be set such + ! that slopewt + curvewt = 1.0. This will limit the total + ! wind weight to between 0.5 and 1.5 (but this is not required). + + ! Compute the wind weighting factor -- dependent on wind direction input. + windwt(i,j) = 1.0 + slopewt * wind_slope(i,j) + curvewt * curv2d(i,j) + + enddo + enddo + + ! Don't apply smoothing if the domain is arbitrarily small (<=100 gnc, gnr). + if (LIS_rc%gnc(n).gt.100 .and. LIS_rc%gnr(n).gt.100) then + do k=1,loops_windwt_smoother + call wind_smoother(LIS_rc%lnc(n),LIS_rc%lnr(n),windwt) !<-- windwt(nc,nr) + enddo + endif + + ! Complete final calculations and translation back to 1D tilespace: + do t=1,LIS_rc%ntiles(n) + i = LIS_domain(n)%tile(t)%col + j = LIS_domain(n)%tile(t)%row + aspect = LIS_domain(n)%tile(t)%aspect + + if(tmp(t).gt.0) then + + ! Generate the terrain-modified wind speed. + windspd(i,j) = windwt(i,j) * windspd(i,j) + + ! Modify the wind direction according to Ryan (1977). Note that it + ! is critical that "dirdiff" handles the cases where the slope + ! azimuth and the wind direction are on different sides of the + ! 360-0 line. + if( aspect.gt.270.0 .and. winddir(i,j).lt.90.0 ) then + dirdiff = aspect - winddir(i,j) - 360.0 + elseif( aspect.lt.90.0 .and. winddir(i,j).gt.270.0 ) then + dirdiff = aspect - winddir(i,j) + 360.0 + else + dirdiff = aspect - winddir(i,j) + endif + if( abs(dirdiff).le.90.0 ) then + winddir(i,j) = winddir(i,j) - 0.5 * min(wind_slope(i,j)*rad2deg,45.0) * & + sin(deg2rad * (2.0 * dirdiff)) + if( winddir(i,j).gt.360.0 ) then + winddir(i,j) = winddir(i,j) - 360.0 + elseif( winddir(i,j).lt.0.0 ) then + winddir(i,j) = winddir(i,j) + 360.0 + endif + endif + + ! Avoid problems of zero (low) winds (for example, turbulence theory, + ! log wind profile, etc., says that we must have some wind. Thus, + ! some equations blow up when the wind speed gets very small. + if( windspd(i,j).lt.windspd_min ) then + windspd(i,j) = windspd_min + endif + + ! Final conversion back to corrected uwind and vwind components: + uwcforce = (- windspd(i,j)) * sin(deg2rad*winddir(i,j)) + vwcforce = (- windspd(i,j)) * cos(deg2rad*winddir(i,j)) + + uwind(t) = uwcforce + vwind(t) = vwcforce + + endif + enddo + + deallocate( windspd, winddir ) + deallocate( wind_slope, windwt, curv2d ) + + write(LIS_logunit,*) '[INFO] MicroMet forcing topographic downscaling completed' end subroutine LIS_microMetCorrection + + +subroutine wind_smoother (nx, ny, weight) + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: nx, ny + real, intent(inout) :: weight(nx,ny) +! +! !DESCRIPTION: +! +! Routine performs a 9-point smoothing operation. +! +! The result at each grid point is a weighted average of the grid +! point and the surrounding 8 points. The center point receives +! a weight of 1.0, the points at each side and above and below +! receive a weight of 0.5, and corner points receive a weight of +! 0.3. All points are multiplied by their weights and summed, +! then divided by the total weight. +! +! Ref: +! Liston, G. E., & Elder, K. (2006). A Meteorological Distribution System for High-Resolution +! Terrestrial Modeling (MicroMet), Journal of Hydrometeorology, 7(2), 217-234. +! https://journals.ametsoc.org/view/journals/hydr/7/2/jhm486_1.xml + + integer :: i,j + real :: weight_tmp(nx,ny) + + ! Do the interior. + do i=2,nx-1 + do j=2,ny-1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + & + weight(i,j+1) + weight(i-1,j) + weight(i+1,j)) + 0.3 *& + (weight(i-1,j-1) + weight(i+1,j+1) + weight(i-1,j+1) +& + weight(i+1,j-1))) / 4.2 + enddo + enddo + + ! Do the sides. + j = 1 + do i=2,nx-1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j+1) + weight(i-1,j) +& + weight(i+1,j)) + 0.3 * (weight(i+1,j+1) + weight(i-1,j+1))) / 3.1 + enddo + + j = ny + do i=2,nx-1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + weight(i-1,j) +& + weight(i+1,j)) + 0.3 * (weight(i+1,j-1) + weight(i-1,j-1))) / 3.1 + enddo + + i = 1 + do j=2,ny-1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + weight(i,j+1) +& + weight(i+1,j)) + 0.3 * (weight(i+1,j-1) + weight(i+1,j+1))) / 3.1 + enddo + + i = nx + do j=2,ny-1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + weight(i,j+1) +& + weight(i-1,j)) + 0.3 * (weight(i-1,j-1) + weight(i-1,j+1))) / 3.1 + enddo + + ! Do the corners. + i = 1 + j = 1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j+1) + weight(i+1,j)) +& + 0.3 * weight(i+1,j+1)) / 2.3 + + i = nx + j = 1 + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j+1) + weight(i-1,j)) +& + 0.3 * weight(i-1,j+1)) / 2.3 + + i = 1 + j = ny + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + weight(i+1,j)) +& + 0.3 * weight(i+1,j-1)) / 2.3 + + i = nx + j = ny + weight_tmp(i,j) = (weight(i,j) + 0.5 * (weight(i,j-1) + weight(i-1,j)) +& + 0.3 * weight(i-1,j-1)) / 2.3 + + ! Return the smoothed array. + do i=1,nx + do j=1,ny + weight(i,j) = weight_tmp(i,j) + enddo + enddo + +end subroutine diff --git a/lis/core/LIS_sublsm_FTable.c b/lis/core/LIS_sublsm_FTable.c index 639ba17e9..5103e4a81 100644 --- a/lis/core/LIS_sublsm_FTable.c +++ b/lis/core/LIS_sublsm_FTable.c @@ -368,6 +368,80 @@ void FTN(sublsmfinalize)(char *j,int len) current->func(); } +//BOP +// !ROUTINE: registersublsmreset +// \label{registersublsmreset} +// +// !INTERFACE: +void FTN(registersublsmreset)(char *j, void (*func)(),int len) +// +// !DESCRIPTION: +// Creates an entry in the registry for the routine +// to cleanup allocated structures specific to the +// land surface model +// +// \begin{description} +// \item[j] +// name of the LSM +// \end{description} +// +//EOP +{ + int len1; + struct sublsmresetnode* current; + struct sublsmresetnode* pnode; + // create node + + len1 = len + 1; // ensure that there is space for terminating null + pnode=(struct sublsmresetnode*) malloc(sizeof(struct sublsmresetnode)); + pnode->name=(char*) calloc(len1,sizeof(char)); + strncpy(pnode->name,j,len); + pnode->func = func; + pnode->next = NULL; + + if(sublsmreset_table == NULL){ + sublsmreset_table = pnode; + } + else{ + current = sublsmreset_table; + while(current->next!=NULL){ + current = current->next; + } + current->next = pnode; + } +} +//BOP +// !ROUTINE: sublsmreset +// \label{sublsmreset} +// +// !INTERFACE: +void FTN(sublsmreset)(char *j,int len) +// +// !DESCRIPTION: +// Invokes the routine from the registry for cleaning up +// allocated structures specific to the land surface model +// +// \begin{description} +// \item[j] +// name of the LSM +// \end{description} +// +//EOP +{ + struct sublsmresetnode* current; + + current = sublsmreset_table; + while(strcmp(current->name,j)!=0){ + current = current->next; + if(current==NULL) { + printf("****************Error****************************\n"); + printf("reset routine for LSM %s is not defined\n",j); + printf("program will seg fault.....\n"); + printf("****************Error****************************\n"); + } + } + current->func(); +} //BOP // !ROUTINE: registersublsmsetup diff --git a/lis/core/LIS_topoMod.F90 b/lis/core/LIS_topoMod.F90 index 8c685f4f9..81255d48f 100644 --- a/lis/core/LIS_topoMod.F90 +++ b/lis/core/LIS_topoMod.F90 @@ -47,6 +47,7 @@ module LIS_topoMod real, allocatable :: aspect(:,:,:) real, allocatable :: aspectfgrd(:,:,:) real, allocatable :: curvature(:,:,:) + real, allocatable :: curvfgrd(:,:,:) end type topo_type_dec type(topo_type_dec), allocatable :: LIS_topo(:) @@ -93,9 +94,9 @@ subroutine LIS_topo_init() call read_aspect(n) endif -! if(LIS_rc%usecurvaturemap(n).ne."none") then -! call read_curvature(n) -! endif + if(LIS_rc%usecurvaturemap(n).ne."none") then + call read_curvature(n) + endif enddo end subroutine LIS_topo_init @@ -500,5 +501,112 @@ subroutine read_aspect(n) end subroutine read_aspect +!BOP +! +! !ROUTINE: read_curvature +! \label{read_curvature} +! +! !REVISION HISTORY: +! 03 Sept 2004: Sujay Kumar; Initial Specification +! 23 Mar 2022: K.R. Arsenault; Added curvature +! +! !INTERFACE: + subroutine read_curvature(n) +! !USES: +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + use LIS_coreMod, only : LIS_rc, LIS_localPet,& + LIS_ews_ind, LIS_ewe_ind,& + LIS_nss_ind, LIS_nse_ind, LIS_ews_halo_ind,LIS_ewe_halo_ind, & + LIS_nss_halo_ind, LIS_nse_halo_ind + use LIS_logMod, only : LIS_logunit, LIS_getNextUnitNumber, & + LIS_releaseUnitNumber, LIS_endrun, LIS_verify + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + +! !DESCRIPTION: +! This subroutine reads the curvature data +! +! The arguments are: +! \begin{description} +! \item[n] +! index of n +! \item[locallc] +! landlc for the region of interest +! \end{description} +! +!EOP + integer :: ios1 + integer :: ios,nid,ntypesId,ncId, nrId + integer :: curvid, curvfgrdId + integer :: nc,nr,c,r + logical :: file_exists + +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + + inquire(file=LIS_rc%paramfile(n), exist=file_exists) + if(file_exists) then + + write(LIS_logunit,*)'[INFO] Reading curvature map from '& + //trim(LIS_rc%paramfile(n)) + + ios = nf90_open(path=LIS_rc%paramfile(n),& + mode=NF90_NOWRITE,ncid=nid) + call LIS_verify(ios,'Error in nf90_open in read_curvature') + + ios = nf90_inq_dimid(nid,"east_west",ncId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_curvature') + + ios = nf90_inq_dimid(nid,"north_south",nrId) + call LIS_verify(ios,'Error in nf90_inq_dimid in read_curvature') + +! ios = nf90_inq_dimid(nid,"curvbins",ntypesId) +! call LIS_verify(ios,'Error in nf90_inq_dimid in read_curvature') + + ios = nf90_inquire_dimension(nid,ncId, len=nc) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_curvature') + + ios = nf90_inquire_dimension(nid,nrId, len=nr) + call LIS_verify(ios,'Error in nf90_inquire_dimension in read_curvature') + +! ios = nf90_inquire_dimension(nid,ntypesId, len=LIS_rc%curvbands) +! call LIS_verify(ios,'Error in nf90_inquire_dimension in read_curvature') + + allocate(LIS_topo(n)%curvature(LIS_rc%lnc(n),LIS_rc%lnr(n), & + 1)) + allocate(LIS_topo(n)%curvfgrd(LIS_rc%lnc(n),LIS_rc%lnr(n), & + 1)) + + ios = nf90_inq_varid(nid,'CURVATURE',curvid) + call LIS_verify(ios,'CURVATURE field not found in the LIS param file') + + + ios = nf90_get_var(nid,curvid,LIS_topo(n)%curvature,& + start=(/LIS_ews_halo_ind(n,LIS_localPet+1),& + LIS_nss_halo_ind(n,LIS_localPet+1),1/),& + count=(/LIS_rc%lnc(n),LIS_rc%lnr(n),1/)) + call LIS_verify(ios,'Error in nf90_get_var in read_aspect') + + do r = 1,LIS_rc%lnr(n) + do c = 1,LIS_rc%lnc(n) + if( LIS_topo(n)%curvature(c,r,1) .ne. LIS_rc%udef ) then + LIS_topo(n)%curvfgrd(c,r,1) = 1.0 + else + LIS_topo(n)%curvfgrd(c,r,1) = 0.0 + endif + enddo + enddo + + else + write(LIS_logunit,*) '[ERR] curvature map in: ',LIS_rc%paramfile(n), & + ' does not exist.' + call LIS_endrun + endif +#endif + + end subroutine read_curvature end module LIS_topoMod diff --git a/lis/make/default.cfg b/lis/make/default.cfg index 4d33fd877..b569c6981 100644 --- a/lis/make/default.cfg +++ b/lis/make/default.cfg @@ -1685,7 +1685,7 @@ macro: SM_GEOWRSI_2 path: surfacemodels/land/geowrsi.2 [LSM RDHM.3.5.6] -enabled: True +enabled: False macro: SM_RDHM_3_5_6 path: surfacemodels/land/rdhm.3.5.6, surfacemodels/land/rdhm.3.5.6/sac, @@ -1711,6 +1711,13 @@ path: surfacemodels/land/subLSM/crocus.8.1, surfacemodels/land/subLSM/crocus.8.1/phys, surfacemodels/land/subLSM/crocus.8.1/cplLSM +[SNOWMODEL] +enabled: True +macro: SM_SNOWMODEL +path: surfacemodels/land/subLSM/snowmodel, + surfacemodels/land/subLSM/snowmodel/physics, + surfacemodels/land/subLSM/snowmodel/cplLSM + [Flake.1.0] enabled: False macro: SM_FLAKE_1_0 diff --git a/lis/plugins/LIS_pluginIndices.F90 b/lis/plugins/LIS_pluginIndices.F90 index 074c87c35..0f751369d 100644 --- a/lis/plugins/LIS_pluginIndices.F90 +++ b/lis/plugins/LIS_pluginIndices.F90 @@ -89,11 +89,12 @@ module LIS_pluginIndices character*50, public, parameter :: LIS_cableId = "CABLE" character*50, public, parameter :: LIS_fasstId = "FASST" !character*50, public, parameter :: LIS_sheelsId = "SHEELS" - character*50, public, parameter :: LIS_clsmf25Id = "CLSM F2.5" - character*50, public, parameter :: LIS_geowrsi2Id = "GeoWRSI.2" + character*50, public, parameter :: LIS_clsmf25Id = "CLSM F2.5" + character*50, public, parameter :: LIS_geowrsi2Id = "GeoWRSI.2" character*50, public, parameter :: LIS_rdhm356lsmId = "RDHM.3.5.6" character*50, public, parameter :: LIS_summa1Id = "SUMMA.1.0" - character*50, public, parameter :: LIS_Crocus81Id = "Crocus8.1" + character*50, public, parameter :: LIS_Crocus81Id = "Crocus8.1" + character*50, public, parameter :: LIS_snowmodelId = "SnowModel" !------------------------------------------------------------------------- ! Lake models diff --git a/lis/plugins/LIS_sublsm_pluginMod.F90 b/lis/plugins/LIS_sublsm_pluginMod.F90 index 1ff87760a..f30a82a5e 100644 --- a/lis/plugins/LIS_sublsm_pluginMod.F90 +++ b/lis/plugins/LIS_sublsm_pluginMod.F90 @@ -20,7 +20,8 @@ module LIS_sublsm_pluginMod ! model computations, corresponding to each of the LSMs used in LIS. ! ! !REVISION HISTORY: -! 09 Oct 03 Sujay Kumar Initial Specification +! 09 Oct 2003 Sujay Kumar Initial Specification +! 12 Aug 2021 Kristi Arsenault Added SnowModel ! !EOP implicit none @@ -44,73 +45,73 @@ module LIS_sublsm_pluginMod ! \begin{description} ! \item[Initialization] ! Definition of LSM variables -! (to be registered using {\tt registerlsminit} and later called -! using {\tt lsminit}) +! (to be registered using {\tt registersublsminit} and later called +! using {\tt sublsminit}) ! \item[Setup] ! Initialization of parameters -! (to be registered using {\tt registerlsmsetup} and later called -! using {\tt lsmsetup}) +! (to be registered using {\tt registersublsmsetup} and later called +! using {\tt sublsmsetup}) ! \item[Run] ! Routines to execute LSM on a single gridcell for single timestep -! (to be registered using {\tt registerlsmrun} and later called -! using {\tt lsmrun}) +! (to be registered using {\tt registersublsmrun} and later called +! using {\tt sublsmrun}) ! \item[Read restart] ! Routines to read a restart file for an LSM run -! (to be registered using {\tt registerlsmrestart} and later called -! using {\tt lsmrestart}) +! (to be registered using {\tt registersublsmrestart} and later called +! using {\tt sublsmrestart}) ! \item[Forcing transfer to model tiles] ! Routines to transfer an array of given forcing to model tiles -! (to be registered using {\tt registerlsmf2t} and later called -! using {\tt lsmf2t}) +! (to be registered using {\tt registersublsmf2t} and later called +! using {\tt sublsmf2t}) ! \item[Write restart] ! Routines to write a restart file -! (to be registered using {\tt registerlsmwrst} and later called -! using {\tt lsmwrst}) +! (to be registered using {\tt registersublsmwrst} and later called +! using {\tt sublsmwrst}) ! \item[Finalize] ! Routines to cleanup LSM data structures -! (to be registered using {\tt registerlsmfinalize} and later called -! using {\tt lsmfinalize}) +! (to be registered using {\tt registersublsmfinalize} and later called +! using {\tt sublsmfinalize}) ! \end{description} ! ! The user-defined functions are included in the registry using a -! single index. For example, consider the Noah LSM is +! single index. For example, consider the Crocus LSM is ! incorporated in the registry with an index of 1 and ! is invoked later by the following calls ! ! \begin{verbatim} -! call registerlsminit(1,noah_lsm_ini) -! call registerlsmsetup(1,noah_setup) -! call registerlsmf2t(1,noah_f2t) -! call registerlsmrun(1,noah_main) -! call registerlsmrestart(1,noahrst) -! call registerlsmdynsetup(1,noah_dynsetup) -! call registerlsmwrst(1,noah_writerst) -! call registerlsmfinalize(1,noah_finalize) +! call registersublsminit(1,noah_lsm_ini) +! call registersublsmsetup(1,noah_setup) +! call registersublsmf2t(1,noah_f2t) +! call registersublsmrun(1,noah_main) +! call registersublsmrestart(1,noahrst) +! call registersublsmdynsetup(1,noah_dynsetup) +! call registersublsmwrst(1,noah_writerst) +! call registersublsmfinalize(1,noah_finalize) ! \end{verbatim} ! ! The functions registered above are invoked using generic calls as ! follows: ! ! \begin{verbatim} -! call lsminit(1) - calls noah_lsm_ini -! call lsmsetup(1) - calls noah_setup -! call lsmf2t(1) - calls noah_f2t -! call lsmrun(1) - calls noah_main -! call lsmdynsetup(1) - calls noah_dynsetup -! call lsmwrst(1) - calls noah_writerst -! call lsmfinalize(1) - calls noah_finalize +! call sublsminit(1) - calls noah_lsm_ini +! call sublsmsetup(1) - calls noah_setup +! call sublsmf2t(1) - calls noah_f2t +! call sublsmrun(1) - calls noah_main +! call sublsmdynsetup(1) - calls noah_dynsetup +! call sublsmwrst(1) - calls noah_writerst +! call sublsmfinalize(1) - calls noah_finalize ! \end{verbatim} ! ! In the LIS code, the above calls are typically invoked in the ! following manner. ! \begin{verbatim} -! call lsminit(lis%lsm) -! call lsmsetup(lis%lsm) -! call lsmf2t(lis%lsm) -! call lsmrun(lis%lsm) -! call lsmdynsetup(lis%lsm) -! call lsmwrst(lis%lsm) -! call lsmfinalize(lis%lsm) +! call sublsminit(lis%lsm) +! call sublsmsetup(lis%lsm) +! call sublsmf2t(lis%lsm) +! call sublsmrun(lis%lsm) +! call sublsmdynsetup(lis%lsm) +! call sublsmwrst(lis%lsm) +! call sublsmfinalize(lis%lsm) ! \end{verbatim} ! where $lis\%lsm$ is set through the configuration ! utility, enabling the user make a selection at runtime. @@ -123,6 +124,11 @@ subroutine LIS_sublsm_plugin #if ( defined SM_Crocus_8_1 ) use Crocus81_lsmMod, only : Crocus81_ini #endif + +#if ( defined SM_SNOWMODEL ) + use snowmodel_lsmMod, only : snowmodel_init +#endif + implicit none #if ( defined SM_Crocus_8_1 ) @@ -149,6 +155,26 @@ subroutine LIS_sublsm_plugin #endif +#if ( defined SM_SNOWMODEL ) + external snowmodel_main + external snowmodel_setup + external snowmodel_readrst + external snowmodel_dynsetup + external snowmodel_f2t + external snowmodel_writerst + external snowmodel_finalize + external snowmodel_reset + + external snowmodel_setLSMimport + external snowmodel_getLSMexport + +#if ( defined SM_NOAHMP_4_0_1 ) + external NoahMP401_getSnowModelexport + external NoahMP401_setSnowModelimport +#endif + +#endif + #if ( defined SM_Crocus_8_1 ) call registersublsminit(trim(LIS_Crocus81Id)//char(0),Crocus81_ini) call registersublsmsetup(trim(LIS_Crocus81Id)//char(0),Crocus81_setup) @@ -175,6 +201,36 @@ subroutine LIS_sublsm_plugin trim(LIS_Crocus81Id)//char(0),Crocus81_getLSMexport) #endif #endif + + +#if ( defined SM_SNOWMODEL ) + call registersublsminit(trim(LIS_snowmodelId)//char(0),snowmodel_init) + call registersublsmsetup(trim(LIS_snowmodelId)//char(0),snowmodel_setup) + call registersublsmf2t(trim(LIS_snowmodelId)//"+"& + //trim(LIS_retroId)//char(0),snowmodel_f2t) + call registersublsmf2t(trim(LIS_snowmodelId)//"+"//& + trim(LIS_agrmetrunId)//char(0),snowmodel_f2t) + call registersublsmrun(trim(LIS_snowmodelId)//char(0),snowmodel_main) + call registersublsmrestart(trim(LIS_snowmodelId)//char(0),snowmodel_readrst) + call registersublsmdynsetup(trim(LIS_snowmodelId)//char(0),snowmodel_dynsetup) + call registersublsmwrst(trim(LIS_snowmodelId)//char(0),snowmodel_writerst) + call registersublsmfinalize(trim(LIS_snowmodelId)//char(0),snowmodel_finalize) + call registersublsmreset(trim(LIS_snowmodelId)//char(0),snowmodel_reset) + + ! Wirings between NoahMP and SnowModel + call registersublsmsetLSMimport(trim(LIS_snowmodelId)//char(0),& + Snowmodel_setLSMimport) + +#if ( defined SM_NOAHMP_4_0_1 ) + call registerlsm2sublsmgetexport(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_snowmodelId)//char(0),NoahMP401_getSnowModelexport) + call registerlsmsetsublsmimport(trim(LIS_noahmp401Id)//char(0),& + NoahMP401_setSnowModelimport) + call registersublsm2lsmgetexport(trim(LIS_noahmp401Id)//"+"//& + trim(LIS_snowmodelId)//char(0),SnowModel_getLSMexport) +#endif +#endif + end subroutine LIS_sublsm_plugin end module LIS_sublsm_pluginMod diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 index 11ff367b7..9f6ef947d 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 @@ -138,6 +138,9 @@ subroutine NoahMP401_readcrd() elseif (trim(landuse_scheme_name) .eq. "IGBPNCEP") then NOAHMP401_struc(n)%landuse_scheme_name = & "MODIFIED_IGBP_MODIS_NOAH" + elseif (trim(landuse_scheme_name) .eq. "NALCMS_SM_IGBPNCEP" ) then + NOAHMP401_struc(n)%landuse_scheme_name = & + "MODIFIED_IGBP_MODIS_NOAH" elseif (trim(landuse_scheme_name) .eq. "UMD") then NOAHMP401_struc(n)%landuse_scheme_name = "UMD" else diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 new file mode 100644 index 000000000..8346a1798 --- /dev/null +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 @@ -0,0 +1,75 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: noahmp401_getSnowModelexport +! \label{noahmp401_getSnowModelexport} +! +! !REVISION HISTORY: +! 19 Sep 2020: Sujay Kumar; Initial Specification +! 17 Nov 2020: Mahdi Navari; In analogous to ISBA-Crocus %tgb replaced with %tslb +! 2 Dec 2020: Mahdi Navari; Edited to add soil volumetric liquid and frozen water content +! 12 Aug 2021: Kristi Arsenault; Added SnowModel connections +! +! !INTERFACE: +subroutine noahmp401_getSnowModelexport(n, LSM2SUBLSM_State) +! !USES: + use ESMF + use LIS_coreMod + use LIS_logMod + use noahmp401_lsmMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + type(ESMF_State) :: LSM2SUBLSM_State +! +! !DESCRIPTION: +! +! +!EOP + +#if 0 + type(ESMF_Field) :: gtField + type(ESMF_Field) :: XWGIField + type(ESMF_Field) :: XWGField + real, pointer :: gt(:) + real, pointer :: XWGI(:) + real, pointer :: XWG(:) + integer :: t + integer :: status + + call ESMF_StateGet(LSM2SUBLSM_State,"Ground temperature",gtField,rc=status) + call LIS_verify(status) + call ESMF_StateGet(LSM2SUBLSM_State,"soil volumetric liquid water content",XWGField,rc=status) + call LIS_verify(status) + call ESMF_StateGet(LSM2SUBLSM_State,"soil volumetric frozen water content",XWGIField,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(gtField,localDE=0,farrayPtr=gt,rc=status) + call LIS_verify(status) + call ESMF_FieldGet(XWGField,localDE=0,farrayPtr=XWG,rc=status) + call LIS_verify(status) + call ESMF_FieldGet(XWGIField,localDE=0,farrayPtr=XWGI,rc=status) + call LIS_verify(status) + + + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + gt(t) = NOAHMP401_struc(n)%noahmp401(t)%tslb(1) + !gt(t) = NOAHMP401_struc(n)%noahmp401(t)%tgb + XWGI(t) = NOAHMP401_struc(n)%noahmp401(t)%smc(1) - NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) ! volumetric frozen soil moisture [m3/m3] + XWG(t) = NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) ! volumetric liquid soil moisture [m3/m3] + enddo + +#endif + +end subroutine noahmp401_getSnowModelexport + + diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 new file mode 100755 index 000000000..51d3723a9 --- /dev/null +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 @@ -0,0 +1,68 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: noahmp401_setSnowModelimport +! \label{noahmp401_setSnowModelimport} +! +! !REVISION HISTORY: +! 19 Sep 2020: Sujay Kumar; Initial Specification +! 12 Aug 2021: Kristi Arsenault; Added SnowModel +! +! !INTERFACE: +subroutine noahmp401_setSnowModelimport(n, SubLSM2LSM_State) +! !USES: + use ESMF + use LIS_coreMod + use LIS_logMod + use noahmp401_lsmMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + type(ESMF_State) :: SubLSM2LSM_State +! +! !DESCRIPTION: +! +! +!EOP + type(ESMF_Field) :: snwdField, sweField + real, pointer :: swe(:), snwd(:) + real :: dsneqv,dsnowh + integer :: t + integer :: status + + call ESMF_StateGet(SubLSM2LSM_State,"Total SWE",sweField,rc=status) + call LIS_verify(status,"noahmp401_setSnowModelimport: error in swe state get from SnowModel") + call ESMF_StateGet(SubLSM2LSM_State,"Total snowdepth",snwdField,rc=status) + call LIS_verify(status,"noahmp401_setSnowModelimport: error in snwd state get from SnowModel") + + call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) + call LIS_verify(status,"noahmp401_setSnowModelimport: error in swe data values") + call ESMF_FieldGet(snwdField,localDE=0,farrayPtr=snwd,rc=status) + call LIS_verify(status,"noahmp401_setSnowModelimport: error in snwd data values") + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + ! SnowModel has its SWE in meters -- conversion here to mm: + dsneqv = (swe(t)*1000.) - noahmp401_struc(n)%noahmp401(t)%sneqv !in mm + dsnowh = snwd(t) - noahmp401_struc(n)%noahmp401(t)%snowh !in m + +! if( dsneqv > 0. .or. dsnowh > 0. ) then +! write(501,*) t, swe(t), noahmp401_struc(n)%noahmp401(t)%sneqv, & +! snwd(t), noahmp401_struc(n)%noahmp401(t)%snowh +! endif + + ! Update NoahMP's Snow states: + call noahmp401_snow_update(n, t, dsneqv, dsnowh) + + enddo + +end subroutine noahmp401_setSnowModelimport + + diff --git a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 index e84d3350c..4bd43d672 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 @@ -1821,7 +1821,7 @@ SUBROUTINE ENERGY (parameters,ICE ,VEGTYP ,IST ,NSNOW ,NSOIL , & !in ! ground snow cover fraction [Niu and Yang, 2007, JGR] FSNO = 0. - IF(SNOWH.GT.0.) THEN + IF(SNOWH.GT.0.) THEN BDSNO = SNEQV / SNOWH FMELT = (BDSNO/100.)**parameters%MFSNO FSNO = TANH( SNOWH /(2.5* Z0 * FMELT)) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 new file mode 100644 index 000000000..bbfdb1017 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 @@ -0,0 +1,68 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: snowmodel_getLSMexport +! \label{snowmodel_getLSMexport} +! +! !REVISION HISTORY: +! 19 Sep 2020: Sujay Kumar; Initial Specification +! 9 Dec 2020: Mahdi Navari; edited to take into account the Crocus slope correction +! 2 Aug 2021: Kristi Arsenault; Edited to support SnowModel implementation +! +! !INTERFACE: +subroutine snowmodel_getLSMexport(n, SubLSM2LSM_State) +! !USES: + + use ESMF + use LIS_coreMod + use LIS_logMod + use snowmodel_lsmMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + type(ESMF_State) :: SubLSM2LSM_State +! +! !DESCRIPTION: +! +! +!EOP + type(ESMF_Field) :: snwdField, sweField + real, pointer :: swe(:), snwd(:) + integer :: t + integer :: status + real :: tmp_SLOPE + + call ESMF_StateGet(SubLSM2LSM_State,"Total SWE",sweField,rc=status) + call LIS_verify(status,'Snowmodel_getLSMexport: SM SWE state error get') + call ESMF_StateGet(SubLSM2LSM_State,"Total snowdepth",snwdField,rc=status) + call LIS_verify(status,'Snowmodel_getLSMexport: SM snowd state error get') + + call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) + call LIS_verify(status,'Snowmodel_getLSMexport: SM swe field error get') + call ESMF_FieldGet(snwdField,localDE=0,farrayPtr=snwd,rc=status) + call LIS_verify(status,'Snowmodel_getLSMexport: SM snwd field error get') + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + ! SnowModel states + swe(t) = snowmodel_struc(n)%sm(t)%swe_depth ! SWE: meters + snwd(t) = snowmodel_struc(n)%sm(t)%snow_depth ! Snow depth: meters + ! If values are very small -- set to 0. + if( swe(t) < 0.0001 ) then + swe(t) = 0. + endif + if( snwd(t) < 0.001 ) then + snwd(t) = 0. + endif + enddo + +end subroutine snowmodel_getLSMexport + + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 new file mode 100644 index 000000000..5daa596c4 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 @@ -0,0 +1,77 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: snowmodel_setLSMimport +! \label{snowmodel_setLSMimport} +! +! !REVISION HISTORY: +! 19 Sep 2020: Sujay Kumar; Initial Specification +! 2 Dec 2020: Mahdi Navari; Edited to add soil volumetric liquid and frozen water content +! 2 Aug 2021: Kristi Arsenault; Edited to support SnowModel implementation + +! !INTERFACE: +subroutine snowmodel_setLSMimport(n, LSM2SubLSM_State) +! !USES: + + use ESMF + use LIS_coreMod + use LIS_logMod + use snowmodel_lsmMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + type(ESMF_State) :: LSM2SubLSM_State +! +! !DESCRIPTION: +! +! +!EOP + +#if 0 + type(ESMF_Field) :: gtField + real, pointer :: gt(:) + type(ESMF_Field) :: XWGIField + real, pointer :: XWGI(:) + type(ESMF_Field) :: XWGField + real, pointer :: XWG(:) + integer :: t + integer :: status + + call ESMF_StateGet(LSM2SubLSM_State,"Ground temperature",gtField,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(gtField,localDE=0,farrayPtr=gt,rc=status) + call LIS_verify(status) + + call ESMF_StateGet(LSM2SUBLSM_State,"soil volumetric frozen water content",XWGIField,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(XWGIField,localDE=0,farrayPtr=XWGI,rc=status) + call LIS_verify(status) + + call ESMF_StateGet(LSM2SUBLSM_State,"soil volumetric liquid water content",XWGField,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(XWGField,localDE=0,farrayPtr=XWG,rc=status) + call LIS_verify(status) + + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + snowmodel_struc(n)%crocus81(t)%TG = gt(t) + snowmodel_struc(n)%crocus81(t)%XWGI = XWGI(t) + snowmodel_struc(n)%crocus81(t)%XWG = XWG(t) + enddo + +#endif + +end subroutine snowmodel_setLSMimport + + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 b/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 new file mode 100644 index 000000000..42647dad5 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 @@ -0,0 +1,430 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +module micromet_module +!BOP +! +! !MODULE: micromet_module +! +! !DESCRIPTION: +! This module contains the key MicroMet routines for each +! of the different meteorological forcing fields (e.g., +! temperature, etc.). +! +! The routines in this module include: +! +! \begin{description} +! \item[micromet_relhum] +! micromet_relhum ... +! \end{description} +! +! !REVISION HISTORY: +! 01 Mar 2006: G. Liston and K. Elder; MicroMet routine authors +! 16 Feb 2021: K. Arsenault; Added MicroMet routines to LIS +! 03 Feb 2022: K. Arsenault; Added MicroMet's solar routines +! +!EOP + implicit none + +contains + +!BOP +! +! !ROUTINE: micromet_relhum +! \label{micromet_relhum} +! +! !DESCRIPTION: +! This routine calculates relative humidity (rh; %) for given +! specific humidity (sphm; kg/kg) and pressure (pres; Pa) +! +! !INTERFACE: + subroutine micromet_relhum(nx, ny, tair, sphm, pres, rh) + + implicit none + + integer, intent(in) :: nx + integer, intent(in) :: ny + real, intent(in) :: tair(nx,ny) + real, intent(in) :: sphm(nx,ny) + real, intent(in) :: pres(nx,ny) + real, intent(out) :: rh(nx,ny) + + integer :: i, j + real :: Tf ! Temperature at freezing point + real :: e ! vapor pressure + real :: es ! saturation vapor pressure + real :: A, B, C ! Coeffs for sat vapor pressure over water + +! ______________________________________________________________ + + Tf = 273.16 + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. +! Over water. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + + do j = 1, ny + do i = 1, nx + +! Compute the saturation water vapor pressure for given air temperature. +! CALL SATVAPOR(es,tair,Tf) + es = A * exp((B * (Tair(i,j) - Tf))/(C + (Tair(i,j) - Tf))) + +! Compute the water vapor pressure from the specific humidity (kg/kg) +! and pressure (Pa). + e = sphm(i,j) * pres(i,j) / (0.622 + 0.378 * sphm(i,j)) + +! Relative humidity (%). + rh(i,j) = 100.0 * (e / es) + rh(i,j) = min(100.0,rh(i,j)) + rh(i,j) = max(0.0,rh(i,j)) + + enddo + enddo + + end subroutine micromet_relhum + +!BOP +! +! !ROUTINE: micromet_snowfall +! \label{micromet_snowfall} +! +! !DESCRIPTION: +! This routine discriminates the amount of snowfall +! based on total precipitation, 2m air temperature +! and the snow fraction method based on the option +! selected in snowmodel.par +! +! !INTERFACE: + subroutine micromet_snowfall(nx, ny, snowfall_frac, prec, tair, sprec) + + implicit none + + integer, intent(in) :: nx + integer, intent(in) :: ny + real, intent(in) :: snowfall_frac ! Snowfall method option + real, intent(in) :: prec(nx,ny) ! Total precip + real, intent(in) :: tair(nx,ny) ! 2m Air temp + real, intent(out) :: sprec(nx,ny) ! Snowfall + + real :: Tair_C(nx,ny) ! Temperature in Celsius + real :: Tf ! Temperature at freezing point + + integer :: i,j + real :: snowfall_frac_1, snowfall_frac_2, snowfall_frac_3 + real :: Tair_C_center + real :: slope, b +! ______________________________________________________________ + + Tf = 273.15 + + do j = 1, ny + do i = 1, nx + + Tair_C(i,j) = Tair(i,j) - Tf + +! Option 1: Auer (1974); a rain-snow threshold at +2.0 C. + if (snowfall_frac.eq.1.0) then + + if (Tair_C(i,j).lt.2.0) then + snowfall_frac_1 = 1.0 + else + snowfall_frac_1 = 0.0 + endif + sprec(i,j) = snowfall_frac_1 * prec(i,j) + +! Option 2: Dai, A. (2008): Temperature and pressure dependenxe of the +! rain-snow phase transition over land and ocean, Geophys. +! Res. Lett., 35, L12802, doi:10.1029/2008GL033295. +! In this implementation, G. Liston clipped Dai's values to +! 0 and 1. + elseif (snowfall_frac.eq.2.0) then + snowfall_frac_2 = - 0.482292 * & + (tanh(0.7205 * (Tair_C(i,j) - 1.1662)) - 1.0223) + if (Tair_C(i,j).lt.-4.0) then + snowfall_frac_2 = 1.0 + elseif (Tair_C(i,j).gt.6.0) then + snowfall_frac_2 = 0.0 + endif + sprec(i,j) = snowfall_frac_2 * prec(i,j) + +! Option 3: Glen's linear approximation to Dai (2008). This plots right +! over the top of Dai, between frac = 0.1 and 0.9. + elseif (snowfall_frac.eq.3.0) then + +! Define where you want the center temperature to be when frac = 0.5. + Tair_C_center = 1.1 +! Define the slope of the line. + slope = -0.30 +! Calculate the intercept (the 0.5 is the frac for Tair_C_center). + b = 0.5 - slope * Tair_C_center + +! Solve the equation in the form y = m*x + b + snowfall_frac_3 = slope * Tair_C(i,j) + b + snowfall_frac_3 = max(0.0,snowfall_frac_3) + snowfall_frac_3 = min(1.0,snowfall_frac_3) + sprec(i,j) = snowfall_frac_3 * prec(i,j) + + endif + + enddo + enddo + + end subroutine micromet_snowfall + + +!BOP +! +! !ROUTINE: micromet_wind +! \label{micromet_wind} +! +! !DESCRIPTION: +! This routine calculates the wind distribution, for both +! U- and V-wind gridded fields, and the gridded wind speed +! and wind direction fields. +! Options selected in snowmodel.par +! +! !INTERFACE: + subroutine micromet_wind( nx, ny, deltax, deltay, & + uwind_grid,vwind_grid,slopewt,curvewt,& + curvature,slope_az,terrain_slope,windspd_grid,& + winddir_grid,windspd_flag,winddir_flag,windspd_min,& + vegtype,forest_LAI,calc_subcanopy_met,vegsnowd_xy,& + topo,wind_lapse_rate,curve_len_scale) + + use LIS_mpiMod + use snowmodel_lsmMod, only : snowmodel_struc + + implicit none + + integer, intent(in) :: nx + integer, intent(in) :: ny + real, intent(in) :: deltax ! grid increment in x + real, intent(in) :: deltay ! grid increment in y + + ! Output wind fields + real, intent(inout) :: uwind_grid(nx,ny) ! output U-wind values + real, intent(inout) :: vwind_grid(nx,ny) ! output V-wind values + real, intent(inout) :: winddir_grid(nx,ny) ! output wind direction + real, intent(inout) :: windspd_grid(nx,ny) ! output wind speed + real, intent(inout) :: windspd_flag + real, intent(inout) :: winddir_flag + + ! Input parameters + real, intent(in) :: curvature(nx,ny) + real, intent(in) :: slope_az(nx,ny) + real, intent(in) :: terrain_slope(nx,ny) + real, intent(in) :: vegtype(nx,ny) + real, intent(in) :: vegsnowd_xy(nx,ny) + real, intent(in) :: topo(nx,ny) + + ! User-specified inputs: + real, intent(in) :: slopewt ! wind model slope weight + real, intent(in) :: curvewt ! wind model curvature weight + real, intent(in) :: windspd_min ! Min wind speed threshold (set by user) + real, intent(in) :: curve_len_scale ! length scale for curvature calculation + real, intent(in) :: wind_lapse_rate + real, intent(in) :: calc_subcanopy_met + real, intent(in) :: forest_LAI(5) + + integer :: i, j + integer :: ierr + integer :: loops_windwt_smoother + real :: topo_ref_grid(nx,ny) + real :: delta_topo,alfa1,alfa2 + real :: u_sum, v_sum + real :: pi,deg2rad,rad2deg + +! Initialize any local fields: + topo_ref_grid = 0.0 + +! Define the required constants. + pi = 2.0 * acos(0.0) + deg2rad = pi / 180.0 + rad2deg = 180.0 / pi + +! If desired, impose a wind speed increase with elevation. Here +! the wind_lapse_rate = the wind speed increase per 1-km elevation +! gain. The adjustment is patterned after the precipitation- +! elevation adjustment. +! Note: topo_ref_grid here comes from the precipitation adjustment. + if (wind_lapse_rate.ne.0.0) then + alfa1 = (wind_lapse_rate - 1.0) / (1.0 + wind_lapse_rate) + ! Convert to m-1. + alfa1 = alfa1 / 1000.0 + do j=1,ny + do i=1,nx + delta_topo = topo(i,j) - topo_ref_grid(i,j) + ! Impose some limits to the adjustment. + delta_topo = min(delta_topo,1800.0) + alfa2 = alfa1 * delta_topo + uwind_grid(i,j) = uwind_grid(i,j) * (1.0 + alfa2)/(1.0 - alfa2) + vwind_grid(i,j) = vwind_grid(i,j) * (1.0 + alfa2)/(1.0 - alfa2) + enddo + enddo + endif + +! Convert these u and v components to speed and directions. + do j=1,ny + do i=1,nx +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(uwind_grid(i,j)).lt.1e-10) then + uwind_grid(i,j) = 1e-10 + endif + winddir_grid(i,j) = rad2deg * atan2(uwind_grid(i,j),vwind_grid(i,j)) + if (winddir_grid(i,j).ge.180.0) then + winddir_grid(i,j) = winddir_grid(i,j) - 180.0 + else + winddir_grid(i,j) = winddir_grid(i,j) + 180.0 + endif + + windspd_grid(i,j) = sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + enddo + enddo + +! Modify the wind speed and direction according to simple +! wind-topography relationships. + call topo_mod_winds(nx,ny,winddir_grid,slopewt,curvewt,& + & windspd_grid,uwind_grid,vwind_grid,curvature,slope_az,& + & terrain_slope,vegtype,forest_LAI,calc_subcanopy_met,& + & vegsnowd_xy,curve_len_scale,deltax,deltay) + +! Avoid problems of zero (low) winds (for example, turbulence +! theory, log wind profile, etc., says that we must have some +! wind. Thus, some equations blow up when the wind speed gets +! very small). + do j=1,ny + do i=1,nx + if (windspd_grid(i,j).lt.windspd_min) then + windspd_grid(i,j) = windspd_min + uwind_grid(i,j) = (- windspd_grid(i,j)) * & + & sin(deg2rad*winddir_grid(i,j)) + vwind_grid(i,j) = (- windspd_grid(i,j)) * & + & cos(deg2rad*winddir_grid(i,j)) + endif + enddo + enddo + +! Find the maximum wind speed in the domain, and the +! domain-averaged wind direction. + windspd_flag = 0.0 + u_sum = 0.0 + v_sum = 0.0 + do j=1,ny + do i=1,nx + windspd_flag = max(windspd_flag,windspd_grid(i,j)) + u_sum = u_sum + uwind_grid(i,j) + v_sum = v_sum + vwind_grid(i,j) + enddo + enddo + +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(u_sum, snowmodel_struc(1)%usum_glb, 1,& + MPI_REAL, MPI_SUM,& + LIS_mpi_comm, ierr) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(v_sum, snowmodel_struc(1)%vsum_glb, 1,& + MPI_REAL, MPI_SUM,& + LIS_mpi_comm, ierr) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(windspd_flag, snowmodel_struc(1)%windspdflg_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + + u_sum = snowmodel_struc(1)%usum_glb + v_sum = snowmodel_struc(1)%vsum_glb + windspd_flag = snowmodel_struc(1)%windspdflg_glb +#endif + +! NOTE: winddir_flag never gets used in any subsequent +! SnowModel submodels, like snowtran3d + u_sum = u_sum / real(nx*ny) + v_sum = v_sum / real(nx*ny) + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(u_sum).lt.1e-10) then + u_sum = 1e-10 + endif + winddir_flag = rad2deg * atan2(u_sum,v_sum) + if (winddir_flag.ge.180.0) then + winddir_flag = winddir_flag - 180.0 + else + winddir_flag = winddir_flag + 180.0 + endif + + end subroutine micromet_wind + + +!BOP +! +! !ROUTINE: micromet_solar +! \label{micromet_solar} +! +! !DESCRIPTION: +! Calculate solar radiation and estiamte a cloud cover +! for SWdown inputs to SnowModel. +! +! Options selected in snowmodel.par +! +! !INTERFACE: +! subroutine micromet_solar( nx,ny,xhour,J_day,topo,rh_grid,Tair_grid,& +! xlat_grid,Qsi_grid,slope_az,terrain_slope,dt,vegtype,& +! forest_LAI,T_lapse_rate,Td_lapse_rate,& +! calc_subcanopy_met,gap_frac,cloud_frac_factor,UTC_flag,& +! xlon_grid,cloud_frac_grid) + +! use LIS_mpiMod +! use snowmodel_lsmMod, only : snowmodel_struc + +! implicit none + +! integer, intent(in) :: nx +! integer, intent(in) :: ny +! real, intent(in) :: xhour ! model decimal hour +! integer, intent(in) :: J_day ! model day of year + + ! Input parameters and fields +! real, intent(in) :: rh_grid(nx,ny) +! real, intent(in) :: Tair_grid(nx,ny) +! real, intent(in) :: xlat_grid(nx,ny) +! real, intent(in) :: xlon_grid(nx,ny) +! real, intent(in) :: topo(nx,ny) +! real, intent(in) :: slope_az(nx,ny) +! real, intent(in) :: terrain_slope(nx,ny) +! real, intent(in) :: vegtype(nx,ny) +! real, intent(in) :: cloud_frac_grid(nx,ny) +! real, intent(in) :: dt +! real, intent(in) :: forest_LAI +! real, intent(in) :: T_lapse_rate +! real, intent(in) :: Td_lapse_rate +! real, intent(in) :: calc_subcanopy_met +! real, intent(in) :: gap_frac +! real, intent(in) :: cloud_frac_factor +! real, intent(in) :: UTC_flag + + ! Output SWdown fields +! real, intent(inout) :: Qsi_grid(nx,ny) ! output SWdown values + +! end subroutine micromet_solar + +end module micromet_module + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/dataassim_user.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/dataassim_user.f90 new file mode 100755 index 000000000..d5e20a102 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/dataassim_user.f90 @@ -0,0 +1,1958 @@ +! dataassim_user.f90 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! subroutine DATAASSIM_USER does the SWE assimilation. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine DATAASSIM_USER(nx,ny,icorr_factor_index,& + & corr_factor,max_iter,deltax,deltay,xmn,ymn,nobs_dates,& + & print_inc,iday_init,imonth_init,iyear_init,dt,& + & output_path_wo_assim,xhour_init) + +! Perform the required correction (precipitation and melt) factor +! calculations. To run the data assimilation routines requires +! additional model inputs to be added here (inputs in addition +! to those in the snowmodel.par file). Then you must recompile +! the code before running it. + +! This program works when you have data at one or many points +! (many individual grid cells), for one or more times. And for +! data (e.g., average swe) over areas of grid cells; there can be +! many of these areas, at many different times. + +! The input (swe) data file is assumed to be in the directory: +! /snowmodel/swe_assim/. See below for the details of how this +! file is to be configured. + +! The data assimilation produces a couple of extra files the user +! can look at to study what the model did with the input data +! file (fname_sweobs) that was provided. First, there is a text +! file written to /snowmodel/swe_assim/ that provides a summary +! of the calculations that were done (see unit=77 in the code +! below for what is written to this file). Second, there is a +! copy of the precipitation correction surfaces that were +! generated. This is also placed in /snowmodel/swe_assim/, the +! file is a GrADS file (called corr_factor.gdat), and there is +! also a corr_factor.ctl there that can be modified to fit the +! current simulation. The data layers in corr_factor.gdat arec +! structured as follows: +! The number of layers equals the total number of observation +! times that were assimilated, plus the number of years in the +! assimilation. The order is: the correction surface (cf) for +! the time between the start of the simulation and observation +! time 1 in year 1, the cf for the time between obs time 1 in +! year 1 and obs time 2 in year 1, etc., then a cf==1.0 for the +! time between the last obs time and the end of year 1 (or the +! end of the simulation for a 1-year run). Then this order +! repeats for the rest of the years of the simulation. In the +! GrADS control file (corr_factor.ctl) these layers are assumed +! to correspond to different times in the data file (although +! the actual time increment defined in the .ctl file is not +! really relevant: for example, t=1 corresponds to the cf for +! obs 1, t=2 is for obs 2, t=3 is for the time between the last +! obs time and the end of year 1, t=4 is for the obs 1 in year +! 2, etc.). + + use snowmodel_inc + implicit none + + real deltax,deltay,beta,areas_flag,print_inc,dt,xhour_init + real sprec_ratio(max_obs_dates),smelt_ratio(max_obs_dates) + real corr_factor(nx_max,ny_max,max_obs_dates) + real areas_mask(nx_max,ny_max) + + double precision xmn,ymn + double precision xstn(nx_max*ny_max),ystn(nx_max*ny_max) + + integer icorr_factor_index(max_time_steps) + integer iobs_rec(max_obs_dates) + integer nobs_dates,nx,ny,max_iter,local_assim_flag,iday_init,& + & imonth_init,iyear_init,nyear,nyears,nobs_total,nobs_total_cfi + + character*89 fname_swed,fname_sspr,fname_ssmt + character*80 fname_sweobs + character*80 fname_sweobs_barnes_mask + + character*80 output_path_wo_assim + integer trailing_blanks,i_len_wo + integer i,j + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! BEGIN USER EDIT SECTION. +! BEGIN USER EDIT SECTION. + +! Define how many years there are in this simulation. Note that +! these are SnowModel simulation years. So, for example, year +! 1 might be 1 Sep 2007 - 31 Aug 2008, and year 2 might be +! 1 Sep 2008 - 31 Aug 2009, etc. +! NOTE: this is now put in the first line of the swe assimilation +! input file (in 'fname_sweobs' below). +! nyears = 20 +! nyears = 1 + +! A single data file describes the observation information that +! will be used in the data assimilation. This file contains the +! following information in the following format. The id can be +! any number, x and y are easting and northing in m, and swe is +! in m). + +! total_number_of_observation_dates_for_this_year +! iyr imo idy (for this observation date) +! number_of_stations_for_this_observation_date +! id x y swe +! id x y swe +! id x y swe +! iyr imo idy (for this observation date) +! number_of_stations_for_this_observation_date +! id x y swe +! id x y swe + +! For example: + +! 2 +! 2014 3 15 +! 3 +! 101 3456.7 23677.4 0.42 +! 102 3556.3 25079.3 0.52 +! 103 3106.2 29089.3 0.59 +! 2014 4 1 +! 2 +! 101 3456.7 23677.4 0.48 +! 103 3106.2 29089.3 0.62 + +! Then this repeats for each year of the assimilation (the input +! file looks like the above for a single-year run, and for +! multi-year runs the data for each following year is just +! stacked on top of the previous year). The example below is +! for a two-year assimilation run. +! NOTE: the first '2=nyears' is because this is two-year run (if +! this were a 1-year run, this would be a 1, etc.). + +! 2 +! 2 +! 2014 3 15 +! 3 +! 101 3456.7 23677.4 0.42 +! 102 3556.3 25079.3 0.52 +! 103 3106.2 29089.3 0.59 +! 2014 4 1 +! 2 +! 101 3456.7 23677.4 0.48 +! 103 3106.2 29089.3 0.62 +! 1 +! 2015 3 25 +! 2 +! 101 3456.7 23677.4 0.23 +! 102 3556.3 25079.3 0.32 + +! For the run where you have years with no data to assimilate, +! and some years with data to assimilate, the code still +! requires a "total_number_of_observation_dates_for_this_year" +! line for each year. So, if you have a year with no data, this +! must be set to be 0 (zero). If this is 0, the code sets the +! correction factor to equal 1.0 for that simulation year, and +! no adjustments are made to the precipitation for that year. +! For example, if the first two, and fourth, years of a five- +! year run have no data to assimilate, your input file would +! look like: + +! 5 +! 0 +! 0 +! 1 +! 2014 3 15 +! 3 +! 101 3456.7 23677.4 0.42 +! 102 3556.3 25079.3 0.52 +! 103 3106.2 29089.3 0.59 +! 0 +! 1 +! 2015 3 25 +! 2 +! 101 3456.7 23677.4 0.23 +! 102 3556.3 25079.3 0.32 + +! Provide the name of the data file that contains the observed swe +! information (as described above). This can no longer be +! changed (defining it this way allows the error checking to be +! done). + fname_sweobs = 'swe_assim/swe_obs.dat' + +! Define the file names of the swe depth (swed), annual summed snow +! precipitation (sspr), and annual summed snowmelt (ssmt) outputs +! from the first iteration of the data assimilation run. In this +! implementation of the data assimilation code, I have assumed +! that the output files are those created by outputs_user.f, +! where there is an individual file for each variable. +! NOTE: in the latest code version these paths have already been +! defined in the snowmodel.par file. +! fname_swed = 'outputs/wo_assim/swed.gdat' +! fname_sspr = 'outputs/wo_assim/sspr.gdat' +! fname_ssmt = 'outputs/wo_assim/ssmt.gdat' + i_len_wo = 80 - trailing_blanks(output_path_wo_assim) + fname_swed = output_path_wo_assim(1:i_len_wo)//'swed.gdat' + fname_sspr = output_path_wo_assim(1:i_len_wo)//'sspr.gdat' + fname_ssmt = output_path_wo_assim(1:i_len_wo)//'ssmt.gdat' + +! THE PARAMETERS BELOW ARE RARELY CHANGED, UNLESS YOU ARE DOING AN +! AREAS ASSIMILATION (INSTEAD OF ASSIMILATING POINT DATA). + +! Beta controls the interpolation distance weights. Beta = 1.0 +! will give you a very smooth field, and correction factor +! distributions that may not produce swe's that exactly match +! the observations. Beta << 1.0 will give you correction factor +! fields that go right through the data. If you just have one +! data point/area, beta is not used. + beta = 1.0 +! beta = 0.1 +! beta = 0.5 + +! Define whether this simulation will be processing areas (data +! within groups of grid cells: areas_flag = 1.0), or points +! (single grid cells: areas_flag = 0.0). Note that if you have +! a combination of areas and points, you have to use the areas +! option and treat each point like a single-grid-cell (small) +! area. + areas_flag = 0.0 +! areas_flag = 1.0 + +! If this is an areas simulation, open and read in the areas mask +! data. Note that here I assume that the area mask is a nx by ny +! file with undef values everywhere except at the area 'stations'. +! And that each 'station' area is given a 1.0, 2.0, etc. that +! corresponds to the order of the station listing in the 'station' +! data input file (the first 'station' listed has mask value = 1.0, +! the second listed has mask value = 2.0, etc. + if (areas_flag.eq.1.0) then +! open(63,file= +! & '../1_topo_vege/8_mk_glac_front_mask/seals_fjord_mask.gdat', +! & form='unformatted',access='direct',recl=4*nx*ny) +! read(63,rec=1) ((areas_mask(i,j),i=1,nx),j=1,ny) +! If you have two masks for two different observation dates, then +! do something like the following. +! open(63,file='swe_assim/zack_obs_mask.gdat', +! & form='unformatted',access='direct',recl=4*nx*ny) +! read(63,rec=1) ((areas_mask(i,j,1),i=1,nx),j=1,ny) +! read(63,rec=2) ((areas_mask(i,j,2),i=1,nx),j=1,ny) + endif + +! Define whether this simulation is going to restrict the +! assimilation influence to some local area surrounding each +! data point that is assimilated. This was implemented for +! ANWR simulations where we only had observations in a corner +! of the simulation domain and I didn't want the corrections +! to extend too far outside that local observation area. So, +! this is an example of what can be done, and it is not written +! for general application. If you want to do something similar, +! the associated subroutine can be edited for your specific +! simulation of interest. For yes, local_assim_flag = 1, for +! no, local_assim_flag = 0. + local_assim_flag = 0 + +! Identify the file that contains the local data assimilation +! mask. This is only used if local_assim_flag = 1. + fname_sweobs_barnes_mask = & + & '../swe_obs/2014/barnes/obs.gridded.gdat' + +! END USER EDIT SECTION. +! END USER EDIT SECTION. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Open the swe input file. + open (unit=61,file=fname_sweobs) + +! Read in the number of years this assimilation will process. + read(61,*) nyears + +! LOOP THROUGH THE YEARS IN THE SIMULATION. + do nyear=1,nyears + +! Run the data assimilation routines. + call data_assimilation(nx,ny,deltax,deltay,beta,& + & areas_flag,sprec_ratio,smelt_ratio,corr_factor,& + & areas_mask,xmn,ymn,xstn,ystn,nobs_dates,iobs_rec,& + & local_assim_flag,fname_swed,fname_sspr,fname_ssmt,& + & fname_sweobs,fname_sweobs_barnes_mask,iday_init,& + & imonth_init,iyear_init,nyear,nobs_total,print_inc,& + & nyears,dt,max_iter,xhour_init) + +! Build an array indicating the appropriate correction factor to +! use at any given time during the simulation. What this does +! is define an index array that contains the record number that +! gets used at every model time step during the second model run +! loop. This record number corresponds to the record (krec) of +! the corr_factor(i,j,krec) array that was generated and saved +! in the subroutine above. + call corr_factor_index(nobs_dates,icorr_factor_index,& + & iobs_rec,max_iter,sprec_ratio,smelt_ratio,print_inc,& + & iday_init,imonth_init,iyear_init,nyear,nobs_total_cfi,& + & nyears) + + enddo + + return + end SUBROUTINE DATAASSIM_USER +! end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine data_assimilation(nx,ny,deltax,deltay,beta,& + & areas_flag,sprec_ratio,smelt_ratio,corr_factor,& + & areas_mask,xmn,ymn,xstn,ystn,nobs_dates,iobs_rec,& + & local_assim_flag,fname_swed,fname_sspr,fname_ssmt,& + & fname_sweobs,fname_sweobs_barnes_mask,iday_init,& + & imonth_init,iyear_init,nyear,nobs_total,print_inc,& + & nyears,dt,max_iter,xhour_init) + + use snowmodel_inc + implicit none + + real deltax,deltay,undef,dn,beta,areas_flag,swe_count,cf_min,& + & print_inc,dt,xhour_init + real sprec_ratio(max_obs_dates),smelt_ratio(max_obs_dates) + real corr_factor(nx_max,ny_max,max_obs_dates) + real swe_tmp(nx_max,ny_max),sum_sprec_tmp1(nx_max,ny_max),& + & sum_sprec_tmp2(nx_max,ny_max),grid(nx_max,ny_max),& + & areas_mask(nx_max,ny_max),sum_smelt_tmp1(nx_max,ny_max),& + & sum_smelt_tmp2(nx_max,ny_max) + real corr_factor_tmp(nx_max*ny_max),swe_obs(nx_max*ny_max),& + & swe_model(nx_max*ny_max),sumsprec_model(nx_max*ny_max),& + & delta_old(nx_max*ny_max),obsid(nx_max*ny_max),& + & sumsmelt_model(nx_max*ny_max),obsid_old(nx_max*ny_max),& + & delta_old_tmp(nx_max*ny_max) +! real corr_offset(nx_max*ny_max) + + double precision xmn,ymn + double precision xstn(nx_max*ny_max),ystn(nx_max*ny_max) + + integer iobs_rec(max_obs_dates) + integer ii(nx_max*ny_max),jj(nx_max*ny_max) + integer iobs_num,irec1,irec2,nobs_dates,nx,ny,i,j,ifill,& + & iobsint,k,nstns,nstns_old,kk,local_assim_flag,iiyr,iimo,& + & iidy,iobs_rec_tmp,iday_init,imonth_init,iyear_init,nyear,& + & krec,nobs_total,nyears,max_iter + + character*89 fname_swed,fname_sspr,fname_ssmt + character*80 fname_sweobs + character*80 fname_sweobs_barnes_mask + +! Perform some initialization steps. + if (nyear.eq.1) then + +! Define some of the constants and parameters used in the data +! assimilation. ifill should be = 1; in that case undef is not +! really used (so it does not have to be the same as defined +! in the .par file). + undef = -9999.0 + ifill = 1 + iobsint = 0 + +! Open a file to write some basic correction factor information. +! This just saves information that the user might want to look +! at. + open (unit=77,file='swe_assim/corr_factor.txt') + +! Open an output file for the correction factor array. + open(62,file='swe_assim/corr_factor.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + +! Initialize the number-of-observations counter. + nobs_total = 0 + + endif + +! Read the number of observation dates for this year. + read(61,*) nobs_dates + +! If you have observations for this year, generate the correction +! factors. For the case of no observations for this year, set +! the correction factor equal to 1.0. + if (nobs_dates.gt.0) then + +! Loop through the observation dates. + do iobs_num=1,nobs_dates + +! Increment the number-of-observations counter. + nobs_total = nobs_total + 1 + +! Read the date corresponding to this observation. + read(61,*) iiyr,iimo,iidy + +! Convert this date to the corresponding record number in the +! original SnowModel output files. Note that this has assumed +! that daily data files were written out since the start of +! the simulation. + call get_obs_record(iday_init,imonth_init,iyear_init,& + & iidy,iimo,iiyr,iobs_rec_tmp,print_inc,dt) + iobs_rec(iobs_num) = iobs_rec_tmp + +! For this observation date, read in the data describing the +! location and swe values for each observation. For areas +! simulations, xstn, and ystn correspond to the center of the +! area domain and they are not really used. + read(61,*) nstns + do k=1,nstns + read(61,*) obsid(k),xstn(k),ystn(k),swe_obs(k) + enddo + +! Convert the x and y locations to (ii,jj) locations. + do k=1,nstns + ii(k) = 1 + nint((xstn(k) - xmn) / deltax) + jj(k) = 1 + nint((ystn(k) - ymn) / deltay) + enddo + +! If you do a data assimilation run from start to finish, it is +! not required to close and reopen these files. But if you are +! doing a history restart then these files are no longer open +! so you must do this. What I do below works for both cases. + close (238) + close (239) + close (240) + +! Open the required inputs from the initial assimilation loop. +! Open swe depth (swe_depth). +! /outputs/wo_assim/swed.gdat is unit 238 in outputs_user.f +! Open sum snow precip (sum_sprec). +! /outputs/wo_assim/sspr.gdat is unit 239 in outputs_user.f +! Open sum snow melt (sum_smelt). +! /outputs/wo_assim/ssmt.gdat is unit 240 in outputs_user.f + open (238,file=fname_swed,& + & form='unformatted',access='direct',recl=4*1*nx*ny) + open (239,file=fname_sspr,& + & form='unformatted',access='direct',recl=4*1*nx*ny) + open (240,file=fname_ssmt,& + & form='unformatted',access='direct',recl=4*1*nx*ny) + +! Read the model output for the first observation time. + if (iobs_num.eq.1) then + irec1 = iobs_rec(iobs_num) + read(238,rec=irec1) ((swe_tmp(i,j),i=1,nx),j=1,ny) + read(239,rec=irec1) ((sum_sprec_tmp1(i,j),i=1,nx),j=1,ny) + read(240,rec=irec1) ((sum_smelt_tmp1(i,j),i=1,nx),j=1,ny) + +! For points, just pull the data at the appropriate grid cell. +! For areas, average the data over the masked out area for each +! 'station'. + do k=1,nstns + if (areas_flag.eq.0.0) then + swe_model(k) = swe_tmp(ii(k),jj(k)) + sumsprec_model(k) = sum_sprec_tmp1(ii(k),jj(k)) + sumsmelt_model(k) = sum_smelt_tmp1(ii(k),jj(k)) + elseif (areas_flag.eq.1.0) then + swe_model(k) = 0.0 + sumsprec_model(k) = 0.0 + sumsmelt_model(k) = 0.0 + swe_count = 0.0 + do j=1,ny + do i=1,nx + if (areas_mask(i,j).eq.obsid(k)) then +! The following is used if the mask changes with observation time. +! if (areas_mask(i,j,iobs_num).eq.obsid(k)) then + swe_count = swe_count + 1.0 + swe_model(k) = swe_model(k) + swe_tmp(i,j) + sumsprec_model(k) = sumsprec_model(k) +& + & sum_sprec_tmp1(i,j) + sumsmelt_model(k) = sumsmelt_model(k) +& + & sum_smelt_tmp1(i,j) + endif + enddo + enddo + swe_model(k) = swe_model(k) / swe_count + sumsprec_model(k) = sumsprec_model(k) / swe_count + sumsmelt_model(k) = sumsmelt_model(k) / swe_count + endif + enddo + endif + +! Read the model output for any additional observation times (irec1 +! = current obs time, irec2 = previous obs time). + if (iobs_num.gt.1) then + irec1 = iobs_rec(iobs_num) + irec2 = iobs_rec(iobs_num-1) + read(238,rec=irec1) ((swe_tmp(i,j),i=1,nx),j=1,ny) + read(239,rec=irec1) ((sum_sprec_tmp1(i,j),i=1,nx),j=1,ny) + read(239,rec=irec2) ((sum_sprec_tmp2(i,j),i=1,nx),j=1,ny) + read(240,rec=irec1) ((sum_smelt_tmp1(i,j),i=1,nx),j=1,ny) + read(240,rec=irec2) ((sum_smelt_tmp2(i,j),i=1,nx),j=1,ny) + +! For points, just pull the data at the appropriate grid cell. +! For areas, average the data over the masked out area for each +! 'station'. + do k=1,nstns + if (areas_flag.eq.0.0) then + swe_model(k) = swe_tmp(ii(k),jj(k)) + sumsprec_model(k) = sum_sprec_tmp1(ii(k),jj(k)) -& + & sum_sprec_tmp2(ii(k),jj(k)) + sumsmelt_model(k) = sum_smelt_tmp1(ii(k),jj(k)) -& + & sum_smelt_tmp2(ii(k),jj(k)) + elseif (areas_flag.eq.1.0) then + swe_model(k) = 0.0 + sumsprec_model(k) = 0.0 + sumsmelt_model(k) = 0.0 + swe_count = 0.0 + do j=1,ny + do i=1,nx + if (areas_mask(i,j).eq.obsid(k)) then +! The following is used if the mask changes with observation time. +! if (areas_mask(i,j,iobs_num).eq.obsid(k)) then + swe_count = swe_count + 1.0 + swe_model(k) = swe_model(k) + swe_tmp(i,j) + sumsprec_model(k) = sumsprec_model(k) + & + & sum_sprec_tmp1(i,j) - sum_sprec_tmp2(i,j) + sumsmelt_model(k) = sumsmelt_model(k) + & + & sum_smelt_tmp1(i,j) - sum_smelt_tmp2(i,j) + endif + enddo + enddo + swe_model(k) = swe_model(k) / swe_count + sumsprec_model(k) = sumsprec_model(k) / swe_count + sumsmelt_model(k) = sumsmelt_model(k) / swe_count + endif + enddo + endif + +! To avoid a divide by zero later on, make sure sumsprec_model and +! sumsmelt_model are not both zero. + do k=1,nstns + sumsprec_model(k) = sumsprec_model(k) + 1.0e-6 + enddo + +! Determine whether we will adjust the precipitation or melt. To +! do this, calculate the relative contributions of precipitation +! and melt inputs for this correction period. This can be +! different for each observation interval. Calculate the average +! over all of the stations/areas in the domain. + sprec_ratio(iobs_num) = 0.0 + smelt_ratio(iobs_num) = 0.0 + do k=1,nstns + sprec_ratio(iobs_num) = sprec_ratio(iobs_num) + & + & sumsprec_model(k) / (sumsprec_model(k)+sumsmelt_model(k)) + smelt_ratio(iobs_num) = smelt_ratio(iobs_num) + & + & sumsmelt_model(k) / (sumsprec_model(k)+sumsmelt_model(k)) + enddo + sprec_ratio(iobs_num) = sprec_ratio(iobs_num) / real(nstns) + smelt_ratio(iobs_num) = smelt_ratio(iobs_num) / real(nstns) + +! Initialize the delta swe variable. + if (iobs_num.eq.1) then + do k=1,nstns + delta_old(k) = 0.0 + enddo + else + do k=1,nstns + delta_old(k) = 0.0 + enddo + do k=1,nstns + do kk=1,nstns_old + if(obsid(k).eq.obsid_old(kk)) & + & delta_old(k) = delta_old_tmp(kk) + enddo + enddo +! write (77,*) +! do k=1,nstns +! write (77,*) 'k, delta_old(k)',k,100.*delta_old(k) +! enddo +! write (77,*) + endif + +! Calculate the correction factor to be used in the next model +! iteration. Let the correction factor equal 1.0 during +! periods where we have no swe observations. Also, note that the +! reason for the delta_old variable is to account for the fact +! that that delta will be fixed with the previous date correction +! time period. This is one of the things that allows the +! correction to be done in two model iterations. +! If sumsprec_model or sumsmelt_model are too small to be used in +! the assimilation (like less than 1 mm), set corr_factor_tmp = 1.0 +! so no adjustments are performed for this observation interval. + cf_min = 0.1 + do k=1,nstns + if (sprec_ratio(iobs_num).ge.smelt_ratio(iobs_num)) then + if (sumsprec_model(k).lt.1.0e-3) then + corr_factor_tmp(k) = 1.0 + else + corr_factor_tmp(k) = 1.0 + & + & (swe_obs(k) - swe_model(k) - delta_old(k)) / & + & sumsprec_model(k) + corr_factor_tmp(k) = max(cf_min,corr_factor_tmp(k)) + endif + else + if (sumsmelt_model(k).lt.1.0e-3) then + corr_factor_tmp(k) = 1.0 + else + corr_factor_tmp(k) = 1.0 + & + & (swe_model(k) - swe_obs(k) + delta_old(k)) / & + & sumsmelt_model(k) + corr_factor_tmp(k) = max(cf_min,corr_factor_tmp(k)) + endif + endif +! Save some information about the model calculations. +! write (77,*) '---' +! write (77,*) k,swe_obs(k) +! write (77,*) k,swe_model(k) +! write (77,*) k,delta_old(k) +! write (77,*) k,swe_obs(k)-swe_model(k)-delta_old(k) +! write (77,*) k,sumsprec_model(k) +! write (77,*) k,sumsmelt_model(k) +! write (77,*) k,corr_factor_tmp(k) +! write (77,*) '---' + +! Save some data from this observation time for use at the next +! observation time. + nstns_old = nstns + obsid_old(k) = obsid(k) + delta_old_tmp(k) = swe_obs(k) - swe_model(k) + enddo + +! Now that I have the correction factors calculated at each +! observation point, interpolate those over the simulation domain. + +! Use the barnes oi scheme to create the distribution. If there is +! only a single station, distribute those data uniformly over +! the domain. + if (nstns.ge.2) then + call get_dn(nx,ny,deltax,deltay,nstns,dn,iobsint) + +! Modify the size of dn. + dn = beta * dn + + call barnes_oi(nx,ny,deltax,deltay,xmn,ymn, & + & nstns,xstn,ystn,corr_factor_tmp,dn,grid,undef,ifill) + elseif (nstns.eq.1) then + call single_stn(nx,ny,nstns,corr_factor_tmp,grid) + endif + +! The following calculations are done if you want to implement the +! special case where you limit the data assimilation corrections +! to a certain area of your simulation domain. Edits to this +! subroutine will certainly be required to make it work for your +! specific application. This subroutine generates correction +! factors with 1.0's in places outside the local obs influences. + if (local_assim_flag.eq.1) then + call mk_local_cfs(nx,ny,undef,xmn,ymn,deltax,deltay,& + & fname_sweobs,fname_sweobs_barnes_mask,nobs_dates,& + & corr_factor_tmp,beta,iobsint,ifill,grid) + endif + +! Define the correction surface record that corresponds to this +! year and observation. + krec = nobs_total + (nyear - 1) + if (krec.gt.max_obs_dates) then + print *, 'max_obs_dates must be increased in snowmodel.inc' + print *, 'krec = ',krec,' max_obs_dates = ',max_obs_dates + stop + endif + +! Use the gridded output file to build the corr_factor array. + do j=1,ny + do i=1,nx + corr_factor(i,j,krec) = grid(i,j) + corr_factor(i,j,krec) = & + & max(cf_min,corr_factor(i,j,krec)) + enddo + enddo + +! Note that the interpolation scheme may have produced correction +! factors that do not produce exact matches with the +! observations (like happens with the case of having a single +! data point). If you are interested, calculate the difference +! between the exact value and the actual calculated value, and +! then write it out as done below. +! do k=1,nstns +! if (sprec_ratio(iobs_num).ge.smelt_ratio(iobs_num)) then +! corr_offset(k) = sumsprec_model(k) * +! & (corr_factor(ii(k),jj(k),iobs_num) - corr_factor_tmp(k)) +! else +! corr_offset(k) = sumsmelt_model(k) * +! & (corr_factor(ii(k),jj(k),iobs_num) - corr_factor_tmp(k)) +! endif +! enddo + +! Write some information to the text file. + write (77,*) & + & '**************************************************************' + +! write (77,*) ' sprec_ratio =',sprec_ratio(iobs_num), +! & ' smelt_ratio =',smelt_ratio(iobs_num) +! write (77,*) + + write (77,*) iiyr,iimo,iidy + write (77,*) ' sprec_ratio =',sprec_ratio(iobs_num) + write (77,*) ' smelt_ratio =',smelt_ratio(iobs_num) + write (77,*) + + do k=1,nstns +! write (77,*) k,' swe diff =', +! & 100.0*abs(swe_obs(k)-swe_model(k)),' SWE OBS =', +! & 100.0*swe_obs(k) +! write (77,*) 'sumsprec =',sumsprec_model(k)*100., +! & ' SWE MODEL =',swe_model(k)*100. +! write (77,*) 'iobs_num =',iobs_num, +! & ' CORR_FACTOR =',corr_factor_tmp(k) + + write (77,*) ' SWE OBS (cm) =',100.0*swe_obs(k) + write (77,*) ' SWE MODEL (cm) =',100.0*swe_model(k) + write (77,*) ' CORR_FACTOR =',corr_factor_tmp(k) + +!c write (77,*) 'corr_offset =',100.*corr_offset(k), +!c & ' ij',ii(k),jj(k) +!c write (77,*) ' delta_old =',100.*delta_old(k), +!c & ' corr fact used =',corr_factor(ii(k),jj(k),iobs_num) +! write (77,*) +! write (77,*) k,' sumsprec_model(k) =',sumsprec_model(k) +! write (77,*) k,' sumsmelt_model(k) =',sumsmelt_model(k) +! write (77,*) + enddo + + write (77,*) & + & '**************************************************************' + +! Write the output data to a grads file. + write(62,rec=krec) ((corr_factor(i,j,krec),i=1,nx),j=1,ny) + + enddo + +! Fill corr_factor with 1.0 for the period following the last obs +! date in the current year. This is also required for the history +! restart to work correctly. Without the history restart this was +! already done as part of the model initialization. + if (krec+1.gt.max_obs_dates) then + print *, 'max_obs_dates must be increased in snowmodel.inc' + print *, 'krec+1 = ',krec+1,' max_obs_dates = ',max_obs_dates + stop + endif + do j=1,ny + do i=1,nx + corr_factor(i,j,krec+1) = 1.0 + enddo + enddo + + write(62,rec=krec+1) ((corr_factor(i,j,krec+1),i=1,nx),j=1,ny) + +! The met, topo, and veg files must be closed for the next model +! iteration. + close (20) + close (37) + close (38) + + close (238) + close (239) + close (240) + + else + +! For the case of no observations for this year, set the correction +! factor equal to 1.0. + krec = nobs_total + nyear + if (krec.gt.max_obs_dates) then + print *, 'max_obs_dates must be increased in snowmodel.inc' + print *, 'krec = ',krec,' max_obs_dates = ',max_obs_dates + stop + endif + + do j=1,ny + do i=1,nx + corr_factor(i,j,krec) = 1.0 + enddo + enddo + + write(62,rec=krec) ((corr_factor(i,j,krec),i=1,nx),j=1,ny) + + endif + +! Create the GrADS .ctl (control) file to go with the GrADS +! .gdat corr_factor file that was generated by this model run. + call mk_cf_prec_ctl(nx,ny,deltax,deltay,xmn,ymn,dt, & + & iyear_init,imonth_init,iday_init,xhour_init,max_iter, & + & nobs_total,nyears) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine corr_factor_index(nobs_dates,icorr_factor_index, & + & iobs_rec,max_iter,sprec_ratio,smelt_ratio,print_inc, & + & iday_init,imonth_init,iyear_init,nyear,nobs_total_cfi, & + & nyears) + + use snowmodel_inc + implicit none + + integer icorr_factor_index(max_time_steps) + + integer kk,istart,iend,nobs_dates,iter,max_iter,krec,nyear,& + & nobs_total_cfi,ioptn,julian_start,iiyr,julian_end,iday_init,& + & imonth_init,iyear_init,nyears + integer iobs_rec(max_obs_dates) + real sprec_ratio(max_obs_dates),smelt_ratio(max_obs_dates) + real print_inc + +! Initialize the number-of-observations counter. + if (nyear.eq.1) nobs_total_cfi = 0 + +! Build an array indicating the appropriate correction factor to +! use at each time step during the simulation. + if (nobs_dates.gt.0) then + +! Loop through the observation dates. + do kk=1,nobs_dates+1 + +! Increment the number-of-observations counter. + if (kk.le.nobs_dates) nobs_total_cfi = nobs_total_cfi + 1 + +! FIRST, FROM THE SIMULATION START UNTIL THE FIRST OBSERVATION, FOR +! EACH YEAR. + if (kk.eq.1) then + +! Here istart equals the first model time step of each year. + ioptn = 3 + call calndr (ioptn,iday_init,imonth_init,iyear_init,& + & julian_start) + +! Find the Julian day for this data record. + iiyr = iyear_init + (nyear - 1) + call calndr (ioptn,iday_init,imonth_init,iiyr,julian_end) + +! Calculate istart. + istart = 1 + (julian_end - julian_start) * nint(print_inc) + +! Here iend equals the model time step corresponding to the end of +! the first observation day. Take advantage of the data-file +! record that was calculated before. Convert from daily data +! output records to model time steps using print_inc. + iend = iobs_rec(kk) * nint(print_inc) + +! Define the corr_factor data array record. + krec = nobs_total_cfi + (nyear - 1) + +! Fill the index for each model time step. + do iter=istart,iend + if (sprec_ratio(kk).ge.smelt_ratio(kk)) then + icorr_factor_index(iter) = krec + else + icorr_factor_index(iter) = -krec + endif + enddo + +! SECOND, BETWEEN THE LAST OBSERVATION AND THE END OF THE SIMULATION. + elseif (kk.eq.nobs_dates+1) then + istart = iobs_rec(kk-1) * nint(print_inc) + 1 + +! Here iend equals the last time step in the year of interest. +! Find the Julian day for this data record. + iiyr = iyear_init + nyear + call calndr (ioptn,iday_init,imonth_init,iiyr,julian_end) + +! Calculate iend for this year. + iend = (julian_end - julian_start) * nint(print_inc) + iend = min(iend,max_iter) + +! Define the corr_factor data array record. + krec = nobs_total_cfi + nyear + +! Fill the index for each model time step. + do iter=istart,iend + icorr_factor_index(iter) = krec + enddo + +! THIRD, ANY PERIODS BETWEEN OBSERVATIONS. + else + istart = iobs_rec(kk-1) * nint(print_inc) + 1 + iend = iobs_rec(kk) * nint(print_inc) + +! Define the corr_factor data array record. + krec = nobs_total_cfi + (nyear - 1) + +! Fill the index for each model time step. + do iter=istart,iend + if (sprec_ratio(kk).ge.smelt_ratio(kk)) then + icorr_factor_index(iter) = krec + else + icorr_factor_index(iter) = -krec + endif + enddo + endif + enddo + + else + +! Create an array indes for the case of no observations for this +! year. Here istart equals the first model time step of each year. + ioptn = 3 + call calndr (ioptn,iday_init,imonth_init,iyear_init,& + & julian_start) + +! Find the Julian day for this data record. + iiyr = iyear_init + (nyear - 1) + call calndr (ioptn,iday_init,imonth_init,iiyr,julian_end) + +! Calculate istart. + istart = 1 + (julian_end - julian_start) * nint(print_inc) + +! Calculate iend for this year. + iiyr = iyear_init + nyear + call calndr (ioptn,iday_init,imonth_init,iiyr,julian_end) + iend = (julian_end - julian_start) * nint(print_inc) + iend = min(iend,max_iter) + +! Define the corr_factor data array record. + krec = nobs_total_cfi + nyear + +! Fill the index for each model time step. + do iter=istart,iend + icorr_factor_index(iter) = krec + enddo + + endif + +! SAVE A VERSION OF THE INDEX THAT THE USER CAN EASILY LOOK AT. + if (nyear.eq.nyears) then + print * + do iter=1,max_iter + write (77,*) iter,icorr_factor_index(iter) + enddo + print * + endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_local_cfs(nx,ny,undef,xmn,ymn,deltax,deltay,& + & fname_sweobs,fname_sweobs_barnes_mask,nobs_dates,& + & corr_factor_tmp,beta,iobsint,ifill,grid) + + use snowmodel_inc + implicit none + + integer nstns,k,nx,ny,i,j,ntstations,icount,nobs_dates,ifill, & + & iobsint,nstns2 + + real dummy,stnid,undef,deltax,deltay,beta,dn + real xmask(nx_max,ny_max),grid(nx_max,ny_max) + real corr_factor_tmp(nx_max*ny_max),cf_tmp2(nx_max*ny_max),& + & obsid(nx_max*ny_max) + + real var(nstns_max) + + double precision xmn,ymn + double precision yg(nx_max,ny_max),xg(nx_max,ny_max) + double precision xstn(nstns_max),ystn(nstns_max) + + character*80 fname_sweobs + character*80 fname_sweobs_barnes_mask + + print * + print *,'You are doing local assimilation, this requires' + print *,'an observation mask to have been generated before' + print *,'the model run and saved in the file called:' + print *,'fname_sweobs_barnes_mask' + print * + print *,'This was also not tested after some big changes to' + print *,'the data assimilation code. So I strongly suggest' + print *,'you make sure this is doing what you want when you' + print *,'first start using it.' + print * + stop + if (nobs_dates.gt.1) then + print *,'THIS HAS NOT BEEN MADE TO WORK WITH MORE THAN' + print *,'ONE OBS TIME.' + stop + endif + print * + +! Save the correction factors for the local-influence assimilation +! scheme. + open (unit=78,file='swe_assim/cf.txt') + do k=1,nstns + write (78,*) corr_factor_tmp(k) + enddo + close (78) + +! These are the obs and correction factors calculated from the +! first loop in SnowModel. + open (721,file=fname_sweobs) + open (731,file='swe_assim/cf.txt') + + read (721,*) nstns + do k=1,nstns + read (721,*) stnid,xstn(k),ystn(k),dummy + read (731,*) var(k) +! if (var(k).gt.1.5) then +! print *, 'cf > 1.5 found; setting to 1.5',k,var(k) +! var(k) = 1.5 +! endif +! if (var(k).lt.0.5) then +! print *, 'cf < 0.5 found; setting to 0.5',k,var(k) +! var(k) = 0.5 +! endif +! var(k) = min(1.5,var(k)) +! var(k) = max(0.5,var(k)) + enddo + close (721) + close (731) + +! Create a collection of 'stations' with correction factors of +! 1.0 in areas outside of our traverse regions. + open(741,file=fname_sweobs_barnes_mask,& + & form='unformatted',access='direct',recl=4*nx*ny) + read (741,rec=1) ((xmask(i,j),i=1,nx),j=1,ny) + close (741) + +! Create an array of e, n coordinates for this domain. + do j=1,ny + do i=1,nx + xg(i,j) = xmn + deltax * (real(i) - 1.0) + yg(i,j) = ymn + deltay * (real(j) - 1.0) + enddo + enddo + + do j=1,ny + do i=1,nx + if (xmask(i,j).ne.undef) then + xg(i,j) = undef + yg(i,j) = undef + endif + enddo + enddo + +! Count how many cf=1.0 'stations' you are going to end up with. + icount = 0 + do j=1,ny,100 + do i=1,nx,100 + if (xg(i,j).ne.undef) then + icount = icount + 1 + endif + enddo + enddo + +! Write out the original stations. + open (761,file='swe_assim/cf_with_mask.txt') + ntstations = nstns + icount + write (761,88) ntstations + do k=1,nstns + write (761,89) k,xstn(k),ystn(k),var(k) + enddo + +! Write out the cf=1.0 stations. + icount = 0 + do j=1,ny,100 + do i=1,nx,100 + if (xg(i,j).ne.undef) then + icount = icount + 1 + write (761,89) icount+1000,xg(i,j),yg(i,j),1.0 + endif + enddo + enddo + close (761) + +! Read in the new local cf data. + open (79,file='swe_assim/cf_with_mask.txt') + read (79,*) nstns2 + do k=1,nstns2 + read (79,*) obsid(k),xstn(k),ystn(k),cf_tmp2(k) + enddo + close (79) + + call get_dn(nx,ny,deltax,deltay,nstns2,dn,iobsint) + + dn = beta * dn + + call barnes_oi(nx,ny,deltax,deltay,xmn,ymn,& + & nstns2,xstn,ystn,cf_tmp2,dn,grid,undef,ifill) + +! Write the output data to a grads file. + open(511,file='swe_assim/corr_factor_w-mask.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + write(511,rec=1) ((grid(i,j),i=1,nx),j=1,ny) + close (511) + + 88 format (i10) + 89 format (i10,2f15.1,f10.4) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_obs_record(iday_init,imonth_init,iyear_init,& + & iidy,iimo,iiyr,iobs_rec_tmp,print_inc,dt) + + implicit none + + integer ioptn,iday_init,imonth_init,iyear_init,julian_start,& + & iidy,iimo,iiyr,julian_end,iobs_rec_tmp,n_writes_per_day + + real print_inc,dt + +! Find the Julian day at the start of the model run. + ioptn = 3 + call calndr (ioptn,iday_init,imonth_init,iyear_init,julian_start) + +! Find the Julian day for this data record. + call calndr (ioptn,iidy,iimo,iiyr,julian_end) + +! Calculate the day of simulation for this data record. This is the +! same as the output file data record. + iobs_rec_tmp = julian_end - julian_start + 1 + +! Correct this for the case where sub-daily data writes were made. + n_writes_per_day = nint((86400.0 / dt) / print_inc) + iobs_rec_tmp = n_writes_per_day * iobs_rec_tmp + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_cf_prec_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & nobs_total,nyears) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,nobs_total,nyears + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_desc,trailing_blanks + + character*95 output_fname + character*80 filename,description + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + data description /& + & 'cf 0 0 precip correction factor (above and below 1.0)'/ + + undef = -9999.0 + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert the write interval from seconds to hours or a day. + igrads_dt = 1 + cdt = 'dy' + + filename = 'swe_assim/corr_factor.ctl' + output_fname = 'corr_factor.gdat' + + len_desc = 80 - trailing_blanks(description) + + open (71,file=filename) + + write (71,51) output_fname + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) nobs_total+nyears,nint(xhour_init),& + & iday_init,cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) description(1:len_desc) + write (71,60) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 51 format ('DSET ^',a) + 52 format ('TITLE SnowModel data assimilation precip corr factor') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 59 format (a) + 60 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! file = calendar.f version 1.0 +! +! Note from Glen: This is the version that should be used as +! part of my computer programs!!!!!!!!!!!!!!!!!!!!!!!!!! +! +! This program performs various date conversion calculations +! using subroutine calndr(). +! On a 32-bit computer, it can handle any date between roughly +! 5 million BC and 5 million AD. This limitation is due to +! the range of integers that can be expressed with 32 bits. +! The algorithm has no limitation. +! +! Using function idaywk(), the day of the week is computed +! along with the answer to the user's calendar calculation. +! +! External routines called: +! calndr calendar conversions +! idaywk day of the week determination +! +! Portability +! This routine is coded to Fortran 77 standards except that +! lower case is used. +! +! Copyright (C) 1999 Jon Ahlquist. +! Issued under the second GNU General Public License. +! See www.gnu.org for details. +! This program is distributed in the hope that it will be useful, +! but WITHOUT ANY WARRANTY; without even the implied warranty of +! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +! If you find any errors, please notify: +! Jon Ahlquist +! Dept of Meteorology +! Florida State University +! Tallahassee, FL 32306-4520 +! 15 March 1999. +! +!---------- +! +! Declare variables. +! implicit none +! integer day, daynum, ioptn, julian, month, year +! character*9 daynam(0:6) +! +! Declare the integer function used to compute the day of the week. +! integer idaywk +! +! Define the day names. +! data daynam /'Sunday', 'Monday', 'Tuesday', 'Wednesday', +! & 'Thursday', 'Friday', 'Saturday'/ +! +! Variables and their meanings +! day day of the month. +! daynam array of day names. (daynam(0)='Sunday', daynam(1)='Monday', +! ..., daynam(6)='Saturday') +! daynum day number during the year. (1 for 1 January, 2 for +! 2 January, 32 for 1 February, etc.) +! idaywk integer function that returns an integer counter indicating +! the day of the week, where 0 refers to Sunday, 1 to Monday, +! up to 6 for Saturday. +! ioptn option indicator where 0 < abs(ioptn) < 6. +! See below and especially subroutine calndr for details. +! julian Julian Day number. +! month month counter (1=January, 2=February, ..., 12=December) +! year year expressed with ALL digits. DO NOT abbreviate years +! by using only the last two digits. +! +!---------- +! + subroutine calndr (ioptn, iday, month, iyear, idayct) +! +!---------- +! +! CALNDR = CALeNDaR conversions, version 1.0 +! +! Input variable specifying the desired calendar conversion option. + integer ioptn +! +! Input/Output variables (sometimes input, sometimes output, +! depending on the value of the desired option, ioptn.) + integer iday, month, iyear, idayct +! +!---------- +! +! Subroutine calndr() performs calendar calculations using either +! the standard Gregorian calendar or the old Julian calendar. +! This subroutine extends the definitions of these calendar systems +! to any arbitrary year. The algorithms in this subroutine +! will work with any date in the past or future, +! but overflows will occur if the numbers are sufficiently large. +! For a computer using a 32-bit integer, this routine can handle +! any date between roughly 5.8 million BC and 5.8 million AD +! without experiencing overflow during calculations. +! +! No external functions or subroutines are called. +! +!---------- +! +! INPUT/OUTPUT ARGUMENTS FOR SUBROUTINE CALNDR() +! +! "ioptn" is the desired calendar conversion option explained below. +! Positive option values use the standard modern Gregorian calendar. +! Negative option values use the old Julian calendar which was the +! standard in Europe from its institution by Julius Caesar in 45 BC +! until at least 4 October 1582. The Gregorian and Julian calendars +! are explained further below. +! +! (iday,month,iyear) is a calendar date where "iday" is the day of +! the month, "month" is 1 for January, 2 for February, etc., +! and "iyear" is the year. If the year is 1968 AD, enter iyear=1968, +! since iyear=68 would refer to 68 AD. +! For BC years, iyear should be negative, so 45 BC would be iyear=-45. +! By convention, there is no year 0 under the BC/AD year numbering +! scheme. That is, years proceed as 2 BC, 1 BC, 1 AD, 2 AD, etc., +! without including 0. Subroutine calndr() will print an error message +! and stop if you specify iyear=0. +! +! "idayct" is a day count. It is either the day number during the +! specified year or the Julian Day number, depending on the value +! of ioptn. By day number during the specified year, we mean +! idayct=1 on 1 January, idayct=32 on 1 February, etc., to idayct=365 +! or 366 on 31 December, depending on whether the specified year +! is a leap year. +! +! The values of input variables are not changed by this subroutine. +! +! +! ALLOWABLE VALUES FOR "IOPTN" and the conversions they invoke. +! Positive option values ( 1 to 5) use the standard Gregorian calendar. +! Negative option values (-1 to -5) use the old Julian calendar. +! +! Absolute +! value +! of ioptn Input variable(s) Output variable(s) +! +! 1 iday,month,iyear idayct +! Given a calendar date (iday,month,iyear), compute the day number +! (idayct) during the year, where 1 January is day number 1 and +! 31 December is day number 365 or 366, depending on whether it is +! a leap year. +! +! 2 idayct,iyear iday,month +! Given the day number of the year (idayct) and the year (iyear), +! compute the day of the month (iday) and the month (month). +! +! 3 iday,month,iyear idayct +! Given a calendar date (iday,month,iyear), compute the Julian Day +! number (idayct) that starts at noon of the calendar date specified. +! +! 4 idayct iday,month,iyear +! Given the Julian Day number (idayct) that starts at noon, +! compute the corresponding calendar date (iday,month,iyear). +! +! 5 idayct iday,month,iyear +! Given the Julian Day number (idayct) that starts at noon, +! compute the corresponding day number for the year (iday) +! and year (iyear). On return from calndr(), "month" will always +! be set equal to 1 when ioptn=5. +! +! No inverse function is needed for ioptn=5 because it is +! available through option 3. One simply calls calndr() with: +! ioptn = 3, +! iday = day number of the year instead of day of the month, +! month = 1, and +! iyear = whatever the desired year is. +! +!---------- +! +! EXAMPLES +! The first 6 examples are for the standard Gregorian calendar. +! All the examples deal with 15 October 1582, which was the first day +! of the Gregorian calendar. 15 October is the 288-th day of the year. +! Julian Day number 2299161 began at noon on 15 October 1582. +! +! Find the day number during the year on 15 October 1582 +! ioptn = 1 +! call calndr (ioptn, 15, 10, 1582, idayct) +! calndr() should return idayct=288 +! +! Find the day of the month and month for day 288 in year 1582. +! ioptn = 2 +! call calndr (ioptn, iday, month, 1582, 288) +! calndr() should return iday=15 and month=10. +! +! Find the Julian Day number for 15 October 1582. +! ioptn = 3 +! call calndr (ioptn, 15, 10, 1582, julian) +! calndr() should return julian=2299161 +! +! Find the Julian Day number for day 288 during 1582 AD. +! When the input is day number of the year, one should specify month=1 +! ioptn = 3 +! call calndr (ioptn, 288, 1, 1582, julian) +! calndr() should return dayct=2299161 +! +! Find the date for Julian Day number 2299161. +! ioptn = 4 +! call calndr (ioptn, iday, month, iyear, 2299161) +! calndr() should return iday=15, month=10, and iyear=1582 +! +! Find the day number during the year (iday) and year +! for Julian Day number 2299161. +! ioptn = 5 +! call calndr (ioptn, iday, month, iyear, 2299161) +! calndr() should return iday=288, month=1, iyear=1582 +! +! Given 15 October 1582 under the Gregorian calendar, +! find the date (idayJ,imonthJ,iyearJ) under the Julian calendar. +! To do this, we call calndr() twice, using the Julian Day number +! as the intermediate value. +! call calndr ( 3, 15, 10, 1582, julian) +! call calndr (-4, idayJ, monthJ, iyearJ, julian) +! The first call to calndr() should return julian=2299161, and +! the second should return idayJ=5, monthJ=10, iyearJ=1582 +! +!---------- +! +! BASIC CALENDAR INFORMATION +! +! The Julian calendar was instituted by Julius Caesar in 45 BC. +! Every fourth year is a leap year in which February has 29 days. +! That is, the Julian calendar assumes that the year is exactly +! 365.25 days long. Actually, the year is not quite this long. +! The modern Gregorian calendar remedies this by omitting leap years +! in years divisible by 100 except when the year is divisible by 400. +! Thus, 1700, 1800, and 1900 are leap years under the Julian calendar +! but not under the Gregorian calendar. The years 1600 and 2000 are +! leap years under both the Julian and the Gregorian calendars. +! Other years divisible by 4 are leap years under both calendars, +! such as 1992, 1996, 2004, 2008, 2012, etc. For BC years, we recall +! that year 0 was omitted, so 1 BC, 5 BC, 9 BC, 13 BC, etc., and 401 BC, +! 801 BC, 1201 BC, etc., are leap years under both calendars, while +! 101 BC, 201 BC, 301 BC, 501 BC, 601 BC, 701 BC, 901 BC, 1001 BC, +! 1101 BC, etc., are leap years under the Julian calendar but not +! the Gregorian calendar. +! +! The Gregorian calendar is named after Pope Gregory XIII. He declared +! that the last day of the old Julian calendar would be Thursday, +! 4 October 1582 and that the following day, Friday, would be reckoned +! under the new calendar as 15 October 1582. The jump of 10 days was +! included to make 21 March closer to the spring equinox. +! +! Only a few Catholic countries (Italy, Poland, Portugal, and Spain) +! switched to the Gregorian calendar on the day after 4 October 1582. +! It took other countries months to centuries to change to the +! Gregorian calendar. For example, England's first day under the +! Gregorian calendar was 14 September 1752. The same date applied to +! the entire British empire, including America. Japan, Russia, and many +! eastern European countries did not change to the Gregorian calendar +! until the 20th century. The last country to change was Turkey, +! which began using the Gregorian calendar on 1 January 1927. +! +! Therefore, between the years 1582 and 1926 AD, you must know +! the country in which an event was dated to interpret the date +! correctly. In Sweden, there was even a year (1712) when February +! had 30 days. Consult a book on calendars for more details +! about when various countries changed their calendars. +! +! DAY NUMBER DURING THE YEAR +! The day number during the year is simply a counter equal to 1 on +! 1 January, 32 on 1 February, etc., thorugh 365 or 366 on 31 December, +! depending on whether the year is a leap year. Sometimes this is +! called the Julian Day, but that term is better reserved for the +! day counter explained below. +! +! JULIAN DAY NUMBER +! The Julian Day numbering system was designed by Joseph Scaliger +! in 1582 to remove ambiguity caused by varying calendar systems. +! The name "Julian Day" was chosen to honor Scaliger's father, +! Julius Caesar Scaliger (1484-1558), an Italian scholar and physician +! who lived in France. Because Julian Day numbering was especially +! designed for astronomers, Julian Days begin at noon so that the day +! counter does not change in the middle of an astronmer's observing +! period. Julian Day 0 began at noon on 1 January 4713 BC under the +! Julian calendar. A modern reference point is that 23 May 1968 +! (Gregorian calendar) was Julian Day 2,440,000. +! +! JULIAN DAY NUMBER EXAMPLES +! +! The table below shows a few Julian Day numbers and their corresponding +! dates, depending on which calendar is used. A negative 'iyear' refers +! to BC (Before Christ). +! +! Julian Day under calendar: +! iday month iyear Gregorian Julian +! 24 11 -4714 0 -38 +! 1 1 -4713 38 0 +! 1 1 1 1721426 1721424 +! 4 10 1582 2299150 2299160 +! 15 10 1582 2299161 2299171 +! 1 3 1600 2305508 2305518 +! 23 5 1968 2440000 2440013 +! 5 7 1998 2451000 2451013 +! 1 3 2000 2451605 2451618 +! 1 1 2001 2451911 2451924 +! +! From this table, we can see that the 10 day difference between the +! two calendars in 1582 grew to 13 days by 1 March 1900, since 1900 was +! a leap year under the Julian calendar but not under the Gregorian +! calendar. The gap will widen to 14 days after 1 March 2100 for the +! same reason. +! +!---------- +! +! PORTABILITY +! +! This subroutine is written in standard FORTRAN 77. +! It calls no external functions or subroutines and should run +! without problem on any computer having a 32-bit word or longer. +! +!---------- +! +! ALGORITHM +! +! The goal in coding calndr() was clear, clean code, not efficiency. +! Calendar calculations usually take a trivial fraction of the time +! in any program in which dates conversions are involved. +! Data analysis usually takes the most time. +! +! Standard algorithms are followed in this subroutine. Internal to +! this subroutine, we use a year counter "jyear" such that +! jyear=iyear when iyear is positive +! =iyear+1 when iyear is negative. +! Thus, jyear does not experience a 1 year jump like iyear does +! when going from BC to AD. Specifically, jyear=0 when iyear=-1, +! i.e., when the year is 1 BC. +! +! For simplicity in dealing with February, inside this subroutine, +! we let the year begin on 1 March so that the adjustable month, +! February is the last month of the year. +! It is clear that the calendar used to work this way because the +! months September, October, November, and December refer to +! 7, 8, 9, and 10. For consistency, jyear is incremented on 1 March +! rather than on 1 January. Of course, everything is adjusted back to +! standard practice of years beginning on 1 January before answers +! are returned to the routine that calls calndr(). +! +! Lastly, we use a trick to calculate the number of days from 1 March +! until the end of the month that precedes the specified month. +! That number of days is int(30.6001*(month+1))-122, +! where 30.6001 is used to avoid the possibility of round-off and +! truncation error. For example, if 30.6 were used instead, +! 30.6*5 should be 153, but round-off error could make it 152.99999, +! which would then truncated to 152, causing an error of 1 day. +! +! Algorithm reference: +! Dershowitz, Nachum and Edward M. Reingold, 1990: Calendrical +! Calculations. Software-Practice and Experience, vol. 20, number 9 +! (September 1990), pp. 899-928. +! +! Copyright (C) 1999 Jon Ahlquist. +! Issued under the second GNU General Public License. +! See www.gnu.org for details. +! This program is distributed in the hope that it will be useful, +! but WITHOUT ANY WARRANTY; without even the implied warranty of +! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +! If you find any errors, please notify: +! Jon Ahlquist +! Dept of Meteorology +! Florida State University +! Tallahassee, FL 32306-4520 +! 15 March 1999. +! +!----- +! Declare internal variables. + integer jdref, jmonth, jyear, leap,& + & n1yr, n4yr, n100yr, n400yr,& + & ndays, ndy400, ndy100, nyrs,& + & yr400, yrref +! +! Explanation of all internal variables. +! jdref Julian Day on which 1 March begins in the reference year. +! jmonth Month counter which equals month+1 if month .gt. 2 +! or month+13 if month .le. 2. +! jyear Year index, jyear=iyear if iyear .gt. 0, jyear=iyear+1 +! if iyear .lt. 0. Thus, jyear does not skip year 0 +! like iyear does between BC and AD years. +! leap =1 if the year is a leap year, =0 if not. +! n1yr Number of complete individual years between iyear and +! the reference year after all 4, 100, +! and 400 year periods have been removed. +! n4yr Number of complete 4 year cycles between iyear and +! the reference year after all 100 and 400 year periods +! have been removed. +! n100yr Number of complete 100 year periods between iyear and +! the reference year after all 400 year periods +! have been removed. +! n400yr Number of complete 400 year periods between iyear and +! the reference year. +! ndays Number of days since 1 March during iyear. (In intermediate +! steps, it holds other day counts as well.) +! ndy400 Number of days in 400 years. Under the Gregorian calendar, +! this is 400*365 + 100 - 3 = 146097. Under the Julian +! calendar, this is 400*365 + 100 = 146100. +! ndy100 Number of days in 100 years, Under the Gregorian calendar, +! this is 100*365 + 24 = 36524. Under the Julian calendar, +! this is 100*365 + 25 = 36525. +! nyrs Number of years from the beginning of yr400 +! to the beginning of jyear. (Used for option +/-3). +! yr400 The largest multiple of 400 years that is .le. jyear. +! +! +!---------------------------------------------------------------- +! Do preparation work. +! +! Look for out-of-range option values. + if ((ioptn .eq. 0) .or. (abs(ioptn) .ge. 6)) then + write(*,*)'For calndr(), you specified ioptn = ', ioptn + write(*,*) & + & 'Allowable values are 1 to 5 for the Gregorian calendar' + write(*,*) & + & 'and -1 to -5 for the Julian calendar.' + stop + endif +! +! Options 1-3 have "iyear" as an input value. +! Internally, we use variable "jyear" that does not have a jump +! from -1 (for 1 BC) to +1 (for 1 AD). + if (abs(ioptn) .le. 3) then + if (iyear .gt. 0) then + jyear = iyear + elseif (iyear .eq. 0) then + write(*,*) & + & 'For calndr(), you specified the nonexistent year 0' + stop + else + jyear = iyear + 1 + endif +! +! Set "leap" equal to 0 if "jyear" is not a leap year +! and equal to 1 if it is a leap year. + leap = 0 + if ((jyear/4)*4 .eq. jyear) then + leap = 1 + endif + if ((ioptn .gt. 0) .and. & + & ((jyear/100)*100 .eq. jyear) .and. & + & ((jyear/400)*400 .ne. jyear) ) then + leap = 0 + endif + endif +! +! Options 3-5 involve Julian Day numbers, which need a reference year +! and the Julian Days that began at noon on 1 March of the reference +! year under the Gregorian and Julian calendars. Any year for which +! "jyear" is divisible by 400 can be used as a reference year. +! We chose 1600 AD as the reference year because it is the closest +! multiple of 400 to the institution of the Gregorian calendar, making +! it relatively easy to compute the Julian Day for 1 March 1600 +! given that, on 15 October 1582 under the Gregorian calendar, +! the Julian Day was 2299161. Similarly, we need to do the same +! calculation for the Julian calendar. We can compute this Julian +! Day knwoing that on 4 October 1582 under the Julian calendar, +! the Julian Day number was 2299160. The details of these calculations +! is next. +! From 15 October until 1 March, the number of days is the remainder +! of October plus the days in November, December, January, and February: +! 17+30+31+31+28 = 137, so 1 March 1583 under the Gregorian calendar +! was Julian Day 2,299,298. Because of the 10 day jump ahead at the +! switch from the Julian calendar to the Gregorian calendar, 1 March +! 1583 under the Julian calendar was Julian Day 2,299,308. Making use +! of the rules for the two calendar systems, 1 March 1600 was Julian +! Day 2,299,298 + (1600-1583)*365 + 5 (due to leap years) = +! 2,305,508 under the Gregorian calendar and day 2,305,518 under the +! Julian calendar. +! We also set the number of days in 400 years and 100 years. +! For reference, 400 years is 146097 days under the Gregorian calendar +! and 146100 days under the Julian calendar. 100 years is 36524 days +! under the Gregorian calendar and 36525 days under the Julian calendar. + if (abs(ioptn) .ge. 3) then +! +! Julian calendar values. + yrref = 1600 + jdref = 2305518 +! = Julian Day reference value for the day that begins +! at noon on 1 March of the reference year "yrref". + ndy400 = 400*365 + 100 + ndy100 = 100*365 + 25 +! +! Adjust for Gregorian calendar values. + if (ioptn .gt. 0) then + jdref = jdref - 10 + ndy400 = ndy400 - 3 + ndy100 = ndy100 - 1 + endif + endif +! +!---------------------------------------------------------------- +! OPTIONS -1 and +1: +! Given a calendar date (iday,month,iyear), compute the day number +! of the year (idayct), where 1 January is day number 1 and 31 December +! is day number 365 or 366, depending on whether it is a leap year. + if (abs(ioptn) .eq. 1) then +! +! Compute the day number during the year. + if (month .le. 2) then + idayct = iday + (month-1)*31 + else + idayct = iday + int(30.6001 * (month+1)) - 63 + leap + endif +! +!---------------------------------------------------------------- +! OPTIONS -2 and +2: +! Given the day number of the year (idayct) and the year (iyear), +! compute the day of the month (iday) and the month (month). + elseif (abs(ioptn) .eq. 2) then +! + if (idayct .lt. 60+leap) then + month = (idayct-1)/31 + iday = idayct - month*31 + month = month + 1 + else + ndays = idayct - (60+leap) +! = number of days past 1 March of the current year. + jmonth = (10*(ndays+31))/306 + 3 +! = month counter, =4 for March, =5 for April, etc. + iday = (ndays+123) - int(30.6001*jmonth) + month = jmonth - 1 + endif +! +!---------------------------------------------------------------- +! OPTIONS -3 and +3: +! Given a calendar date (iday,month,iyear), compute the Julian Day +! number (idayct) that starts at noon. + elseif (abs(ioptn) .eq. 3) then +! +! Shift to a system where the year starts on 1 March, so January +! and February belong to the preceding year. +! Define jmonth=4 for March, =5 for April, ..., =15 for February. + if (month .le. 2) then + jyear = jyear - 1 + jmonth = month + 13 + else + jmonth = month + 1 + endif +! +! Find the closest multiple of 400 years that is .le. jyear. + yr400 = (jyear/400)*400 +! = multiple of 400 years at or less than jyear. + if (jyear .lt. yr400) then + yr400 = yr400 - 400 + endif +! + n400yr = (yr400 - yrref)/400 +! = number of 400-year periods from yrref to yr400. + nyrs = jyear - yr400 +! = number of years from the beginning of yr400 +! to the beginning of jyear. +! +! Compute the Julian Day number. + idayct = iday + int(30.6001*jmonth) - 123 + 365*nyrs + nyrs/4 & + & + jdref + n400yr*ndy400 +! +! If we are using the Gregorian calendar, we must not count +! every 100-th year as a leap year. nyrs is less than 400 years, +! so we do not need to consider the leap year that would occur if +! nyrs were divisible by 400, i.e., we do not add nyrs/400. + if (ioptn .gt. 0) then + idayct = idayct - nyrs/100 + endif +! +!---------------------------------------------------------------- +! OPTIONS -5, -4, +4, and +5: +! Given the Julian Day number (idayct) that starts at noon, +! compute the corresponding calendar date (iday,month,iyear) +! (abs(ioptn)=4) or day number during the year (abs(ioptn)=5). + else +! +! Create a new reference date which begins on the nearest +! 400-year cycle less than or equal to the Julian Day for 1 March +! in the year in which the given Julian Day number (idayct) occurs. + ndays = idayct - jdref + n400yr = ndays / ndy400 +! = integral number of 400-year periods separating +! idayct and the reference date, jdref. + jdref = jdref + n400yr*ndy400 + if (jdref .gt. idayct) then + n400yr = n400yr - 1 + jdref = jdref - ndy400 + endif +! + ndays = idayct - jdref +! = number from the reference date to idayct. +! + n100yr = min(ndays/ndy100, 3) +! = number of complete 100-year periods +! from the reference year to the current year. +! The min() function is necessary to avoid n100yr=4 +! on 29 February of the last year in the 400-year cycle. +! + ndays = ndays - n100yr*ndy100 +! = remainder after removing an integral number of +! 100-year periods. +! + n4yr = ndays / 1461 +! = number of complete 4-year periods in the current century. +! 4 years consists of 4*365 + 1 = 1461 days. +! + ndays = ndays - n4yr*1461 +! = remainder after removing an integral number +! of 4-year periods. +! + n1yr = min(ndays/365, 3) +! = number of complete years since the last leap year. +! The min() function is necessary to avoid n1yr=4 +! when the date is 29 February on a leap year, +! in which case ndays=1460, and 1460/365 = 4. +! + ndays = ndays - 365*n1yr +! = number of days so far in the current year, +! where ndays=0 on 1 March. +! + iyear = n1yr + 4*n4yr + 100*n100yr + 400*n400yr + yrref +! = year, as counted in the standard way, +! but relative to 1 March. +! +! At this point, we need to separate ioptn=abs(4), which seeks a +! calendar date, and ioptn=abs(5), which seeks the day number during +! the year. First compute the calendar date if desired (abs(ioptn)=4). + if (abs(ioptn) .eq. 4) then + jmonth = (10*(ndays+31))/306 + 3 +! = offset month counter. jmonth=4 for March, =13 for +! December, =14 for January, =15 for February. + iday = (ndays+123) - int(30.6001*jmonth) +! = day of the month, starting with 1 on the first day +! of the month. +! +! Now adjust for the fact that the year actually begins +! on 1 January. + if (jmonth .le. 13) then + month = jmonth - 1 + else + month = jmonth - 13 + iyear = iyear + 1 + endif +! +! This code handles abs(ioptn)=5, finding the day number during the year. + else +! ioptn=5 always returns month=1, which we set now. + month = 1 +! +! We need to determine whether this is a leap year. + leap = 0 + if ((jyear/4)*4 .eq. jyear) then + leap = 1 + endif + if ((ioptn .gt. 0) .and. & + & ((jyear/100)*100 .eq. jyear) .and. & + & ((jyear/400)*400 .ne. jyear) ) then + leap = 0 + endif +! +! Now find the day number "iday". +! ndays is the number of days since the most recent 1 March, +! so ndays=0 on 1 March. + if (ndays .le.305) then + iday = ndays + 60 + leap + else + iday = ndays - 305 + iyear = iyear + 1 + endif + endif +! +! Adjust the year if it is .le. 0, and hence BC (Before Christ). + if (iyear .le. 0) then + iyear = iyear - 1 + endif +! +! End the code for the last option, ioptn. + endif +! + return + end + + + integer function idaywk(jdayno) +! +! IDAYWK = compute the DAY of the WeeK given the Julian Day number, +! version 1.0. +! +! Input variable + integer jdayno +! jdayno = Julian Day number starting at noon of the day in question. +! +! Output variable: +! idaywk = day of the week, where 0=Sunday, 1=Monday, ..., 6=Saturday. +! +!---------- +! Compute the day of the week given the Julian Day number. +! You can find the Julian Day number given (day,month,year) +! using subroutine calndr.f. +! Example: For the first day of the Gregorian calendar, +! 15 October 1582, compute the Julian day number (option 3 of +! subroutine calndr) and compute the day of the week. +! call calndr (3, 15, 10, 1582, jdayno) +! write(*,*) jdayno, idaywk(jdayno) +! The numbers printed should be 2299161 and 5, +! where 6 refers to Friday. +! +! Copyright (C) 1999 Jon Ahlquist. +! Issued under the second GNU General Public License. +! See www.gnu.org for details. +! This program is distributed in the hope that it will be useful, +! but WITHOUT ANY WARRANTY; without even the implied warranty of +! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +! If you find any errors, please notify: +! Jon Ahlquist +! Dept of Meteorology +! Florida State University +! Tallahassee, FL 32306-4520 +! 15 March 1999. +! +!----- +! Declare internal variable. +! jdSun is the Julian Day number starting at noon on any Sunday. +! I arbitrarily chose the first Sunday after Julian Day 1, +! which is Julian Day 6. + integer jdSun + data jdSun /6/ + idaywk = mod(jdayno-jdSun,7) +! If jdayno-jdSun < 0, then we are taking the modulus of a negative +! number. Fortran's built-in mod function returns a negative value +! when the argument is negative. In that case, we adjust the result +! to a positive value. + if (idaywk .lt. 0) idaywk = idaywk + 7 + return + + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/enbal_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/enbal_code.f90 new file mode 100755 index 000000000..8c948637e --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/enbal_code.f90 @@ -0,0 +1,808 @@ +! enbal_code.f + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ENBAL_CODE(nx,ny,Tair_grid,uwind_grid,sfc_pressure,& + & vwind_grid,rh_grid,Tsfc,Qsi_grid,Qli_grid,Qle,Qh,Qe,& + & Qc,Qm,e_balance,Qf,snow_d,ht_windobs,icond_flag,& + & albedo,snow_z0,veg_z0,vegtype,undef,albedo_snow_forest,& + & albedo_snow_clearing,albedo_glacier,snod_layer,T_old,& + & gamma,KK) + + use snowmodel_inc + implicit none + + real Tair_grid(nx,ny) + real rh_grid(nx,ny) + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + real Qsi_grid(nx,ny) + real Qli_grid(nx,ny) + real albedo(nx,ny) + real vegtype(nx,ny) + real veg_z0(nx,ny) + + real,dimension(nx,ny) :: Tsfc,Qle,& + & Qh,Qe,Qc,& + & Qm,e_balance,Qf,& + & snow_d,sfc_pressure + + real snow_z0,veg_z0_tmp,windspd,ht_windobs,undef,& + & albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + & count_Tsfc_not_converged + + integer i,j,nx,ny,icond_flag,k + + integer KK(nx,ny) + real snod_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real gamma(nx,ny,nz_max) + real snod_layer_z(2) + real T_old_z(2) + real gamma_z(2) + +! print *,' solving the energy balance' + + count_Tsfc_not_converged = 0.0 + + do j=1,ny + do i=1,nx + + windspd = sqrt(uwind_grid(i,j)**2+vwind_grid(i,j)**2) + +! Prevent the problem of low wind speeds in the logarithmic wind +! profile calculations. + windspd = max(1.0,windspd) + + veg_z0_tmp = veg_z0(i,j) + +! Extract the vertical column for this i,j point, and send it +! to the subroutine. *** Note that I should use f95, then I would +! not have to do this (I could pass in subsections of the arrays). + if (icond_flag.eq.1) then + do k=1,2 + snod_layer_z(k) = snod_layer(i,j,k) + T_old_z(k) = T_old(i,j,k) + gamma_z(k) = gamma(i,j,k) + enddo + endif + + CALL ENBAL_CORE(Tair_grid(i,j),windspd,rh_grid(i,j),& + & Tsfc(i,j),Qsi_grid(i,j),Qli_grid(i,j),Qle(i,j),Qh(i,j),& + & Qe(i,j),Qc(i,j),Qm(i,j),e_balance(i,j),Qf(i,j),undef,& + & sfc_pressure(i,j),snow_d(i,j),ht_windobs,& + & icond_flag,albedo(i,j),snow_z0,veg_z0_tmp,vegtype(i,j),& + & albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + & snod_layer_z,T_old_z,gamma_z,KK(i,j),& + & count_Tsfc_not_converged) + enddo + enddo + +! Calculate the % of the grid cells that did not converge during +! this time step. + count_Tsfc_not_converged = 100.0* count_Tsfc_not_converged / & + & real(nx*ny) + +! Set the not-converged threshold to be 1% of the grid cells. + if (count_Tsfc_not_converged.gt.1.0) then + print *,'Over 1% of the grid cells failed to converge' + print *,' in the Tsfc energy balance calculation. This' + print *,' usually means there in a problem with the' + print *,' atmopheric forcing inputs, or that windspd_min' + print *,' in snowmodel.par is set too low; like less than' + print *,' 1 m/s.' + print * + print *,'% Tsfc not converged = ',count_Tsfc_not_converged + endif + + return + end SUBROUTINE ENBAL_CODE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ENBAL_CORE(Tair,windspd,rh,& + & Tsfc,Qsi,Qli,Qle,Qh,& + & Qe,Qc,Qm,e_balance,Qf,undef,& + & sfc_pressure,snow_d,ht_windobs,& + & icond_flag,albedo,snow_z0,veg_z0_tmp,vegtype,& + & albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + & snod_layer_z,T_old_z,gamma_z,KK,& + & count_Tsfc_not_converged) + +! This is the FORTRAN code which implements the surface energy +! balance model used in: +! +! (1) "Local Advection of Momentum, Heat, and Moisture during the +! Melt of Patchy Snow Covers", G. E. Liston, J. Applied +! Meteorology, 34, 1705-1715, 1995. +! +! (2) "An Energy-Balance Model of Lake-Ice Evolution", G. E. +! Liston, D. K. Hall, J. of Glaciology, (41), 373-382, 1995. +! +! (3) "Sensitivity of Lake Freeze-Up and Break-Up to Climate +! Change: A Physically Based Modeling Study", G. E. Liston, +! D. K. Hall, Annals of Glaciology, (21), 387-393, 1995. +! +! (4) "Below-Surface Ice Melt on the Coastal Antarctic Ice +! Sheet", G. E. Liston, and 4 others, J. of Glaciology, (45), +! 273-285, 1999. +! +! This version runs at sub-hourly to daily time steps. +! +! In addition, this version includes the influence of direct and +! diffuse solar radiation, and the influence of topographic +! slope and aspect on incoming solar radiation. + + implicit none + + real Tair,windspd,rh,Tsfc,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,e_balance,& + & Qf,sfc_pressure,snow_d,ht_windobs,albedo,snow_z0,& + & veg_z0_tmp,vegtype,emiss_sfc,Stef_Boltz,ro_air,Cp,gravity,& + & xls,xkappa,xLf,Tf,ro_water,Cp_water,ro_ice,z_0,ea,de_h,& + & stability,es0,undef,albedo_snow_forest,albedo_snow_clearing,& + & albedo_glacier,count_Tsfc_not_converged + + integer icond_flag,KK + + real snod_layer_z(2) + real T_old_z(2) + real gamma_z(2) + +! Define the constants used in the computations. + CALL CONSTS_ENBAL(emiss_sfc,Stef_Boltz,ro_air,Cp,gravity,& + & xls,xkappa,xLf,Tf,ro_water,Cp_water,ro_ice) + +! Define the surface characteristics based on the snow conditions. + CALL GET_SFC(snow_d,albedo,z_0,Tf,Tair,snow_z0,veg_z0_tmp,& + & vegtype,albedo_snow_forest,albedo_snow_clearing,& + & albedo_glacier) + +! Atmospheric vapor pressure from relative humidity data. + CALL VAPPRESS(ea,rh,Tair,Tf) + +! Compute the turbulent exchange coefficients. + CALL EXCOEFS(De_h,z_0,ht_windobs,windspd,xkappa) + +! Compute the flux contribution due to conduction. + CALL CONDUCT(icond_flag,Qc,snod_layer_z,T_old_z,gamma_z,& + & KK) + +! Solve the energy balance for the surface temperature. + CALL SFCTEMP(Tsfc,Tair,Qsi,Qli,ea,albedo,De_h,& + & sfc_pressure,ht_windobs,windspd,ro_air,Cp,emiss_sfc,& + & Stef_Boltz,gravity,xLs,xkappa,z_0,Tf,Qc,& + & count_Tsfc_not_converged) + +! Make sure the snow surface temperature is <= 0 C. + CALL MELTTEMP(Tsfc,Tf,snow_d,vegtype) + +! Compute the stability function. + CALL STABLEFN(stability,Tair,Tsfc,windspd,ht_windobs,& + & gravity,xkappa,z_0) + +! Compute the water vapor pressure at the surface. + CALL VAPOR(es0,Tsfc,Tf) + +! Compute the latent heat flux. + CALL LATENT(Qe,De_h,stability,ea,es0,ro_air,xLs,& + & sfc_pressure,undef,snow_d,vegtype) + +! Compute the sensible heat flux. + CALL SENSIBLE(Qh,De_h,stability,Tair,Tsfc,ro_air,Cp,& + & undef,snow_d,vegtype) + +! Compute the longwave flux emitted by the surface. + CALL LONGOUT(Qle,Tsfc,emiss_sfc,Stef_Boltz) + +! Compute the energy flux available for melting or freezing. + CALL MFENERGY(albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,Qf,Tsfc,& + & Tf,Tair,windspd,ht_windobs,gravity,De_h,ea,ro_air,xLs,& + & sfc_pressure,Cp,emiss_sfc,Stef_Boltz,snow_d,xkappa,z_0,& + & vegtype,icond_flag,undef,snod_layer_z,T_old_z,gamma_z,KK) + +! Perform an energy balance check. + CALL ENBAL(e_balance,albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,& + & undef,snow_d,vegtype) + + return + end SUBROUTINE ENBAL_CORE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE VAPPRESS(ea,rh,Tair,Tf) + + implicit none + + real A,B,C,ea,rh,Tair,Tf + +! Also see the VAPOR subroutine. + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + +! Because I am interested in sublimation over snow during the +! winter, do these calculations over ice. + +! Over water. +! A = 6.1121 * 100.0 +! B = 17.502 +! C = 240.97 +! Over ice. + A = 6.1115 * 100.0 + B = 22.452 + C = 272.55 + +! Atmospheric vapor pressure from relative humidity data. + ea = rh / 100.0 * A * exp((B * (Tair - Tf))/(C + (Tair - Tf))) + + return + end SUBROUTINE VAPPRESS + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE MFENERGY(albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,Qf,Tsfc,& + & Tf,Tair,windspd,ht_windobs,gravity,De_h,ea,ro_air,xLs,& + & sfc_pressure,Cp,emiss_sfc,Stef_Boltz,snow_d,xkappa,z_0,& + & vegtype,icond_flag,undef,snod_layer_z,T_old_z,gamma_z,KK) + + implicit none + + real albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,Qf,Tsfc,Tf,Tair,windspd,& + & ht_windobs,gravity,De_h,ea,ro_air,xLs,sfc_pressure,Cp,& + & emiss_sfc,Stef_Boltz,snow_d,xkappa,z_0,vegtype,xTsfc,& + & xstability,xes0,xQe,xqh,xQle,xQc,undef + + integer icond_flag,KK + + real snod_layer_z(2) + real T_old_z(2) + real gamma_z(2) + +! If Qm is > 0, then this is the energy available for melting. +! If Qm is < 0, then this is the energy available for freezing +! liquid water in the snowpack. + if (snow_d.gt.0.0 .and. Tsfc.eq.Tf) then + Qm = (1.0-albedo) * Qsi + Qli + Qle + Qh + Qe + Qc + elseif (vegtype.eq.20.0 .and. Tsfc.eq.Tf) then + Qm = (1.0-albedo) * Qsi + Qli + Qle + Qh + Qe + Qc + else + Qm = 0.0 + endif + + if (Tsfc.lt.Tf) then + xTsfc = Tf + CALL STABLEFN(xstability,Tair,xTsfc,windspd,ht_windobs,& + & gravity,xkappa,z_0) + CALL VAPOR(xes0,xTsfc,Tf) + CALL LATENT(xQe,De_h,xstability,ea,xes0,ro_air,xLs,& + & sfc_pressure,undef,snow_d,vegtype) + CALL SENSIBLE(xQh,De_h,xstability,Tair,xTsfc,ro_air,Cp,& + & undef,snow_d,vegtype) + CALL LONGOUT(xQle,xTsfc,emiss_sfc,Stef_Boltz) + CALL CONDUCT(icond_flag,xQc,snod_layer_z,T_old_z,gamma_z,& + & KK) + Qf = (1.0-albedo) * Qsi + Qli + xQle + xQh + xQe + xQc + else + Qf = 0.0 + endif + + return + end SUBROUTINE MFENERGY + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE MELTTEMP(Tsfc,Tf,snow_d,vegtype) + + implicit none + + real Tsfc,snow_d,vegtype,Tf + + if (snow_d.gt.0.0 .or. vegtype.eq.20.0) then + if (Tsfc.gt.Tf) Tsfc = Tf + endif + + return + end SUBROUTINE MELTTEMP + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE CONDUCT(icond_flag,Qc,snod_layer_z,T_old_z,gamma_z,& + & KK) + + implicit none + + integer icond_flag,KK + + real Qc + real snod_layer_z(2) + real T_old_z(2) + real gamma_z(2) + + if (icond_flag.eq.0) then + Qc = 0.0 + else + if (KK.le.1) then + Qc = 0.0 + else + Qc = - (gamma_z(1) + gamma_z(2))/2.0 * & + & (T_old_z(1) - T_old_z(2)) / & + & (snod_layer_z(1) + snod_layer_z(2))/2.0 + endif + endif + + return + end SUBROUTINE CONDUCT + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE CONSTS_ENBAL(emiss_sfc,Stef_Boltz,ro_air,Cp,gravity,& + & xLs,xkappa,xLf,Tf,ro_water,Cp_water,ro_ice) + + implicit none + + real emiss_sfc,Stef_Boltz,ro_air,Cp,gravity,xLs,xkappa,xLf,& + & Tf,ro_water,Cp_water,ro_ice + + emiss_sfc = 0.98 + Stef_Boltz = 5.6696e-8 + ro_air = 1.275 + Cp = 1004. + gravity = 9.81 + xLs = 2.500e6 + xkappa = 0.4 + xLf = 3.34e5 + Tf = 273.15 + ro_water = 1000.0 + Cp_water = 4180.0 + ro_ice = 917.0 + + return + end SUBROUTINE CONSTS_ENBAL + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ENBAL(e_balance,albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,& + & undef,snow_d,vegtype) + + implicit none + + real e_balance,albedo,Qsi,Qli,Qle,Qh,Qe,Qc,Qm,undef,snow_d,& + & vegtype + + if (snow_d.gt.0.0 .or. vegtype.eq.20.0) then + e_balance = (1.0-albedo)*Qsi + Qli + Qle + Qh + Qe + Qc - Qm + else + e_balance = undef + endif + + return + end SUBROUTINE ENBAL + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE STABLEFN(stability,Tair,Tsfc,windspd,ht_windobs,& + & gravity,xkappa,z_0) + + implicit none + + real C1,C2,B1,B2,stability,Tair,Tsfc,windspd,ht_windobs,& + & gravity,xkappa,z_0,B8,B3,z_0_tmp + + z_0_tmp = min(0.25*ht_windobs,z_0) + C1 = 5.3 * 9.4 * (xkappa/(log(ht_windobs/z_0_tmp)))**2 * & + & sqrt(ht_windobs/z_0_tmp) + C2 = gravity * ht_windobs / (Tair * windspd**2) + B1 = 9.4 * C2 + B2 = C1 * sqrt(C2) + + if (Tsfc.gt.Tair) then +! Unstable case. + B3 = 1.0 + B2 * sqrt(Tsfc - Tair) + stability = 1.0 + B1 * (Tsfc - Tair) / B3 + elseif (Tsfc.lt.Tair) then +! Stable case. + B8 = B1 / 2.0 + stability = 1.0 / ((1.0 + B8 * (Tair - Tsfc))**2) + else +! Neutrally stable case. + stability = 1.0 + endif + + return + end SUBROUTINE STABLEFN + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE LONGOUT(Qle,Tsfc,emiss_sfc,Stef_Boltz) + + implicit none + + real Qle,emiss_sfc,Stef_Boltz,Tsfc + + Qle = (- emiss_sfc) * Stef_Boltz * Tsfc**4 + + return + end SUBROUTINE LONGOUT + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SENSIBLE(Qh,De_h,stability,Tair,Tsfc,ro_air,Cp,& + & undef,snow_d,vegtype) + + implicit none + + real Qh,De_h,stability,Tair,Tsfc,ro_air,Cp,undef,snow_d,vegtype + + if (snow_d.gt.0.0 .or. vegtype.eq.20.0) then + Qh = ro_air * Cp * De_h * stability * (Tair - Tsfc) + else + Qh = undef +! To do this, see the laps snow-shrub parameterization runs. +! Qh = ro_air * Cp * De_h * stability * (Tair - Tsfc) + endif + + return + end SUBROUTINE SENSIBLE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SFCTEMP(Tsfc,Tair,Qsi,Qli,ea,albedo,De_h,& + & sfc_pressure,ht_windobs,windspd,ro_air,Cp,emiss_sfc,& + & Stef_Boltz,gravity,xLs,xkappa,z_0,Tf,Qc,& + & count_Tsfc_not_converged) + + implicit none + + real Tsfc,Tair,Qsi,Qli,ea,albedo,De_h,sfc_pressure,ht_windobs,& + & windspd,ro_air,Cp,emiss_sfc,Stef_Boltz,gravity,xLs,xkappa,& + & z_0,Tf,Qc,AAA,CCC,DDD,EEE,FFF,C1,C2,B1,B2,z_0_tmp,& + & count_Tsfc_not_converged + + AAA = ro_air * Cp * De_h + CCC = 0.622 / sfc_pressure + DDD = emiss_sfc * Stef_Boltz + EEE = (1.0-albedo) * Qsi + Qli + Qc + FFF = ro_air * xLs * De_h + +! Compute the constants used in the stability coefficient +! computations. + z_0_tmp = min(0.25*ht_windobs,z_0) + C1 = 5.3 * 9.4 * (xkappa/(log(ht_windobs/z_0_tmp)))**2 * & + & sqrt(ht_windobs/z_0_tmp) + C2 = gravity * ht_windobs / (Tair * windspd**2) + B1 = 9.4 * C2 + B2 = C1 * sqrt(C2) + + CALL SOLVE(Tsfc,Tair,ea,AAA,CCC,DDD,EEE,FFF,B1,B2,Tf,& + & count_Tsfc_not_converged) + + return + end SUBROUTINE SFCTEMP + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SOLVE(xnew,Tair,ea,AAA,CCC,DDD,EEE,FFF,B1,B2,Tf,& + & count_Tsfc_not_converged) + + implicit none + + integer maxiter,i + + real tol,old,A,B,C,other1,other2,es0,dother1,dother2,xnew,& + & Tair,ea,AAA,CCC,DDD,EEE,FFF,B1,B2,Tf,B3,stability,& + & dstability,fprime1,fprime2,fprime3,fprime4,B8,funct,& + & fprime,count_Tsfc_not_converged,relax + + tol = 1.0e-2 + maxiter = 20 + old = Tair + relax = 0.8 ! New term added (Apr-2021) + +! Because I am interested in sublimation over snow during the +! winter, do these calculations over ice. + +! Over water. +! A = 6.1121 * 100.0 +! B = 17.502 +! C = 240.97 +! Over ice. + A = 6.1115 * 100.0 + B = 22.452 + C = 272.55 + + do i=1,maxiter + +! This section accounts for an increase in turbulent fluxes +! under unstable conditions. + other1 = AAA * (Tair - old) + es0 = A * exp((B * (old - Tf))/(C + (old - Tf))) + other2 = FFF*CCC*(ea-es0) + + dother1 = - AAA + dother2 = (- FFF)*CCC*es0*B*C/((C + (old - Tf))**2) + + if (old.gt.Tair) then +! Unstable case. + B3 = 1.0 + B2 * sqrt(old - Tair) + stability = 1.0 + B1 * (old - Tair) / B3 + dstability = B1/B3 - (B1*B2*(old-Tair))/ & + & (2.0*B3*B3*sqrt(old-Tair)) + fprime1 = (- 4.0)*DDD*old**3 + fprime2 = stability * dother1 + other1 * dstability + fprime3 = stability * dother2 + other2 * dstability + fprime4 = - 0.0 + + elseif (old.lt.Tair) then +! Stable case. + B8 = B1 / 2.0 + stability = 1.0 / ((1.0 + B8 * (Tair - old))**2) + dstability = 2.0 * B8 / ((1.0 + B8 * (Tair - old))**3) + fprime1 = (- 4.0)*DDD*old**3 + fprime2 = stability * dother1 + other1 * dstability + fprime3 = stability * dother2 + other2 * dstability + fprime4 = - 0.0 + + else +! Neutrally stable case. + stability = 1.0 + fprime1 = (- 4.0)*DDD*old**3 + fprime2 = dother1 + fprime3 = dother2 + fprime4 = - 0.0 + endif + + funct = EEE - DDD*old**4 + AAA*(Tair-old)*stability + & + & FFF*CCC*(ea-es0)*stability + & + & 0.0 + fprime = fprime1 + fprime2 + fprime3 + fprime4 + +! Original code: +! xnew = old - funct/fprime +! G. Liston code update: Apr, 2021 + xnew = old - relax * funct/fprime + + if (abs(xnew - old).lt.tol) return + old = xnew + + enddo + +! If the maximum iterations are exceeded, send a message and set +! the surface temperature to the air temperature. +! write (*,102) +! 102 format('max iteration exceeded when solving for Tsfc') + +! Count the number of times the model did not converge for this +! time step. + count_Tsfc_not_converged = count_Tsfc_not_converged + 1.0 + + xnew = Tair + + return + end SUBROUTINE SOLVE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE LATENT(Qe,De_h,stability,ea,es0,ro_air,xLs,& + & sfc_pressure,undef,snow_d,vegtype) + + implicit none + + real Qe,De_h,stability,ea,es0,ro_air,xLs,sfc_pressure,undef,& + & snow_d,vegtype + + if (snow_d.gt.0.0 .or. vegtype.eq.20.0) then + Qe = ro_air * xLs * De_h * stability * & + & (0.622/sfc_pressure * (ea - es0)) + else + Qe = undef +! To do this, see the laps snow-shrub parameterization runs. +! Qe = ro_air * xLs * De_h * stability * +! & (0.622/sfc_pressure * (ea - es0)) + endif + + return + end SUBROUTINE LATENT + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE EXCOEFS(De_h,z_0,ht_windobs,windspd,xkappa) + + implicit none + + real De_h,z_0,ht_windobs,windspd,xkappa,z_0_tmp + + z_0_tmp = min(0.25*ht_windobs,z_0) + De_h = (xkappa**2) * windspd / ((log(ht_windobs/z_0_tmp))**2) + + return + end SUBROUTINE EXCOEFS + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE VAPOR(es0,Tsfc,Tf) + + implicit none + + real es0,Tsfc,Tf,A,B,C + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + +! Because I am interested in sublimation over snow during the +! winter, do these calculations over ice. + +! Over water. +! A = 6.1121 * 100.0 +! B = 17.502 +! C = 240.97 +! Over ice. + A = 6.1115 * 100.0 + B = 22.452 + C = 272.55 + +! Compute the water vapor pressure at the surface. + es0 = A * exp((B * (Tsfc - Tf))/(C + (Tsfc - Tf))) + + return + end SUBROUTINE VAPOR + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GET_SFC(snow_d,albedo,z_0,Tf,Tair,snow_z0,veg_z0_tmp,& + & vegtype,albedo_snow_forest,albedo_snow_clearing,& + & albedo_glacier) + + implicit none + + real snow_d,albedo,z_0,Tf,Tair,snow_z0,veg_z0_tmp,vegtype,& + & albedo_veg,albedo_snow_forest,albedo_snow_clearing,& + & albedo_glacier +! real scf + +! Note that this is very crude for many reasons, and should be +! improved. See below for an alternative solution. + + albedo_veg = 0.15 + +! Define the albedo and roughness length. + if (snow_d.gt.0.0) then +! Snow. + z_0 = snow_z0 + if (Tair.gt.Tf) then + if (vegtype.le.5.0) then +! Melting. Assume, because of leaf litter, etc., that the snow +! albedo under a forest canopy is different than in a clearing. + albedo = albedo_snow_forest + else + albedo = albedo_snow_clearing + endif +! For thin melting snowcovers (less than 15 cm), reduce the albedo +! to account for the observed enhanced melting processes. +! scf = min(1.0,snow_d/0.15) +! albedo = scf * albedo + (1.0 - scf) * albedo_veg + else +! Dry. + albedo = 0.8 + endif + +! No snow. + else + if (vegtype.eq.20.0) then +! Glacier or permanant snow. + z_0 = snow_z0 + albedo = albedo_glacier + else +! Land. + z_0 = veg_z0_tmp + if (vegtype.le.5.0) then + z_0 = 0.2 + elseif (vegtype.le.11.0) then + z_0 = 0.04 + else + z_0 = 0.02 + endif + albedo = albedo_veg + endif + endif + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! The code below simulates the TIME-EVOLUTION OF SNOW ALBEDO in +! response to precipitation and melt. + +! The general model equations are described in the paper: +! Modeling Snow Depth for Improved Simulation of +! Snow-Vegetion-Atmosphere Interactions. +! Strack, J. E., G. E. Liston, and R. A. Pielke, Sr., 2004, +! Journal of Hydrometeorology, 5, 723-734. + +! implicit none +! real albedo +! real Tair +! real prec +! real al_gr_cold +! real al_gr_melt +! real al_min +! real al_max +! real dt,tau_1 + +! Model time step. +! dt = 3600. +! dt = 86400. + +! Maximum albedo, minimum albedo, gradient cold snow albedo +! gradient melting snow albedo +! al_max = 0.8 +! al_min = 0.5 +! al_gr_cold = 0.008 +! al_gr_melt = 0.24 +! tau_1 = 86400. + +! Define the initial condition. +! albedo = al_max + +! do iter=1,maxiter + +! In the presence of precipitation, re-initialize the albedo. +! if (prec.gt.0.003) albedo = al_max + +! Evolve the snow albedo. +! CALL SNOW_ALBEDO(Tair,albedo,al_gr_cold,al_min, +! & al_gr_melt,dt,tau_1) + +! enddo + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! SUBROUTINE SNOW_ALBEDO(Tair,albedo,al_gr_cold,al_min, +! & al_gr_melt,dt,tau_1) + +! implicit none +! real Tair +! real albedo +! real al_gr_cold +! real al_min +! real al_gr_melt +! real dt,tau_1 + +! if (Tair.le.0.0) then +! albedo = albedo - (al_gr_cold * dt / tau_1) +! albedo = max(albedo,al_min) +! else +! albedo = (albedo - al_min) * exp(-al_gr_melt * dt / tau_1) + +! & al_min +! endif + +! return +! end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + return + end SUBROUTINE GET_SFC + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/micromet_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/micromet_code.f90 new file mode 100755 index 000000000..cefce05cf --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/micromet_code.f90 @@ -0,0 +1,3553 @@ +! micromet_code.f + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +#include "LIS_misc.h" + + subroutine MICROMET_CODE(nx,ny,xmn,ymn,deltax,deltay,& + & iyear_init,imonth_init,iday_init,xhour_init,dt,undef,& + & ifill,iobsint,dn,iter,curve_len_scale,slopewt,curvewt,& + & topo,curvature,terrain_slope,slope_az,Tair_grid,& + & rh_grid,uwind_grid,vwind_grid,Qsi_grid,prec_grid,& + & i_tair_flag,i_rh_flag,i_wind_flag,i_solar_flag,& + & i_prec_flag,isingle_stn_flag,igrads_metfile,& + & windspd_grid,winddir_grid,windspd_flag,winddir_flag,& + & sprec,windspd_min,Qli_grid,i_longwave_flag,vegtype,& + & forest_LAI,iyear,imonth,iday,xhour,corr_factor,& + & icorr_factor_index,lapse_rate_user_flag,& + & iprecip_lapse_rate_user_flag,use_shortwave_obs,& + & use_longwave_obs,use_sfc_pressure_obs,sfc_pressure,& + & run_enbal,run_snowpack,calc_subcanopy_met,vegsnowd_xy,& + & gap_frac,cloud_frac_factor,barnes_lg_domain,n_stns_used,& + & k_stn,xlat_grid,xlon_grid,UTC_flag,icorr_factor_loop,& + & snowmodel_line_flag,xg_line,yg_line,irun_data_assim,& + & wind_lapse_rate,iprecip_scheme,cf_precip_flag,cf_precip,& + & cloud_frac_grid,snowfall_frac,seaice_run,metforce_opt) + + use snowmodel_inc +!KRA + use LIS_logMod, only : LIS_logunit + use LIS_coreMod +!KRA + + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + integer nstns_orig ! number of input values + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real Tair_orig(nstns_max) ! input values + real rh_orig(nstns_max) ! input values + real winddir_orig(nstns_max) ! input values + real windspd_orig(nstns_max) ! input values + real prec_orig(nstns_max) ! input values + real elev_orig(nstns_max) ! station elevation + real dn ! average observation spacing + real topo(nx,ny) ! grid topography + real xlat_grid(nx,ny) ! lat (dec deg) of cell centers + real xlon_grid(nx,ny) ! lon (dec deg) of cell centers + + real Tair_grid(nx,ny) ! output values + real rh_grid(nx,ny) ! output values + real uwind_grid(nx,ny) ! output, E-W wind component + real vwind_grid(nx,ny) ! output, N-S wind component + real windspd_grid(nx,ny) + real winddir_grid(nx,ny) + real Qsi_grid(nx,ny) ! output + real Qli_grid(nx,ny) ! output + real prec_grid(nx,ny) ! output + real sprec(nx,ny) ! output + real sfc_pressure(nx,ny) + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + real dt ! model time step, in seconds + integer iter ! model iteration + integer iyear_init ! model start year + integer imonth_init ! model start month + integer iday_init ! model start day + real xhour_init ! model start hour + integer J_day ! model Julian day, actually day-of-year + + real undef ! undefined value + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + real curvature(nx,ny) ! topographic curvature + real slope_az(nx,ny) ! azimuth of topographic slope + real terrain_slope(nx,ny) ! terrain slope + real vegtype(nx,ny) + real vegsnowd_xy(nx,ny) + real, save, allocatable :: topo_ref_grid(:,:)! reference surface + + real curve_len_scale ! length scale for curvature calculation + real slopewt ! wind model slope weight + real curvewt ! wind model curvature weight + + integer i_tair_flag,i_rh_flag,i_wind_flag,i_solar_flag,& + & i_prec_flag,i_longwave_flag,isingle_stn_flag,igrads_metfile,& + & lapse_rate_user_flag,iprecip_lapse_rate_user_flag,n_stns_used,& + & icorr_factor_loop,irun_data_assim,iprecip_scheme,metforce_opt + + real windspd_flag,winddir_flag,windspd_min,calc_subcanopy_met,& + & T_lapse_rate,Td_lapse_rate,precip_lapse_rate,& + & use_shortwave_obs,use_longwave_obs,use_sfc_pressure_obs,& + & run_enbal,run_snowpack,gap_frac,cloud_frac_factor,& + & barnes_lg_domain,UTC_flag,wind_lapse_rate + + integer, parameter :: nftypes = 5 + real forest_LAI(nftypes) + + real corr_factor(nx_max,ny_max,max_obs_dates+1) + integer icorr_factor_index(max_time_steps) + integer k_stn(nx,ny,9) + + real cf_precip(nx,ny) + real cf_precip_flag + + real cloud_frac_grid(nx,ny) + real snowfall_frac + + real seaice_run + integer i,j,irec,irec_day + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + if(.not.allocated(topo_ref_grid)) then + allocate(topo_ref_grid(nx,ny)) + topo_ref_grid = 0.0 + end if + +! Calculate what the current simulation date should be. + call get_model_time(iyear_init,imonth_init,iday_init,& + & xhour_init,iter,dt,iyear,imonth,iday,xhour,J_day) + + if (irun_data_assim.eq.1) then + write (*,150) icorr_factor_loop,iyear,imonth,iday,xhour + 150 format('In Assim Loop #',i1,'; WORKING ON MODEL TIME =', & + & i5,2i4,f6.1) + else + write (*,151) iyear,imonth,iday,xhour + 151 format(' WORKING ON MODEL TIME =',& + & i5,2i4,f6.1) + endif + +! Read in the observations for this time step, and build an array of +! valid observations to be interpolated. + call get_obs_data(nstns_orig,Tair_orig,rh_orig,xstn_orig,& + & ystn_orig,elev_orig,iyear,imonth,iday,xhour,undef,& + & windspd_orig,winddir_orig,prec_orig,isingle_stn_flag,& + & igrads_metfile,iter) + +! Make the topographic calculations required by the wind and solar +! radiation models. These calculations are not fixed in time +! because as the snow depth evolves it modifies the "topography". + call topo_data(nx,ny,deltax,deltay,topo,& + & curvature,terrain_slope,slope_az,curve_len_scale) + +! Calculate the temperature and dew-point lapse rates to be used in +! the interpolations. + call get_lapse_rates(imonth,iday,T_lapse_rate,& + & Td_lapse_rate,xlat_grid(1,1),lapse_rate_user_flag,& + & precip_lapse_rate,iprecip_lapse_rate_user_flag) + +! Calculate the forest lai for each of the five forest types, and +! for this day of the simulation (the lai varies seasonally for +! the case of deciduous trees). + call get_lai(J_day,forest_LAI) + +! If this is a Lagrangian sea ice parcel trajectory simulation, +! extract the lat-lon of the parcels at this time step. Note +! that these files have daily data in them, so the record has +! to be adjusted to account for this. + if (seaice_run.eq.4.0) then + + if (iter.eq.1) then + open (91,file='extra_met/grid_lat_time.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + open (92,file='extra_met/grid_lon_time.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + endif + + if (dt.eq.86400.0) then + irec = iter + elseif (dt.eq.10800.0) then + call get_daily_irec (iter,dt,irec_day) + irec = irec_day + else + print *,'This has not been set up to work on dt' + print *,' values other than 1 day and 3-hours.' + print *,' dt =',dt + stop + endif + + read (91,rec=irec) ((xlat_grid(i,j),i=1,nx),j=1,ny) + read (92,rec=irec) ((xlon_grid(i,j),i=1,nx),j=1,ny) + + endif + +! TEMPERATURE. + if (i_tair_flag.eq.1) then +! print *,' solving for temperature' + call temperature(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,Tair_orig,dn,Tair_grid,& + & undef,ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,& + & topo,T_lapse_rate,barnes_lg_domain,n_stns_used,k_stn,& + & snowmodel_line_flag,xg_line,yg_line,seaice_run) + endif + +! RELATIVE HUMIDITY. + if (i_rh_flag.eq.1) then +! print *,' solving for relative humidity' + call relative_humidity(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,rh_orig,dn,rh_grid,undef,& + & ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,topo,& + & Tair_orig,Tair_grid,Td_lapse_rate,barnes_lg_domain,& + & n_stns_used,k_stn,snowmodel_line_flag,xg_line,yg_line,& + & seaice_run) + endif + +! WIND SPEED AND DIRECTION. + if (i_wind_flag.eq.1) then +! print *,' solving for wind speed and direction' + call wind(nx,ny,deltax,deltay,xmn,ymn,windspd_orig,& + & nstns_orig,xstn_orig,ystn_orig,dn,undef,ifill,& + & iobsint,iyear,imonth,iday,xhour,elev_orig,& + & winddir_orig,uwind_grid,vwind_grid,slopewt,curvewt,& + & curvature,slope_az,terrain_slope,windspd_grid,& + & winddir_grid,windspd_flag,winddir_flag,windspd_min,& + & vegtype,forest_LAI,calc_subcanopy_met,vegsnowd_xy,& + & barnes_lg_domain,n_stns_used,k_stn,snowmodel_line_flag,& + & xg_line,yg_line,topo_ref_grid,topo,wind_lapse_rate,& + & curve_len_scale,seaice_run) + +! Provide the ability to read in an alternate wind dataset that +! has been previously generated with another program, like +! NUATMOS. The following assumes you are reading in a single +! file with u and v values. The file name is hardcoded here. + elseif (i_wind_flag.eq.-1) then + call read_wind_file(nx,ny,iter,uwind_grid,vwind_grid,& + & windspd_grid,winddir_grid,windspd_flag,winddir_flag,& + & windspd_min) + endif + +! SOLAR RADIATION. + if (i_solar_flag.eq.1) then +! print *,' solving for solar radiation' + call solar(nx,ny,xhour,J_day,topo,rh_grid,Tair_grid,& + & xlat_grid,Qsi_grid,slope_az,terrain_slope,dt,vegtype,& + & forest_LAI,T_lapse_rate,Td_lapse_rate,& + & calc_subcanopy_met,gap_frac,cloud_frac_factor,UTC_flag,& + & xlon_grid,cloud_frac_grid) + +! If requested, modify the model output to account for shortwave +! radiation observations. + if (use_shortwave_obs.eq.1.0) then + if (barnes_lg_domain.eq.1.0) then + print *,'The model is not configured to assimilate' + print *,' solar data with barnes_lg_domain = 1.0.' + stop + endif + call shortwave_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,Qsi_grid,iter) + endif + endif + +! INCOMING LONGWAVE RADIATION. + if (i_longwave_flag.eq.1) then +! print *,' solving for incoming longwave radiation' + call longwave(nx,ny,rh_grid,Tair_grid,Qli_grid,topo,& + & vegtype,forest_LAI,T_lapse_rate,Td_lapse_rate,& + & calc_subcanopy_met,cloud_frac_factor) + +! If requested, modify the model output to account for longwave +! radiation observations. + if (use_longwave_obs.eq.1.0) then + if (barnes_lg_domain.eq.1.0) then + print *,'The model is not configured to assimilate' + print *,' longwave data with barnes_lg_domain = 1.0.' + stop + endif + call longwave_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,Qli_grid,iter) + endif + endif + +! PRECIPITATION. + if (i_prec_flag.eq.1) then +! print *,' solving for precipitation' + call precipitation(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,prec_orig,dn,prec_grid,& + & undef,ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,& + & topo,Tair_grid,sprec,corr_factor,icorr_factor_index,iter,& + & precip_lapse_rate,barnes_lg_domain,n_stns_used,k_stn,& + & snowmodel_line_flag,xg_line,yg_line,topo_ref_grid,& + & iprecip_scheme,cf_precip_flag,cf_precip,snowfall_frac,& + & seaice_run) + endif + +! SURFACE PRESSURE. +! Surface pressure is used in EnBal and SnowMass. If needed for +! this SnowModel simulation, calculate the distribution here. + if (run_enbal.eq.1.0 .or. run_snowpack.eq.1.0) then + call pressure(nx,ny,topo,sfc_pressure) + +! If requested, modify the model output to account for surface +! pressure observations. + if (use_sfc_pressure_obs.eq.1.0) then + if (barnes_lg_domain.eq.1.0) then + print *,'The model is not configured to assimilate' + print *,' pressure data with barnes_lg_domain = 1.0.' + stop + endif + call sfc_pressure_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,sfc_pressure,iter) + endif + endif + + return + end subroutine MICROMET_CODE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine precipitation(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,prec_orig,dn,prec_grid,& + & undef,ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,& + & topo,Tair_grid,sprec,corr_factor,icorr_factor_index,iter,& + & precip_lapse_rate,barnes_lg_domain,n_stns_used,k_stn,& + & snowmodel_line_flag,xg_line,yg_line,topo_ref_grid,& + & iprecip_scheme,cf_precip_flag,cf_precip,snowfall_frac,& + & seaice_run) + +! Interpolate the observed precipitation values to the grid. Also +! interpolate the station elevations to a reference surface. Use +! a precipitation "lapse rate", or adjustment factor to define +! the precipitation on the actual elevation grid. The reason the +! interpolated station elevations are used as the topographic +! reference surface (instead of something like sea level), is +! because the precipitation adjustment factor is a non-linear +! function of elevation difference. + +! The adjustment factor that is used comes from: Thornton, P. E., +! S. W. Running, and M. A. White, 1997: Generating surfaces of +! daily meteorological variables over large regions of complex +! terrain. J. Hydrology, 190, 214-251. + + use snowmodel_inc + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real prec(nstns_max) ! input values + real elev(nstns_max) ! station elevation + real undef ! undefined value + + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! station elevation + real prec_orig(nstns_max) ! input values + + real dn ! average observation spacing + real topo(nx,ny) ! grid topography + real prec_grid(nx,ny) ! output values + real Tair_grid(nx,ny) ! input values + real sprec(nx,ny) ! output values + real topo_ref_grid(nx,ny) ! reference surface + + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + + real delta_topo,alfa,Tf,precip_lapse_rate_m,precip_lapse_rate,& + & barnes_lg_domain + integer i,j,iter,n_stns_used + integer k_stn(nx,ny,9) + + real corr_factor(nx_max,ny_max,max_obs_dates+1) + integer icorr_factor_index(max_time_steps) + integer iprecip_scheme + + real cf_precip(nx,ny) + real cf_precip_flag + + real Tair_C,Tair_C_center,slope,b,snowfall_frac + real snowfall_frac_1,snowfall_frac_2,snowfall_frac_3 + + real seaice_run + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,prec_orig,prec) + +! Use the barnes oi scheme to interpolate the station elevation data +! to the grid, so that it can be used as a topographic reference +! surface. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,elev,dn,topo_ref_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! Use the barnes oi scheme to interpolate the station data to +! the grid. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,prec,dn,prec_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! Convert the precipitation "lapse rate" (km-1) to m-1. + precip_lapse_rate_m = precip_lapse_rate / 1000.0 + +! Choose between Glen's original precipitation increase with +! elevation scheme, and Ward van Pelt's scheme used in our +! Svalbard simulations (see van Pelt et al. 2016). + +! This is Glen's original MicroMet precipitation adjustment +! scheme. + if (iprecip_scheme.eq.1) then + + do j=1,ny + do i=1,nx + +! Convert the gridded station data to the SnowModel-grid elevations. + delta_topo = topo(i,j) - topo_ref_grid(i,j) + +! Don't let the elevation difference be greater than some number +! (like 1800 meters gives a factor of 4.4). If it is too large +! you get huge precipitation adjustment, a divide by zero, or +! even negative adjustments for high elevations). + delta_topo = min(delta_topo,1800.0) + alfa = precip_lapse_rate_m * delta_topo + prec_grid(i,j) = prec_grid(i,j) * (1.0 + alfa)/(1.0 - alfa) + + enddo + enddo + +! This is van Pelt's precipitation adjustment scheme. + elseif (iprecip_scheme.eq.2) then + + do j=1,ny + do i=1,nx + +! Don't correct precipitation above 1000 m a.s.l.. + if (topo_ref_grid(i,j).le.1000.0) then + if (topo(i,j).gt.1000.0) then + delta_topo = 1000.0 - topo_ref_grid(i,j) + else + delta_topo = topo(i,j) - topo_ref_grid(i,j) + endif + endif + if (topo_ref_grid(i,j).gt.1000.0) then + if (topo(i,j).gt.1000.0) then + delta_topo = 0.0 + else + delta_topo = topo(i,j) - 1000.0 + endif + endif + +! Don't let the elevation difference be greater than some number +! (like 1800 meters gives a factor of 4.4). If it is too large +! you get huge precipitation adjustment, a divide by zero, or +! even negative adjustments for high elevations). + delta_topo = min(delta_topo,1800.0) + alfa = 1.75 * delta_topo / 1000.0 + prec_grid(i,j) = prec_grid(i,j) * max(1.0+alfa,0.1) + + enddo + enddo + + endif + +! Convert the precipitation values from mm to m swe. Also, make +! sure the interpolation has not created any negetive +! precipitation values. + do j=1,ny + do i=1,nx + prec_grid(i,j) = prec_grid(i,j) / 1000.0 + prec_grid(i,j) = max(0.0,prec_grid(i,j)) + enddo + enddo + +! This is my original code: +! Use the temperature distribution to define whether this +! precipitation is falling as rain or snow (generate a +! snow-precipitation array following the air temperature +! threshold defined by Auer (1974) = 2.0 C). Note here that, +! if you ever want it, rain_prec = prec_grid - sprec. This +! snow precipitation (sprec) is assumed to be in meters +! snow-water-equivalent per time step. +! Tf = 273.15 +! do j=1,ny +! do i=1,nx +! if (Tair_grid(i,j).lt.2.0+Tf) then +! if (icorr_factor_index(iter).gt.0) then +! prec_grid(i,j) = +! & corr_factor(i,j,icorr_factor_index(iter)) * +! & prec_grid(i,j) +! else +! prec_grid(i,j) = prec_grid(i,j) +! endif +! sprec(i,j) = prec_grid(i,j) +! else +! sprec(i,j) = 0.0 +! endif +! enddo +! enddo + +! First apply any precipitation correction factors calculated as +! part of any data assimilation. + do j=1,ny + do i=1,nx + if (icorr_factor_index(iter).gt.0) then + prec_grid(i,j) = & + & corr_factor(i,j,icorr_factor_index(iter)) * & + & prec_grid(i,j) + endif + enddo + enddo + +! Apply the user-defined precipitation correction factor, if one +! exists. + if (cf_precip_flag.ne.0.0) then + do j=1,ny + do i=1,nx + prec_grid(i,j) = cf_precip(i,j) * prec_grid(i,j) + enddo + enddo + endif + +! Now calculate whether the precipiation is falling as rain or +! snow, and how much of each. + Tf = 273.15 + +! Auer (1974); a rain-snow threshold at +2.0 C. + if (snowfall_frac.eq.1.0) then + + do j=1,ny + do i=1,nx + Tair_C = Tair_grid(i,j) - Tf + if (Tair_C.lt.2.0) then + snowfall_frac_1 = 1.0 + else + snowfall_frac_1 = 0.0 + endif + sprec(i,j) = snowfall_frac_1 * prec_grid(i,j) + enddo + enddo + +! Dai, A. (2008): Temperature and pressure dependence of the +! rain-snow phase transition over land and ocean, Geophys. +! Res. Lett., 35, L12802, doi:10.1029/2008GL033295. +! In this implementation I have clipped Dai's values to 0 +! and 1. + elseif (snowfall_frac.eq.2.0) then + + do j=1,ny + do i=1,nx + Tair_C = Tair_grid(i,j) - Tf + snowfall_frac_2 = - 0.482292 * & + & (tanh(0.7205 * (Tair_C - 1.1662)) - 1.0223) + if (Tair_C.lt.-4.0) then + snowfall_frac_2 = 1.0 + elseif (Tair_C.gt.6.0) then + snowfall_frac_2 = 0.0 + endif + sprec(i,j) = snowfall_frac_2 * prec_grid(i,j) + enddo + enddo + +! Glen's linear approximation to Dai (2008). This plots right +! over the top of Dai, between frac = 0.1 and 0.9. + elseif (snowfall_frac.eq.3.0) then + +! Define where you want the center temperature to be when frac = 0.5. + Tair_C_center = 1.1 +! Define the slope of the line. + slope = -0.30 +! Calculate the intercept (the 0.5 is the frac for Tair_C_center). + b = 0.5 - slope * Tair_C_center + + do j=1,ny + do i=1,nx + Tair_C = Tair_grid(i,j) - Tf + +! Solve the equation in the form y = m*x + b + snowfall_frac_3 = slope * Tair_C + b + snowfall_frac_3 = max(0.0,snowfall_frac_3) + snowfall_frac_3 = min(1.0,snowfall_frac_3) + + sprec(i,j) = snowfall_frac_3 * prec_grid(i,j) + enddo + enddo + + endif + + return + end subroutine precipitation + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine longwave(nx,ny,rh_grid,Tair_grid,Qli_grid,topo,& + & vegtype,forest_LAI,T_lapse_rate,Td_lapse_rate,& + & calc_subcanopy_met,cloud_frac_factor) + + use snowmodel_inc + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + + real Tair_grid(nx,ny) + real rh_grid(nx,ny) + real Qli_grid(nx,ny) + real topo(nx,ny) + real vegtype(nx,ny) + + real T_lapse_rate,Td_lapse_rate,es,e,emiss_cloud,& + & A,B,C,Tf,Stef_Boltz,cloud_frac,E1,X1,Y1,Z1,E2,X2,Y2,Z2,& + & Xs,Ys,Zs,forest_frac,E3,X3,Y3,Z3,alfa,calc_subcanopy_met,& + & cloud_frac_factor + + integer, parameter :: nftypes = 5 + + real forest_LAI(nftypes) + + integer i,j,nveg + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 + +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + +! Define the freezing temperature to be used to convert from C to K. + Tf = 273.15 + +! Define the Stefan Boltzmann constant. + Stef_Boltz = 5.6696e-8 + +! Constants required for Iziomon et al. (2003). + E1 = 200.0 + X1 = 0.35 + Y1 = 0.100 + Z1 = 0.224 + + E2 = 1500.0 + X2 = 0.43 + Y2 = 0.115 + Z2 = 0.320 + +! Assume the X and Y coefficients increase linearly to 3000 m, +! and adjust Z to create a best fit to the CLPX data. + E3 = 3000.0 + X3 = 0.51 + Y3 = 0.130 + Z3 = 1.100 + + do j=1,ny + do i=1,nx + +! Compute the cloud fraction. + call get_cloudfrac(Tair_grid(i,j),rh_grid(i,j),topo(i,j),& + & cloud_frac,T_lapse_rate,Td_lapse_rate,cloud_frac_factor) + +! Calculate the vapor pressure. + es = A * exp((B * (Tair_grid(i,j) - Tf))/ & + & (C + (Tair_grid(i,j) - Tf))) + e = es * rh_grid(i,j) / 100.0 + +! Compute Qli following Iziomon et al. (2003). + if (topo(i,j).lt.E1) then + Xs = X1 + Ys = Y1 + Zs = Z1 + elseif (topo(i,j).gt.E2) then + Xs = X3 + Ys = Y3 + Zs = Z3 + else + Xs = X1 + (topo(i,j) - E1) * (X3 - X1)/(E3 - E1) + Ys = Y1 + (topo(i,j) - E1) * (Y3 - Y1)/(E3 - E1) + Zs = Z1 + (topo(i,j) - E1) * (Z3 - Z1)/(E3 - E1) + endif + + alfa = 1.083 + emiss_cloud = alfa * & + & (1.0 - Xs * exp((- Ys) * e/Tair_grid(i,j))) * & + & (1.0 + Zs * cloud_frac**2) + emiss_cloud = min(1.0,emiss_cloud) + + Qli_grid(i,j) = emiss_cloud * Stef_Boltz * Tair_grid(i,j)**4 + +! Modify the incoming longwave radiation for the forest canopy. + if (vegtype(i,j).le.5.0) then + if (calc_subcanopy_met.eq.1.0) then + +! Define the forest-canopy parameters. + nveg = nint(vegtype(i,j)) + if (forest_LAI(nveg).lt.0.2) then + forest_frac = 0.5 * forest_LAI(nveg) + else + forest_frac = & + & min(1.0,0.55 + 0.29 * log(forest_LAI(nveg))) + endif + Qli_grid(i,j) = Qli_grid(i,j) * (1.0 - forest_frac) + & + & (Stef_Boltz * Tair_grid(i,j)**4) * forest_frac + endif + endif + + enddo + enddo + + return + end subroutine longwave + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine solar(nx,ny,xhour,J_day,topo,rh_grid,Tair_grid,& + & xlat_grid,Qsi_grid,slope_az,terrain_slope,dt,vegtype,& + & forest_LAI,T_lapse_rate,Td_lapse_rate,& + & calc_subcanopy_met,gap_frac,cloud_frac_factor,UTC_flag,& + & xlon_grid,cloud_frac_grid) + +! First take the surface gridded fields of Tair and RH, and +! calculate Td for the topographic surface. Then use Tair and +! Td, and the associated lapse rates, and calculate Tair and Td +! for the 700 mb level. Use these surfaces to calculate RH at +! 700 mb, and convert these values to cloud fraction following +! Walcek, C. J., 1994: Cloud cover and its relationship to +! relative humidity during a spring midlatitude cyclone. Mon. +! Wea. Rev., 122, 1021-1035. + + use snowmodel_inc + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + + real topo(nx,ny) + real Tair_grid(nx,ny) + real rh_grid(nx,ny) + real Qsi_grid(nx,ny) + real slope_az(nx,ny) + real terrain_slope(nx,ny) + real vegtype(nx,ny) + real xlat_grid(nx,ny) + real xlon_grid(nx,ny) + real cloud_frac_grid(nx,ny) + + real xhour ! model decimal hour + real xxhour + integer J_day ! model day of year + integer i,j,ihrs_day,ihour,nveg + real dt,cloud_frac,Qsi_tmp,Qsi_sum,trans_veg,& + & T_lapse_rate,Td_lapse_rate,calc_subcanopy_met,gap_frac,& + & cloud_frac_factor,UTC_flag + + integer, parameter :: nftypes = 5 + real forest_LAI(nftypes) + + ihrs_day = 24 + + do j=1,ny + do i=1,nx + +! Compute the cloud fraction. + call get_cloudfrac(Tair_grid(i,j),rh_grid(i,j),topo(i,j),& + & cloud_frac,T_lapse_rate,Td_lapse_rate,cloud_frac_factor) + +! Save a copy of the cloud fraction distribution. + cloud_frac_grid(i,j) = cloud_frac + +! Compute the incoming solar radiation. The solar_rad subroutine +! calculates the instantaneous incoming solar radiation, so +! if the time step is very long, account for this by calculating +! the incoming solar radiation every 3 hours and then taking the +! average. + if (dt.le.10800.0) then + call solar_rad(Qsi_grid(i,j),J_day,xlat_grid(i,j),& + & cloud_frac,xhour,slope_az(i,j),terrain_slope(i,j),& + & UTC_flag,xlon_grid(i,j)) + elseif (dt.eq.86400.0) then + Qsi_sum = 0.0 + do ihour=3,ihrs_day,3 + xxhour = real(ihour) + call solar_rad(Qsi_tmp,J_day,xlat_grid(i,j),& + & cloud_frac,xxhour,slope_az(i,j),terrain_slope(i,j),& + & UTC_flag,xlon_grid(i,j)) + Qsi_sum = Qsi_sum + Qsi_tmp + enddo + Qsi_grid(i,j) = Qsi_sum / (real(ihrs_day)/3.0) + else + print *,'The model may not do what you want with this dt' + stop + endif + +! Modify the incoming solar radiation for the forest canopy. + if (vegtype(i,j).le.5.0) then + if (calc_subcanopy_met.eq.1.0) then + +! Define the forest-canopy transmissivity. 0.71 provided a +! best-fit to the observations, when averaged over the two years +! of hourly data. + nveg = nint(vegtype(i,j)) + trans_veg = exp((- 0.71) * forest_LAI(nveg)) + +! Account for any gaps in the forest canopy that will allow +! direct incoming solar radiation to reach the snow surface. + trans_veg = gap_frac * (1.0 - trans_veg) + trans_veg + + Qsi_grid(i,j) = trans_veg * Qsi_grid(i,j) + + endif + endif + + enddo + enddo + + return + end subroutine solar + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_cloudfrac(Tair_grid,rh_grid,topo,& + & cloud_frac,T_lapse_rate,Td_lapse_rate,cloud_frac_factor) + + implicit none + + real Td_lapse_rate,topo_ref,delta_topo,A,B,C,e,es,dx,& + & T_lapse_rate,press_ratio,f_max,one_minus_RHe,f_1,& + & Td_700,Tair_700,rh_700,cloud_frac,Tair_grid,rh_grid,& + & topo,Td_grid,Tf,cloud_frac_factor + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 + +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + +! Define the freezing temperature to be used to convert from C to K. + Tf = 273.15 + +! Assume that 700 mb is equivalent to 3000 m in a standard +! atmosphere. + topo_ref = 3000.0 + +! Define the ratio of 700 mb level pressure to the surface pressure +! (~1000 mb). + press_ratio = 0.7 + +! Assume dx = 80.0 km, for Walcek (1994). + dx = 80.0 + +! Walcek coefficients. + f_max = 78.0 + 80.0/15.5 + one_minus_RHe = 0.196 + (0.76-80.0/2834.0) * (1.0 - press_ratio) + f_1 = f_max * (press_ratio - 0.1) / 0.6 / 100.0 + +! Convert the gridded topo-surface RH to Td. + es = A * exp((B * (Tair_grid - Tf))/(C + (Tair_grid - Tf))) + e = es * max(10.0,rh_grid) / 100.0 + Td_grid = C * log(e/A) / (B - log(e/A)) + Tf + +! Convert the topo-surface temperature values to 700 mb values. +! delta_topo = topo - topo_ref + delta_topo = topo_ref - topo + Td_700 = Td_grid + Td_lapse_rate * delta_topo + Tair_700 = Tair_grid + T_lapse_rate * delta_topo + +! Convert each Td to a gridded relative humidity (0-1). + e = A * exp((B * (Td_700 - Tf))/(C + (Td_700 - Tf))) + es = A * exp((B * (Tair_700 - Tf))/(C + (Tair_700 - Tf))) + rh_700 = e/es + rh_700 = min(1.0,rh_700) + rh_700 = max(0.0,rh_700) + +! Use this RH at 700 mb to define the cloud fraction (0-1). + cloud_frac = f_1 * exp((rh_700 - 1.0)/one_minus_RHe) + +! If the user wants to, reduce the calculate cloud fraction by the +! cloud_frac_factor. + cloud_frac = cloud_frac_factor * cloud_frac + + return + end subroutine get_cloudfrac + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine solar_rad(Qsi,J_day,xlat,& + & cloud_frac,xxhour,slope_az,terrain_slope,& + & UTC_flag,xlon) + + implicit none + + integer J_day + + real solar_const,days_yr,Trop_Can,solstice,pi,deg2rad,& + & Qsi_direct,Qsi_diffuse,cos_i,cos_Z,Qsi,xlat,sin_z,xxhour,& + & cloud_frac,slope_az,terrain_slope,sol_dec,hr_angl,& + & trans_direct,trans_diffuse,Qsi_trans_dir,Qsi_trans_dif,& + & sun_azimuth,slope_az_S0,xxxhour,UTC_flag,xlon + +! Required constants. + solar_const = 1370. + days_yr = 365.25 + Trop_Can = 0.41 + solstice = 173. + pi = 2.0 * acos(0.0) + deg2rad = pi / 180.0 + +! COMPUTE THE BASIC SOLAR RADIATION PARAMETERS. + +! Compute the solar declination angle (radians). + sol_dec = Trop_Can * & + & cos(2.*pi * (real(J_day) - solstice)/days_yr) + +! For the case of running UTC time and a latitudinal variation +! in solar radiation, adjust the time to correspond to the +! local time at this longitude position. + if (UTC_flag.ne.0.0) then + xxxhour = xxhour + xlon / 15.0 + if (xxxhour.ge.24.0) xxxhour = xxxhour - 24.0 + if (xxxhour.lt.0.0) xxxhour = xxxhour + 24.0 + else + xxxhour = xxhour + endif + +! Compute the sun's hour angle (radians). + hr_angl = (xxxhour * 15.0 - 180.0) * deg2rad + +! Compute cos_Z. Note that the sin of the solar elevation angle, +! sin_alfa, is equal to the cosine of the solar zenith angle, +! cos_Z. + cos_Z = sin(sol_dec) * sin(xlat * deg2rad) + & + & cos(sol_dec) * cos(xlat * deg2rad) * cos(hr_angl) + cos_Z = max(0.0,cos_Z) + +! Account for clouds, water vapor, pollution, etc. + trans_direct = (0.6 + 0.2 * cos_Z) * (1.0 - cloud_frac) + trans_diffuse = (0.3 + 0.1 * cos_Z) * cloud_frac + +! Compute the solar radiation transmitted through the atmosphere. + Qsi_trans_dir = solar_const * trans_direct + Qsi_trans_dif = solar_const * trans_diffuse + +! COMPUTE THE CORRECTIONS TO ALLOW FOR TOPOGRAPHIC SLOPE AND ASPECT. + +! The sine of the solar zenith angle. + sin_Z = sqrt(1.0 - cos_Z*cos_Z) + +! Azimuth of the sun, with south having zero azimuth for the +! northern hemisphere. + sun_azimuth = & + & asin(max(-1.0,min(1.0,cos(sol_dec)*sin(hr_angl)/sin_Z))) + if (xlat.lt.0.0) then + sun_azimuth = - sun_azimuth + endif + +! Make the corrections so that the angles below the local horizon +! are still measured from the normal to the slope. + if (xlat.ge.0.0) then + if (hr_angl.lt.0.0) then + if (hr_angl.lt.sun_azimuth) sun_azimuth = - pi - sun_azimuth + elseif (hr_angl.gt.0.0) then + if (hr_angl.gt.sun_azimuth) sun_azimuth = pi - sun_azimuth + endif + else +! if (hr_angl.lt.0.0) then +! if (hr_angl.lt.sun_azimuth) sun_azimuth = - pi - sun_azimuth +! elseif (hr_angl.gt.0.0) then +! if (hr_angl.gt.sun_azimuth) sun_azimuth = pi - sun_azimuth +! endif + endif + +! Build, from the variable with north having zero azimuth, a +! slope_azimuth value with south having zero azimuth. Also +! make north have zero azimuth if in the southern hemsisphere. + if (xlat.ge.0.0) then + if (slope_az.ge.180.0) then + slope_az_S0 = slope_az - 180.0 + else + slope_az_S0 = slope_az + 180.0 + endif + else + slope_az_S0 = slope_az + endif + +! Compute the angle between the normal to the slope and the angle +! at which the direct solar radiation impinges on the sloping +! terrain (radians). + cos_i = cos(terrain_slope * deg2rad) * cos_Z + & + & sin(terrain_slope * deg2rad) * sin_Z * & + & cos(sun_azimuth - slope_az_S0 * deg2rad) + +! Adjust the topographic correction due to local slope so that +! the correction is zero if the sun is below the local horizon +! (i.e., the slope is in the shade) or if the sun is below the +! global horizon. + if (cos_i.lt.0.0) cos_i = 0.0 + if (cos_Z.le.0.0) cos_i = 0.0 + +! Adjust the solar radiation for slope, etc. + Qsi_direct = cos_i * Qsi_trans_dir + Qsi_diffuse = cos_Z * Qsi_trans_dif + +! Combine the direct and diffuse solar components. + Qsi = Qsi_direct + Qsi_diffuse + + return + end subroutine solar_rad + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine wind(nx,ny,deltax,deltay,xmn,ymn,windspd_orig,& + & nstns_orig,xstn_orig,ystn_orig,dn,undef,ifill,& + & iobsint,iyear,imonth,iday,xhour,elev_orig,& + & winddir_orig,uwind_grid,vwind_grid,slopewt,curvewt,& + & curvature,slope_az,terrain_slope,windspd_grid,& + & winddir_grid,windspd_flag,winddir_flag,windspd_min,& + & vegtype,forest_LAI,calc_subcanopy_met,vegsnowd_xy,& + & barnes_lg_domain,n_stns_used,k_stn,snowmodel_line_flag,& + & xg_line,yg_line,topo_ref_grid,topo,wind_lapse_rate,& + & curve_len_scale,seaice_run) + +! This program takes the station wind speed and direction, converts +! them to u and v components, interpolates u and v to a grid, +! converts the gridded values to speed and direction, and then +! runs a simple wind model that adjusts those speeds and +! directions according to topographic slope and curvature +! relationships. The resulting speeds and directions are +! converted to u and v components and passed back to the main +! program to be written to a file. (All of the conversion +! between u-v and speed-dir is done because of the problems +! with interpolating over the 360/0 direction line.) + + use snowmodel_inc + ! KRA + use LIS_coreMod + use LIS_mpiMod + use snowmodel_lsmMod, only : snowmodel_struc + ! KRA + implicit none + + integer :: ierr ! KRA + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real elev(nstns_max) ! station elevation + real undef ! undefined value + + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! station elevation + + real windspd_orig(nstns_max) ! input values + real winddir_orig(nstns_max) ! input values + + real speed(nstns_max) ! input values + real dir(nstns_max) ! input values + real u(nstns_max) ! u component of wind + real v(nstns_max) ! v component of wind + + real dn ! average observation spacing + real uwind_grid(nx,ny) ! output values + real vwind_grid(nx,ny) ! output values + real u_grid(nx,ny) ! temporary u wind component + real v_grid(nx,ny) ! temporary v wind component + real winddir_grid(nx,ny) ! temporary wind direction + real windspd_grid(nx,ny) ! temporary wind speed + + real curvature(nx,ny) ! topographic curvature + real slope_az(nx,ny) ! azimuth of topographic slope + real terrain_slope(nx,ny) ! terrain slope + real vegtype(nx,ny) + real vegsnowd_xy(nx,ny) + real topo_ref_grid(nx,ny) ! reference surface + real topo(nx,ny) + + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + + real pi,deg2rad,rad2deg,slopewt,curvewt,curve_len_scale + integer i,j,k,n_stns_used + integer k_stn(nx,ny,9) + real windspd_flag,winddir_flag,u_sum,v_sum,windspd_min,& + & calc_subcanopy_met,barnes_lg_domain,wind_lapse_rate,& + & delta_topo,alfa1,alfa2 + + integer, parameter :: nftypes = 5 + real forest_LAI(nftypes) + real seaice_run + +! Define the required constants. + pi = 2.0 * acos(0.0) + deg2rad = pi / 180.0 + rad2deg = 180.0 / pi + +! Filter through the original input data, and eliminate any +! missing values (i.e., make sure each wind direction is paired +! up with a wind speed. + call get_good_values2(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,windspd_orig,winddir_orig,& + & speed,dir) + +! Convert these station data to u and v wind components. + do k=1,nstns + speed(k) = max(windspd_min,speed(k)) + u(k) = (- speed(k)) * sin(deg2rad * dir(k)) + v(k) = (- speed(k)) * cos(deg2rad * dir(k)) + enddo + +! Use the barnes oi scheme to interpolate the station data to +! the grid. +! U component. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,u,dn,u_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! V component. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,v,dn,v_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! If desired, impose a wind speed increase with elevation. Here +! the wind_lapse_rate = the wind speed increase per 1-km elevation +! gain. The adjustment is patterned after the precipitation- +! elevation adjustment. topo_ref_grid here comes from the +! precipitation adjustment. + if (wind_lapse_rate.ne.0.0) then + alfa1 = (wind_lapse_rate - 1.0) / (1.0 + wind_lapse_rate) +! Convert to m-1. + alfa1 = alfa1 / 1000.0 + do j=1,ny + do i=1,nx + delta_topo = topo(i,j) - topo_ref_grid(i,j) +! Impose some limits to the adjustment. + delta_topo = min(delta_topo,1800.0) + alfa2 = alfa1 * delta_topo + u_grid(i,j) = u_grid(i,j) * (1.0 + alfa2)/(1.0 - alfa2) + v_grid(i,j) = v_grid(i,j) * (1.0 + alfa2)/(1.0 - alfa2) + enddo + enddo + endif + +! Convert these u and v components to speed and directions. + do j=1,ny + do i=1,nx + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(u_grid(i,j)).lt.1e-10) u_grid(i,j) = 1e-10 + + winddir_grid(i,j) = rad2deg * atan2(u_grid(i,j),v_grid(i,j)) + if (winddir_grid(i,j).ge.180.0) then + winddir_grid(i,j) = winddir_grid(i,j) - 180.0 + else + winddir_grid(i,j) = winddir_grid(i,j) + 180.0 + endif + +! winddir_grid(i,j) = 270.0 - +! & rad2deg*atan2(v_grid(i,j),u_grid(i,j)) +! if (winddir_grid(i,j).ge.360.0) +! & winddir_grid(i,j) = winddir_grid(i,j)-360.0 + + windspd_grid(i,j) = sqrt(u_grid(i,j)**2 + v_grid(i,j)**2) + enddo + enddo + +! Modify the wind speed and direction according to simple +! wind-topography relationships. + call topo_mod_winds(nx,ny,winddir_grid,slopewt,curvewt,& + & windspd_grid,uwind_grid,vwind_grid,curvature,slope_az,& + & terrain_slope,vegtype,forest_LAI,calc_subcanopy_met,& + & vegsnowd_xy,curve_len_scale,deltax,deltay) + +! Avoid problems of zero (low) winds (for example, turbulence +! theory, log wind profile, etc., says that we must have some +! wind. Thus, some equations blow up when the wind speed gets +! very small). + do j=1,ny + do i=1,nx + if (windspd_grid(i,j).lt.windspd_min) then + windspd_grid(i,j) = windspd_min + uwind_grid(i,j) = (- windspd_grid(i,j)) * & + & sin(deg2rad*winddir_grid(i,j)) + vwind_grid(i,j) = (- windspd_grid(i,j)) * & + & cos(deg2rad*winddir_grid(i,j)) + endif + enddo + enddo + +! Find the maximum wind speed in the domain, and the +! domain-averaged wind direction. + windspd_flag = 0.0 + u_sum = 0.0 + v_sum = 0.0 + do j=1,ny + do i=1,nx + windspd_flag = max(windspd_flag,windspd_grid(i,j)) + u_sum = u_sum + uwind_grid(i,j) + v_sum = v_sum + vwind_grid(i,j) + enddo + enddo + +! KRA +#if (defined SPMD) +! CAF calls for locating totals ... (Alessandro) +! call co_sum(u_sum) +! call co_sum(v_sum) +! call co_max(windspd_flag) + +! print *, "wind: ",LIS_localPet+1, u_sum, v_sum, windspd_flag + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(u_sum, snowmodel_struc(1)%usum_glb, 1,& + MPI_REAL, MPI_SUM,& + LIS_mpi_comm, ierr) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(v_sum, snowmodel_struc(1)%vsum_glb, 1,& + MPI_REAL, MPI_SUM,& + LIS_mpi_comm, ierr) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(windspd_flag, snowmodel_struc(1)%windspdflg_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + + u_sum = snowmodel_struc(1)%usum_glb + v_sum = snowmodel_struc(1)%vsum_glb + windspd_flag = snowmodel_struc(1)%windspdflg_glb + +! print *, " final u_sum: ",u_sum +! print *, " final v_sum: ",v_sum +! print *, " final wspdflag: ",windspd_flag + +#endif +! KRA + + u_sum = u_sum / real(nx*ny) + v_sum = v_sum / real(nx*ny) + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(u_sum).lt.1e-10) u_sum = 1e-10 + + winddir_flag = rad2deg * atan2(u_sum,v_sum) + if (winddir_flag.ge.180.0) then + winddir_flag = winddir_flag - 180.0 + else + winddir_flag = winddir_flag + 180.0 + endif + +! winddir_flag = 270.0 - rad2deg*atan2(v_sum,u_sum) +! if (winddir_flag.ge.360.0) winddir_flag = winddir_flag-360.0 + + return + end subroutine wind + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine relative_humidity(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,rh_orig,dn,rh_grid,undef,& + & ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,topo,& + & Tair_orig,Tair_grid,Td_lapse_rate,barnes_lg_domain,& + & n_stns_used,k_stn,snowmodel_line_flag,xg_line,yg_line,& + & seaice_run) + +! This procedure follows: Kunkel, K. E., 1989: Simple procedures for +! extrapolation of humidity variables in the mountainous Western +! United States. J. Climate, 2, 656-669. + +! First convert stn relative humidity to dew-point temperature. Use +! the Td lapse rate to take the stn Td to sea level. Interpolate +! the stn Td to the grid. Use the Td lapse rate to take the sea +! level grid to the actual elevations. Convert each Td to +! relative humidity. + + use snowmodel_inc + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real elev(nstns_max) ! station elevation + real undef ! undefined value + + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! station elevation + + real Tair_orig(nstns_max) ! input values + real rh_orig(nstns_max) ! input values + + real Tair(nstns_max) ! input values + real Td(nstns_max) ! input values + real rh(nstns_max) ! input values + + real dn ! average observation spacing + real topo(nx,ny) ! grid topography + real Tair_grid(nx,ny) ! output values + real Td_grid(nx,ny) ! output values + real rh_grid(nx,ny) ! output values + + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + + real Td_lapse_rate,topo_ref,delta_topo,A,B,C,e,es,Tf,& + & barnes_lg_domain + integer i,j,k,n_stns_used + integer k_stn(nx,ny,9) + real seaice_run + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 + +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + +! Define the freezing temperature to be used to convert from C to K. + Tf = 273.15 + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values2(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,Tair_orig,rh_orig,& + & Tair,rh) + +! Convert the stn relative humidity to Td. + do k=1,nstns + +! Saturation vapor pressure at temperature, T. + es = A * exp((B * (Tair(k) - Tf))/(C + (Tair(k) - Tf))) + +! Dew point temperature for a given temperature and relative humidity. + e = es * max(10.0,rh(k)) / 100.0 + Td(k) = C * log(e/A) / (B - log(e/A)) + Tf + + enddo + +! Define the topographic reference surface. + topo_ref = 0.0 + +! Convert the station data to sea level values. + do k=1,nstns + delta_topo = topo_ref - elev(k) + Td(k) = Td(k) + Td_lapse_rate * delta_topo + enddo + +! Use the barnes oi scheme to interpolate the station data to +! the grid. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,Td,dn,Td_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! Convert these grid values back to the actual gridded elevations. + do j=1,ny + do i=1,nx + delta_topo = topo(i,j) - topo_ref + Td_grid(i,j) = Td_grid(i,j) + Td_lapse_rate * delta_topo + enddo + enddo + +! Convert each Td to a gridded relative humidity. + do j=1,ny + do i=1,nx + e = A * exp((B * (Td_grid(i,j) - Tf)) / & + & (C + (Td_grid(i,j) - Tf))) + es = A * exp((B * (Tair_grid(i,j) - Tf)) /& + & (C + (Tair_grid(i,j) - Tf))) + rh_grid(i,j) = 100.0 * e/es + +! Make sure the interpolation processes has not created any values +! above 100 and below 0. + rh_grid(i,j) = min(100.0,rh_grid(i,j)) + rh_grid(i,j) = max(0.0,rh_grid(i,j)) + enddo + enddo + + return + end subroutine relative_humidity + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine temperature(nx,ny,deltax,deltay,xmn,ymn,& + & nstns_orig,xstn_orig,ystn_orig,Tair_orig,dn,Tair_grid,& + & undef,ifill,iobsint,iyear,imonth,iday,xhour,elev_orig,& + & topo,T_lapse_rate,barnes_lg_domain,n_stns_used,k_stn,& + & snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! The lapse rate used depends on the month of the year, and is +! defined by: Kunkel, K. E., 1989: Simple procedures for +! extrapolation of humidity variables in the mountainous Western +! United States. J. Climate, 2, 656-669. + +! First adjust the stn temperatures to a common level (sea level), +! assuming this lapse rate. Then interpolate the temperatures +! to the model grid. Then use the topography data and lapse +! rate to adjust the gridded temperatures values back to the +! actual elevation. + +! Contact Glen if you are interested in the temperature inversion +! code presented in: Mernild, S. H., and G. E. Liston, 2010: +! The influence of air temperature inversions on snowmelt and +! glacier mass-balance simulations, Ammassalik Island, SE +! Greenland. J. Applied Meteorology and Climatology, 49, 47-67. + + use snowmodel_inc + use LIS_coreMod ! KRA + + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real Tair(nstns_max) ! input values + real elev(nstns_max) ! station elevation + real undef ! undefined value + + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! station elevation + real Tair_orig(nstns_max) ! input values + + real dn ! average observation spacing + real topo(nx,ny) ! grid topography + real Tair_grid(nx,ny) ! output values + + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + + real T_lapse_rate,topo_ref,delta_topo,barnes_lg_domain + integer i,j,k,n_stns_used + integer k_stn(nx,ny,9) + real seaice_run + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,Tair_orig,Tair) + +! Define the topographic reference surface. + topo_ref = 0.0 + +! Convert the station data to sea level values. + do k=1,nstns + delta_topo = topo_ref - elev(k) + Tair(k) = Tair(k) + T_lapse_rate * delta_topo + enddo + +! Use the barnes oi scheme to interpolate the station data to +! the grid. + call interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,Tair,dn,Tair_grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + +! Convert these grid values back to the actual gridded elevations. + do j=1,ny + do i=1,nx + delta_topo = topo(i,j) - topo_ref + Tair_grid(i,j) = Tair_grid(i,j) + T_lapse_rate * delta_topo + enddo + enddo + + return + end subroutine temperature + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine topo_mod_winds(nx,ny,winddir_grid,slopewt,curvewt,& + & windspd_grid,uwind_grid,vwind_grid,curvature,slope_az,& + & terrain_slope,vegtype,forest_LAI,calc_subcanopy_met,& + & vegsnowd_xy,curve_len_scale,deltax,deltay) + + use snowmodel_inc +! KRA + use LIS_coreMod + use LIS_mpiMod + use snowmodel_lsmMod, only : snowmodel_struc +! KRA + implicit none + + integer :: ierr ! KRA + + integer i,j,nx,ny,nveg,k + + real pi,deg2rad,rad2deg,slopewt,curvewt,dirdiff,curve_len_scale,& + & wslope_max,beta,veg_ht,a,canopy_windwt,calc_subcanopy_met,& + & deltax,deltay,xmult + integer, parameter :: nftypes = 5 + integer :: loops_windwt_smoother + + real forest_LAI(nftypes) + + real curvature(nx,ny) + real windspd_grid(nx,ny) + real winddir_grid(nx,ny) + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + real wind_slope(nx,ny) + real slope_az(nx,ny) + real terrain_slope(nx,ny) + real vegtype(nx,ny) + real vegsnowd_xy(nx,ny) + real windwt(nx,ny) + +! Compute the wind modification factor which is a function of +! topography and wind direction following Liston and Sturm (1998). + +! Define the required constants. + pi = 2.0 * acos(0.0) + deg2rad = pi / 180.0 + rad2deg = 180.0 / pi + +! Compute the slope in the direction of the wind. + do i=1,nx + do j=1,ny + wind_slope(i,j) = deg2rad * terrain_slope(i,j) * & + & cos(deg2rad * (winddir_grid(i,j) - slope_az(i,j))) + enddo + enddo + +! Scale the wind slope such that the max abs(wind slope) has a value +! of abs(0.5). Include a 1 mm slope in slope_max to prevent +! divisions by zero in flat terrain where the slope is zero. + wslope_max = 0.0 + 0.001 + do j=1,ny + do i=1,nx + wslope_max = max(wslope_max,abs(wind_slope(i,j))) + enddo + enddo + +! KRA +#if (defined SPMD) +! call co_max(wslope_max) +! print *, "wslope_max: ",LIS_localPet+1, wslope_max + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(wslope_max, snowmodel_struc(1)%wslopemax_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + wslope_max = snowmodel_struc(1)%wslopemax_glb +! print *, "final wslope_max: ",wslope_max +#endif +! KRA + + do j=1,ny + do i=1,nx + wind_slope(i,j) = wind_slope(i,j) / (2.0 * wslope_max) + enddo + enddo + +! Calculate the wind speed and direction adjustments. The +! curvature and wind_slope values range between -0.5 and +0.5. +! Valid slopewt and curvewt values are between 0 and 1, with +! values of 0.5 giving approximately equal weight to slope and +! curvature. I suggest that slopewt and curvewt be set such +! that slopewt + curvewt = 1.0. This will limit the total +! wind weight to between 0.5 and 1.5 (but this is not required). + +! Compute the wind weighting factor. + do i=1,nx + do j=1,ny + windwt(i,j) = 1.0 + slopewt * wind_slope(i,j) + & + & curvewt * curvature(i,j) + enddo + enddo + +! Smooth the wind weighting factor to eliminate any sharp speed +! increases resulting from the merging of the curve wt and the +! slope wt. Define the number of times this is done to be a +! function of the curvature length scale and the grid increment. +! The first 0.5 here just means that half of the caclulated +! number appears to be about right (additional loops with this +! smoother does not change the results much). If there are +! unwanted wave features in the snow distribution, this 0.5 +! factor can be increased to 1.0 or more, to get rid of these +! waves. Also see "loops_snowd_smoother" in snowtran_code.f. +! xmult = 0.5 + xmult = 1.0 +! xmult = 1.5 + loops_windwt_smoother = nint(xmult * curve_len_scale / & + & (0.5 * (deltax + deltay))) + +! print * +! print *, 'loops_windwt_smoother ',loops_windwt_smoother +! print * + +! Don't do this smoothing if the domain is arbitrarily small. + if (nx.gt.100 .and. ny.gt.100) then + do k=1,loops_windwt_smoother + call smoother9(nx,ny,windwt) + enddo + endif + +! Continue with the wind calculations. + do i=1,nx + do j=1,ny + +! Generate the terrain-modified wind speed. + windspd_grid(i,j) = windwt(i,j) * windspd_grid(i,j) + +! Further modify the wind speed to account for forest canopies. + if (vegtype(i,j).le.5.0) then + if (calc_subcanopy_met.eq.1.0) then + nveg = nint(vegtype(i,j)) + +! Define the canopy wind-weighting factor. Assume z=0.6*canopy_ht, +! and the canopy_ht equals the vegetation snow-holding depth. + beta = 0.9 + veg_ht = vegsnowd_xy(i,j) + a = beta * forest_LAI(nveg) + canopy_windwt = exp((- a)*(1.0 - (0.6*veg_ht)/veg_ht)) + windspd_grid(i,j) = canopy_windwt * windspd_grid(i,j) + + endif + endif + +! Modify the wind direction according to Ryan (1977). Note that it +! is critical that "dirdiff" handles the cases where the slope +! azimuth and the wind direction are on different sides of the +! 360-0 line. + if (slope_az(i,j).gt.270.0.and. & + & winddir_grid(i,j).lt.90.0) then + dirdiff = slope_az(i,j) - winddir_grid(i,j) - 360.0 + elseif (slope_az(i,j).lt.90.0.and. & + & winddir_grid(i,j).gt.270.0) then + dirdiff = slope_az(i,j) - winddir_grid(i,j) + 360.0 + else + dirdiff = slope_az(i,j) - winddir_grid(i,j) + endif + if (abs(dirdiff).le.90.0) then + winddir_grid(i,j) = winddir_grid(i,j) - 0.5 * & + & min(wind_slope(i,j)*rad2deg,45.0) * & + & sin(deg2rad * (2.0 * dirdiff)) + if (winddir_grid(i,j).gt.360.0) then + winddir_grid(i,j) = winddir_grid(i,j) - 360.0 + elseif (winddir_grid(i,j).lt.0.0) then + winddir_grid(i,j) = winddir_grid(i,j) + 360.0 + endif + endif + +! Extract the u and v wind components. + uwind_grid(i,j) = (- windspd_grid(i,j)) * & + & sin(deg2rad*winddir_grid(i,j)) + vwind_grid(i,j) = (- windspd_grid(i,j)) * & + & cos(deg2rad*winddir_grid(i,j)) + enddo + enddo + + return + end subroutine topo_mod_winds + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine topo_data(nx,ny,deltax,deltay,topo,& + & curvature,terrain_slope,slope_az,curve_len_scale) + + use snowmodel_inc +! KRA + use LIS_coreMod + use LIS_mpiMod + use snowmodel_lsmMod, only : snowmodel_struc +! KRA + implicit none + + integer :: ierr ! KRA + + integer i,j,nx,ny,inc + + real pi,rad2deg,deltax,deltay,deltaxy,curve_len_scale,curve_max + + real topo(nx,ny) + real dzdx(nx,ny) + real dzdy(nx,ny) + real curvature(nx,ny) + real slope_az(nx,ny) + real terrain_slope(nx,ny) + +! Compute the topographic information required to run the wind +! model. + +! Deal with the model running at a point, or along single or double +! lines. + if (nx.le.2 .or. ny.le.2) then + do i=1,nx + do j=1,ny + curvature(i,j) = 0.0 + terrain_slope(i,j) = 0.0 + slope_az(i,j) = 0.0 + enddo + enddo + else + +! Define the required constants. + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + +! CURVATURE CALCULATIONS. + +! Compute the average grid increment. + deltaxy = 0.5 * (deltax + deltay) + +! Convert the length scale to an appropriate grid increment. + inc = max(1,nint(curve_len_scale/deltaxy)) + +! Compute the curvature. + do i=1,nx + do j=1,ny + curvature(i,j) = (4.0 * topo(i,j) - & + & topo(max(1,i-inc),max(1,j-inc)) - & + & topo(min(nx,i+inc),min(ny,j+inc)) - & + & topo(min(nx,i+inc),max(1,j-inc)) - & + & topo(max(1,i-inc),min(ny,j+inc))) / & + & (sqrt(2.0) * 16.0 * real(inc) * deltaxy) + & + & (4.0 * topo(i,j) - & + & topo(min(nx,i+inc),j) - topo(max(1,i-inc),j) - & + & topo(i,min(ny,j+inc)) - topo(i,max(1,j-inc))) / & + & (16.0 * real(inc) * deltaxy) + enddo + enddo + +! Scale the curvature such that the max abs(curvature) has a value +! of abs(0.5). Include a 1 mm curvature in curve_max to prevent +! divisions by zero in flat terrain where the curvature is zero. + curve_max = 0.0 + 0.001 + do j=1,ny + do i=1,nx + curve_max = max(curve_max,abs(curvature(i,j))) + enddo + enddo +! KRA +#if (defined SPMD) +! call co_max(curve_max) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(curve_max, snowmodel_struc(1)%curvemax_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + curve_max = snowmodel_struc(1)%curvemax_glb +#endif +! KRA + do j=1,ny + do i=1,nx + curvature(i,j) = curvature(i,j) / (2.0 * curve_max) + enddo + enddo + +! SLOPE CALCULATIONS. + +! Find dzdx. + do j=1,ny + dzdx(1,j) = (topo(2,j) - topo(1,j)) / deltax + do i=2,nx-1 + dzdx(i,j) = (topo(i+1,j) - topo(i-1,j)) / (2.0 * deltax) + enddo + dzdx(nx,j) = (topo(nx,j) - topo(nx-1,j)) / deltax + enddo + +! Find dzdy. + do i=1,nx + dzdy(i,1) = (topo(i,2) - topo(i,1)) / deltay + do j=2,ny-1 + dzdy(i,j) = (topo(i,j+1) - topo(i,j-1)) / (2.0 * deltay) + enddo + dzdy(i,ny) = (topo(i,ny) - topo(i,ny-1)) / deltay + enddo + +! Calculate the terrain slope and azimuth. + do i=1,nx + do j=1,ny + +! Some compilers will not allow dzdx and dzdy to both be 0.0 in +! the atan2 computation. +! if (abs(dzdx(i,j)).lt.1e-10) dzdx(i,j) = 1e-10 + if (abs(dzdy(i,j)).lt.1e-10) dzdy(i,j) = 1e-10 + +! Compute the slope azimuth, making sure that north has zero +! azimuth. Also note that for the Ryan wind rotation, the +! azimuth values must range from 0 to 360. + slope_az(i,j) = rad2deg * & + & (3.0 / 2.0 * pi - atan2(dzdy(i,j),dzdx(i,j))) + if (slope_az(i,j).ge.360.0) slope_az(i,j) = & + & slope_az(i,j) - 360.0 + +! Compute the slope of the terrain. + terrain_slope(i,j) = rad2deg * & + & atan(sqrt(dzdx(i,j)*dzdx(i,j) + dzdy(i,j)*dzdy(i,j))) + + enddo + enddo + + endif + + return + end subroutine topo_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine interpolate(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,var,dn,grid,undef,ifill,iobsint,& + & iyear,imonth,iday,xhour,barnes_lg_domain,n_stns_used,& + & k_stn,snowmodel_line_flag,xg_line,yg_line,seaice_run) + + use snowmodel_inc + use LIS_coreMod ! KRA + + implicit none + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real var(nstns_max) ! input values + + double precision xstn_tmp(nstns_max) ! input stn x coords + double precision ystn_tmp(nstns_max) ! input stn y coords + real var_tmp(nstns_max) ! input values + + integer nstns ! number of input values, all good + real undef ! undefined value + real dn ! average observation spacing + real grid(nx,ny) ! output values + + integer i,j ! col, row counters + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + + integer k_stn(nx,ny,9) + integer k,n_stns_used + real barnes_lg_domain,seaice_run + +! Use the barnes oi scheme to grid the station data. If there is +! only a single station, distribute those data uniformly over +! the grid. In the event that there are no valid observations, +! send an error message and stop (although this should have been +! caught as part of a preprocessor step). + +! The interpolation can be done two different ways: +! First, barnes_oi does the interpolation by processing all of +! the available station data for each model grid cell. +! Second, barnes_oi_ij does the interpolation by processing only +! the "n_stns_used" number of stations for each model grid cell. +! For small domains, with relatively few met stations (100's), +! the first way is best. For large domains (like the +! United States, Globe, Pan-Arctic, North America, Greenland) +! and many met stations (like 1000's), the second approach is the +! most efficient. But, the second approach carries the following +! restrictions: 1) there can be no missing data for the fields of +! interest; 2) there can be no missing stations (all stations +! must exist throughout the simulation period); and 3) the +! station met file must list the stations in the same order for +! all time steps. In addition, the code limits the number of +! nearest stations used to be 5 or less. + +! In this first case you are doing a Lagrangian sea ice parcel +! simulation. + if (seaice_run.eq.4.0) then + do j=1,ny + do i=1,nx + grid(i,j) = var(i) + enddo + enddo + else + if (nstns.ge.2) then + +! call get_dn(nx,ny,deltax,deltay,nstns,dn,iobsint) !KRA + call get_dn(LIS_rc%gnc(1),LIS_rc%gnr(1),& + deltax,deltay,nstns,dn,iobsint) !KRA + + if (barnes_lg_domain.eq.1.0 .or. barnes_lg_domain.eq.2.0) then + + if (barnes_lg_domain.eq.2.0) then + call get_nearest_stns_2(nx,ny,xmn,ymn,deltax,deltay,& + & n_stns_used,k_stn,nstns,xstn,ystn,xg_line,yg_line,& + & snowmodel_line_flag) + endif + + do j=1,ny + do i=1,nx + +! Use that nearest station list to extract the station information +! to be used in the interpolation. + do k=1,n_stns_used + xstn_tmp(k) = xstn(k_stn(i,j,k)) + ystn_tmp(k) = ystn(k_stn(i,j,k)) + var_tmp(k) = var(k_stn(i,j,k)) + enddo + +! Do the interpolation for this model grid cell. + call barnes_oi_ij(nx,ny,deltax,deltay,xmn,ymn,& + & n_stns_used,xstn_tmp,ystn_tmp,var_tmp,dn,grid,& + & undef,ifill,i,j,snowmodel_line_flag,xg_line,yg_line) + + enddo + enddo + + else + + call barnes_oi(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,var,dn,grid,undef,ifill) + + endif + + elseif (nstns.eq.1) then + + call single_stn(nx,ny,nstns,var,grid) + + else + + print *,'found no valid obs data at this time step' + print *,' model time =', iyear,imonth,iday,xhour + stop + + endif + + endif + + return + end subroutine interpolate + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_nearest_stns_2(nx,ny,xmn,ymn,deltax,deltay,& + & n_stns_used,k_stn,nstns,xstn,ystn,xg_line,yg_line,& + & snowmodel_line_flag) + + use snowmodel_inc + implicit none + + double precision xstn(nstns_max) + double precision ystn(nstns_max) + double precision dsq(nstns_max) + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + double precision xg,yg,xmn,ymn,dist_min + real deltax,deltay + + integer i,j,k,kk,nstns,n_stns_used,nx,ny + integer k_stn(nx,ny,9) + + do j=1,ny + do i=1,nx + +! xcoords of grid nodes at index i,j +! ycoords of grid nodes at index i,j + if (snowmodel_line_flag.eq.1.0) then + xg = xg_line(i,j) + yg = yg_line(i,j) + elseif (snowmodel_line_flag.eq.0.0) then + print *, 'This can be very slow. I suggest you study' + print *, 'and implement some version of the code below' + print *, 'this subroutine before continuing along this' + print *, 'simulation approach.' + stop + xg = xmn + deltax * (real(i) - 1.0) + yg = ymn + deltay * (real(j) - 1.0) + endif + +! Loop through all of the stations, calculating the distance +! between the current grid point and each of the stations. + do k=1,nstns + dsq(k) = (xg - xstn(k))**2 + (yg - ystn(k))**2 + enddo + +! Loop through each of the station distances and find the +! stations closest to the grid point in question. + do kk=1,n_stns_used + dist_min = 1.0e30 + do k=1,nstns + if (dsq(k).le.dist_min) then + k_stn(i,j,kk) = k + dist_min = dsq(k) + endif + enddo + +! Eliminate the last found minimum from the next search by making +! its distance a big number. + dsq(k_stn(i,j,kk)) = 1.0e30 + enddo + + enddo + enddo + + return + end subroutine get_nearest_stns_2 + +! get_nearest.f + +! Find the ii,jj locations of the nearest observation grid +! point (veg grid) closest to each of the output grid cells +! (the topo grid). + +! I'm starting out with original veg data on a UTM grid, and +! interpolating to the UTM coords of the topo data grid. + +! nnx, nny is the original veg data grid. +! nx, ny is the topo data grid. + +!! implicit none + +!! integer nx,ny,nstns,nnx,nny,n,icount + +!! parameter (nx=23401,ny=27502,nnx=14288,nny=16176) +!! parameter (nstns=1) + +!! real dsq(nnx,nny) +!! real xk_min(nx,ny,nstns) + +!! real del_x,del_y,gx_ll,gy_ll +!! real xmn,ymn,deltax,deltay,xg,yg,xs,ys,dist_min +!! integer i,j,k,kk,ii,jj,iii,iiii,jjj,jjjj,inc + +!! real gx_stn(nnx,nny) +!! real gy_stn(nnx,nny) + +!! print *,'preforming the station indexing calculations' + +! Grid increment for the veg grid, in m. +!! del_x = 30.0 +!! del_y = 30.0 + +! Coordinates of center of lower left grid cell of veg (input) grid, +! and grid increments. +!! gx_ll = 398580.0 + del_x/2.0 +!! gy_ll = 8495405.0 + del_y/2.0 + +! UTM coordinates of the 'stations' or input grid-cell centers. +!! do j=1,nny +!! do i=1,nnx +!! gx_stn(i,j) = gx_ll + del_x * (real(i) - 1.0) +!! gy_stn(i,j) = gy_ll + del_y * (real(j) - 1.0) +!! enddo +!! enddo + +! Grid increment for the topo grid, in m. +!! deltax = 20.0 +!! deltay = 20.0 + +! Coordinates of center of lower left grid cell of topo (output) grid, +! and grid increments. +!! xmn = 381990.0 + deltax/2.0 +!! ymn = 8449790.0 + deltay/2.0 + +! Search for the stations nearest to the grid point of interest. +!! icount = 0 +!! do j=1,ny +!! if (mod(j,100).eq.0.0) print *, 'j = ',j +!! do i=1,nx + +! xcoords of topo grid nodes at index i,j +! ycoords of topo grid nodes at index i,j +!! xg = xmn + deltax * (real(i) - 1.0) +!! yg = ymn + deltay * (real(j) - 1.0) + +! Find the corresponding veg grid cell coordinate to this grid cell. +!! iii = nint((xg - gx_ll)/del_x + 1.0) +!! jjj = nint((yg - gy_ll)/del_y + 1.0) + +! Don't let things go outside the array bounds. +!! inc = 5 +!! if (iii.le.inc) iii = 1 + inc +!! if (iii.ge.nnx-inc+1) iii = nnx - inc +!! if (jjj.le.inc) jjj = 1 + inc +!! if (jjj.ge.nny-inc+1) jjj = nny - inc + +! Loop through all of the stations, calculating the distance +! between the current grid point and each of the stations. +!! do jj=jjj-inc,jjj+inc +!! do ii=iii-inc,iii+inc +!! xs = gx_stn(ii,jj) +!! ys = gy_stn(ii,jj) +!! dsq(ii,jj) = (xg - xs)**2 + (yg - ys)**2 +!! enddo +!! enddo + +! Loop through each of the station distances and find the +! stations closest to the grid point in question. +!! do kk=1,nstns +!! dist_min = 1.0e30 +!! do jj=jjj-inc,jjj+inc +!! do ii=iii-inc,iii+inc +!! if (dsq(ii,jj).le.dist_min) then +!! k = ii + (jj - 1) * nnx +!! xk_min(i,j,kk) = real(k) +!! dist_min = dsq(ii,jj) +!! iiii = ii +!! jjjj = jj +!! endif +!! enddo +!! enddo + +! Eliminate the last found minimum from the next search by making +! its distance a big number. +!! dsq(iiii,jjjj) = 1.0e30 +!! enddo + +!! enddo +!! enddo + +! Save xk_min. +!! print *,'--------------------------------------' +!! print *,'--------------------------------------' +!! print *, 'saving data' + +!! open (unit=41,file='nearest_stns_1.gdat', +!! & form='unformatted',access='direct',recl=4*nx) + +!! print *, '1' +!! do j=1,ny +!! write(41,rec=j) (xk_min(i,j,1),i=1,nx) +!! enddo + +!! end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,var_orig,var) + + use snowmodel_inc + implicit none + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real elev(nstns_max) ! input stn elevation + real var(nstns_max) ! input values + real undef ! undefined value + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! input stn elevation + real var_orig(nstns_max) ! input values + + integer k + +! Before performing the interpolation, sort through the data and +! toss out any undefined values. + nstns = 0 + do k=1,nstns_orig + if (var_orig(k).ne.undef) then + nstns = nstns + 1 + xstn(nstns) = xstn_orig(k) + ystn(nstns) = ystn_orig(k) + var(nstns) = var_orig(k) + elev(nstns) = elev_orig(k) + endif + enddo + + return + end subroutine get_good_values1 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_good_values2(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,var1_orig,var2_orig,& + & var1,var2) + +! Account for the special case where you must have two coincident +! values to do the interpolation, like Tair and rh to interpolate +! rh, and wind speed and dir to interpolate the winds. + + use snowmodel_inc + implicit none + + integer nstns ! number of input values, all good + integer nstns_orig ! number of input values + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real elev(nstns_max) ! input stn elevation + real undef ! undefined value + double precision xstn_orig(nstns_max) ! input stn x coords + double precision ystn_orig(nstns_max) ! input stn y coords + real elev_orig(nstns_max) ! input stn elevation + + real var1_orig(nstns_max) ! input values + real var2_orig(nstns_max) ! input values + real var1(nstns_max) ! input values + real var2(nstns_max) ! input values + + integer k + +! Before performing the interpolation, sort through the data and +! toss out any undefined values. + nstns = 0 + do k=1,nstns_orig + if (var1_orig(k).ne.undef .and. var2_orig(k).ne.undef) then + nstns = nstns + 1 + xstn(nstns) = xstn_orig(k) + ystn(nstns) = ystn_orig(k) + var1(nstns) = var1_orig(k) + var2(nstns) = var2_orig(k) + elev(nstns) = elev_orig(k) + endif + enddo + + return + end subroutine get_good_values2 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_obs_data(nstns_orig,Tair_orig,rh_orig,xstn_orig,& + & ystn_orig,elev_orig,iyear,imonth,iday,xhour,undef,& + & windspd_orig,winddir_orig,prec_orig,isingle_stn_flag,& + & igrads_metfile,iter) + + use snowmodel_inc + implicit none + + integer iyr,imo,idy ! year, month, and day of data + real xhr ! decimal hour + integer idstn ! station id number + + integer k,nstns_orig,isingle_stn_flag,igrads_metfile,iter + integer iyear,imonth,iday + + real Tair_orig(nstns_max),rh_orig(nstns_max) + real winddir_orig(nstns_max),windspd_orig(nstns_max) + double precision xstn_orig(nstns_max),ystn_orig(nstns_max) + real elev_orig(nstns_max),xhour,prec_orig(nstns_max) + real undef ! undefined value + + if (isingle_stn_flag.eq.1) then + nstns_orig = 1 + else + read(20,*) nstns_orig + endif + + if (nstns_orig.gt.nstns_max) then + print * + print *, 'You must increase the value of nstns_max in' + print *, ' snowmodel.inc to be greater than nstns_orig.' + print *, 'nstns_max = ',nstns_max + print *, 'nstns_orig = ',nstns_orig + print * + stop + endif + + do k=1,nstns_orig + if (igrads_metfile.eq.1) then + read(20,rec=iter) iyr,imo,idy,xhr,idstn,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),Tair_orig(k),rh_orig(k),& + & windspd_orig(k),winddir_orig(k),prec_orig(k) + else + read(20,*) iyr,imo,idy,xhr,idstn,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),Tair_orig(k),rh_orig(k),& + & windspd_orig(k),winddir_orig(k),prec_orig(k) + endif + +! MicroMet assumes that the air temperature comes in as deg C, but +! all computations must be done in K. Check for this and make +! an appropriate adjustment. + if (Tair_orig(k).lt.150.0 .and. Tair_orig(k).ne.undef) & + & Tair_orig(k) = Tair_orig(k) + 273.15 + +! Do some error checking. Check for the presence of data from +! the same date. + if (iyr.ne.iyear .or. imo.ne.imonth .or. idy.ne.iday & + & .or. xhr.ne.xhour) then + print *,'model time does not match data input time' + print *,' model =', iyear,imonth,iday,xhour + print *,' obs =', iyr,imo,idy,xhr + stop + endif + + enddo + + return + end subroutine get_obs_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_model_time(iyear_init,imonth_init,iday_init,& + & xhour_init,iter,dt,iyear,imonth,iday,xhour,J_day) + + implicit none + + integer iyear,imonth,iday ! model year, month, and day + real xhour ! model decimal hour + real dt ! model time step, in seconds + integer iter ! model iteration + integer iyear_init ! model start year + integer imonth_init ! model start month + integer iday_init ! model start day + real xhour_init ! model decimal start hour + integer J_day ! model day of year + +! Misc. variables. + real xmin,xhour_frac,xhour_tmp,xday + integer ihour,last + + integer lastday(12) + data lastday/31,28,31,30,31,30,31,31,30,31,30,31/ + +! Convert the simulation time to the exact year, month, day, and +! decimal hour. + +! Number of minutes into the simulation. Here I have assumed that +! dt will never be in fractions of minutes. +! xmin = ((real(iter) - 1.0) * dt) / 60.0 + xmin = (real(iter) - 1.0) * (dt / 60.0) + +! Model integration time in decimal hours. The xhour_frac variable +! needs to be fixed for dt < 3600 sec. + xhour_tmp = xhour_init + xmin / 60.0 + ihour = mod(int(xhour_tmp),24) + xhour_frac = 0.0 + xhour = real(ihour) + xhour_frac + +! Number of days. + xday = xhour_tmp / 24.0 + iday = iday_init + int(xday) + +! Month and year, while accounting for leap-years. + imonth = imonth_init + iyear = iyear_init + 20 continue + last = lastday(imonth) + if (imonth.eq.2 .and. mod(iyear,4).eq.0 & + & .and. (mod(iyear,100).ne.0 .or. mod(iyear,1000).eq.0)) then + last = last + 1 + endif + if (iday.gt.last) then + iday = iday - last + imonth = imonth + 1 + if (imonth.gt.12) then + imonth = 1 + iyear = iyear + 1 + endif + go to 20 + endif + +! Calculate the day of year (1...365,366) corresponding to the date +! iyear-imonth-iday. + J_day = iday & + & + min(1,max(0,imonth-1))*31 & + & + min(1,max(0,imonth-2))*(28+(1-min(1,mod(iyear,4)))) & + & + min(1,max(0,imonth-3))*31 & + & + min(1,max(0,imonth-4))*30 & + & + min(1,max(0,imonth-5))*31 & + & + min(1,max(0,imonth-6))*30 & + & + min(1,max(0,imonth-7))*31 & + & + min(1,max(0,imonth-8))*31 & + & + min(1,max(0,imonth-9))*30 & + & + min(1,max(0,imonth-10))*31 & + & + min(1,max(0,imonth-11))*30 & + & + min(1,max(0,imonth-12))*31 + +! print *, iyear,imonth,iday,xhour,J_day + + return + end subroutine get_model_time + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_lapse_rates(imonth,iday,T_lapse_rate,& + & Td_lapse_rate,xlat,lapse_rate_user_flag,& + & precip_lapse_rate,iprecip_lapse_rate_user_flag) + + implicit none + + integer imonth,iday,mbefore,mafter,k,& + & lapse_rate_user_flag,iprecip_lapse_rate_user_flag + real weight,T_lapse_rate,Td_lapse_rate,A,B,C,xlat,& + & precip_lapse_rate + integer, parameter :: months = 12 + integer lastday(months) + data lastday/31,28,31,30,31,30,31,31,30,31,30,31/ + +! The lapse rate units are in deg_C km-1. They are converted to +! negative_deg_C m-1 below. + real lapse_rate(months) + real lapse_rate_nohem(months) + real lapse_rate_sohem(months) + real lapse_rate_user(months) + data lapse_rate_nohem /4.4,5.9,7.1,7.8,8.1,8.2,& + & 8.1,8.1,7.7,6.8,5.5,4.7/ + data lapse_rate_sohem /8.1,8.1,7.7,6.8,5.5,4.7,& + & 4.4,5.9,7.1,7.8,8.1,8.2/ + +! If you want to use the 'user' array, put your monthly values in +! here and set lapse_rate_user_flag = 1 in the .par file. + data lapse_rate_user /4.4,5.9,7.1,7.8,8.1,8.2, & + & 8.1,8.1,7.7,6.8,5.5,4.7/ + +! The initial vapor pressure coeffs are in units of km-1. + real am(months) + real am_nohem(months) + real am_sohem(months) + real am_user(months) + data am_nohem /0.41,0.42,0.40,0.39,0.38,0.36, & + & 0.33,0.33,0.36,0.37,0.40,0.40/ + data am_sohem /0.33,0.33,0.36,0.37,0.40,0.40, & + & 0.41,0.42,0.40,0.39,0.38,0.36/ + +! If you want to use the 'user' array, put your monthly values in +! here and set lapse_rate_user_flag = 1 in the .par file. + data am_user /0.41,0.42,0.40,0.39,0.38,0.36, & + & 0.33,0.33,0.36,0.37,0.40,0.40/ + +! The precipitation lapse rate units are in km-1. + real prec_lapse_rate(months) + real precip_lapse_rate_nohem(months) + real precip_lapse_rate_sohem(months) + real precip_lapse_rate_user(months) + data precip_lapse_rate_nohem /0.35,0.35,0.35,0.30,0.25,0.20,& + & 0.20,0.20,0.20,0.25,0.30,0.35/ + data precip_lapse_rate_sohem /0.20,0.20,0.20,0.25,0.30,0.35,& + & 0.35,0.35,0.35,0.30,0.25,0.20/ + +! If you want to use the 'user' array, put your monthly values in +! here and set iprecip_lapse_rate_user_flag = 1 in the .par file. + data precip_lapse_rate_user /0.35,0.35,0.35,0.30,0.25,0.20,& + & 0.20,0.20,0.20,0.25,0.30,0.35/ + +! Air and dewpoint temperature. + do k=1,months + if (lapse_rate_user_flag.eq.0) then + if (xlat.lt.0.0) then + lapse_rate(k) = lapse_rate_sohem(k) + am(k) = am_sohem(k) + else + lapse_rate(k) = lapse_rate_nohem(k) + am(k) = am_nohem(k) + endif + elseif (lapse_rate_user_flag.eq.1) then + lapse_rate(k) = lapse_rate_user(k) + am(k) = am_user(k) + endif + enddo + +! Precipitation. + do k=1,months + if (iprecip_lapse_rate_user_flag.eq.0) then + if (xlat.lt.0.0) then + prec_lapse_rate(k) = precip_lapse_rate_sohem(k) + else + prec_lapse_rate(k) = precip_lapse_rate_nohem(k) + endif + elseif (iprecip_lapse_rate_user_flag.eq.1) then + prec_lapse_rate(k) = precip_lapse_rate_user(k) + endif + enddo + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 + +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + +! Find the month before and after the day in question. + if (iday.le.15) then + mbefore = imonth - 1 + if (mbefore.eq.0) mbefore = 12 + mafter = imonth + weight = (real(lastday(mbefore)) - 15. + real(iday)) / & + & real(lastday(mbefore)) + else + mbefore = imonth + mafter = imonth + 1 + if (mafter.eq.13) mafter = 1 + weight = (real(iday) - 15.) / real(lastday(mbefore)) + endif + +! Define the temperature lapse rate (deg C/m). + T_lapse_rate = (- (weight * lapse_rate(mafter) + & + & (1. - weight) * lapse_rate(mbefore))) / 1000.0 + +! Define the dew-point temperature lapse rate (deg C/m). + Td_lapse_rate = (- ((weight * am(mafter) + & + & (1. - weight) * am(mbefore)) * C)) / (B * 1000.0) + +! Define the precipitation lapse rate (km-1). + precip_lapse_rate = weight * prec_lapse_rate(mafter) + & + & (1. - weight) * prec_lapse_rate(mbefore) + + return + end subroutine get_lapse_rates + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_dn(nx,ny,deltax,deltay,nstns,dn,iobsint) + + implicit none + + integer nx,ny,nstns + real deltax,deltay,dn + real dn_max ! the max obs spacing, dn_r + real dn_min ! dn_r, for large n + integer iobsint ! flag (=1) use dn value from .par file + +! Calculate an appropriate filtered wavelength value. First +! calculate dn for the case of severely nonuniform data, and +! then for the case where there is just about a station for +! every grid cell. Then assume that the average of these two +! is a reasonable value to use in the interpolation. + dn_max = sqrt(deltax*real(nx) * deltay*real(ny)) * & + & ((1.0 + sqrt(real(nstns))) / (real(nstns) - 1.0)) + dn_min = sqrt((deltax*real(nx) * deltay*real(ny)) / & + & real(nstns)) + + if (iobsint.eq.1) then +! dn = dn + else + dn = 0.5 * (dn_min + dn_max) + endif + +! print *,'You are using an average obs spacing of',dn +! print *,' the program indicates a min, max range of', +! & dn_min,dn_max + + return + end subroutine get_dn + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine barnes_oi(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,var,dn,grid,undef,ifill) + +! This is an implementation of the Barnes objective analysis scheme +! as described in: +! +! Koch, S. E., M. DesJardins, and P. J. Kocin, 1983: An +! interactive Barnes objective map analysis scheme for use with +! satellite and conventional data. J. Climate and Applied +! Meteorology, 22(9), 1487-1503. + + use snowmodel_inc + implicit none + + real, parameter :: gamma = 0.2 + + real pi + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn !center x coords of lower left grid cell + double precision ymn !center y coords of lower left grid cell + + integer nstns ! number of input values, all good + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real var(nstns_max) ! input values + integer nflag ! determines if output will be undef value + real undef ! undefined value + + real dn ! average observation spacing + real grid(nx,ny) ! output values + + integer i,j ! col, row counters + integer mm,nn ! station counters + integer ifill ! flag (=1) forces a value in every cell + + double precision xg,yg !temporary x and y coords of current cell + real w1,w2 ! weights for Gauss-weighted average + real wtot1,wtot2 ! sum of weights + real ftot1,ftot2 ! accumulators for values, corrections + real dsq ! delx**2 + dely**2 + double precision xa,ya ! x, y coords of current station + double precision xb,yb ! x, y coords of current station + real dvar(nstns_max) ! estimated error + + real xkappa_1 ! Gauss constant for first pass + real xkappa_2 ! Gauss constant for second pass + real rmax_1 ! maximum scanning radii, for first + real rmax_2 ! and second passes + real anum_1 ! numerator, beyond scanning radius, + real anum_2 ! for first and second passes + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Compute the first and second pass values of the scaling parameter +! and the maximum scanning radius used by the Barnes scheme. +! Values above this maximum will use a 1/r**2 weighting. Here I +! have assumed a gamma value of 0.2. + +! First-round values, Eqn (13). + pi = 2.0 * acos(0.0) + xkappa_1 = 5.052 * (2.0*dn/pi)**2 + +! Define the maximum scanning radius to have weight defined by +! wt = 1.0 x 10**(-30) = exp(-rmax_1/xkappa_1) +! Also scale the 1/r**2 wts so that when dsq = rmax, the wts match. + rmax_1 = xkappa_1 * 30.0 * log(10.0) + anum_1 = 1.0e-30 * rmax_1 + +! Second-round values, Eqn (4). + xkappa_2 = gamma * xkappa_1 + rmax_2 = rmax_1 * gamma + anum_2 = 1.0e-30 * rmax_2 + +! Scan each input data point and construct estimated error, dvar, at +! that point. + do nn=1,nstns + + xa = xstn(nn) + ya = ystn(nn) + wtot1 = 0.0 + ftot1 = 0.0 + + do mm=1,nstns + + xb = xstn(mm) + yb = ystn(mm) + dsq = (xb - xa)**2 + (yb - ya)**2 + + if (dsq.le.rmax_1) then + + w1 = exp((- dsq)/xkappa_1) + + else + +! Assume a 1/r**2 weight. + w1 = anum_1/dsq + + endif + + wtot1 = wtot1 + w1 + ftot1 = ftot1 + w1 * var(mm) + + end do ! end loop on sites m + + if (wtot1.eq.0.0) print *,'stn wt totals zero' + + dvar(nn) = var(nn) - ftot1/wtot1 + + end do ! end prediction loop on sites nn + +! Grid-prediction loop. Generate the estimate using first set of +! weights, and correct using error estimates, dvar, and second +! set of weights. + + do j=1,ny + do i=1,nx + +! xcoords of grid nodes at index i,j +! ycoords of grid nodes at index i,j + xg = xmn + deltax * (real(i) - 1.0) + yg = ymn + deltay * (real(j) - 1.0) + +! Scan each input data point. + ftot1 = 0.0 + wtot1 = 0.0 + ftot2 = 0.0 + wtot2 = 0.0 + nflag = 0 + + do nn=1,nstns + + xa = xstn(nn) + ya = ystn(nn) + dsq = (xg - xa)**2 + (yg - ya)**2 + + if (dsq.le.rmax_2) then + + w1 = exp((- dsq)/xkappa_1) + w2 = exp((- dsq)/xkappa_2) + + elseif (dsq.le.rmax_1) then + + w1 = exp((- dsq)/xkappa_1) + w2 = anum_2/dsq + + else + +! Assume a 1/r**2 weight. + w1 = anum_1/dsq + nflag = nflag + 1 +! With anum_2/dsq. + w2 = gamma * w1 + + endif + + wtot1 = wtot1 + w1 + wtot2 = wtot2 + w2 + ftot1 = ftot1 + w1 * var(nn) + ftot2 = ftot2 + w2 * dvar(nn) + + end do ! end loop on data sites nn + + if (wtot1.eq.0.0 .or. wtot2.eq.0.0) print *,'wts total zero' + + if (ifill.eq.1) then + grid(i,j) = ftot1/wtot1 + ftot2/wtot2 + else + if (nflag.lt.nstns) then + grid(i,j) = ftot1/wtot1 + ftot2/wtot2 + else + grid(i,j) = undef + endif + endif + + end do ! end loop on cols i + end do ! end loop on rows j + + return + end subroutine barnes_oi + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine barnes_oi_ij(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,var,dn,grid,& + & undef,ifill,i,j,snowmodel_line_flag,xg_line,yg_line) + +! This is an implementation of the Barnes objective analysis scheme +! as described in: +! +! Koch, S. E., M. DesJardins, and P. J. Kocin, 1983: An +! interactive Barnes objective map analysis scheme for use with +! satellite and conventional data. J. Climate and Applied +! Meteorology, 22(9), 1487-1503. + + use snowmodel_inc + implicit none + + real, parameter :: gamma = 0.2 + + real pi + + integer nx ! number of x output values + integer ny ! number of y output values + real deltax ! grid increment in x + real deltay ! grid increment in y + double precision xmn !center x coords of lower left grid cell + double precision ymn !center y coords of lower left grid cell + + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + integer nstns ! number of input values, all good + double precision xstn(nstns_max) ! input stn x coords + double precision ystn(nstns_max) ! input stn y coords + real var(nstns_max) ! input values + integer nflag ! determines if output will be undef value + real undef ! undefined value + + real dn ! average observation spacing + real grid(nx,ny) ! output values + + integer i,j ! col, row counters + integer mm,nn ! station counters + integer ifill ! flag (=1) forces a value in every cell + + double precision xg,yg !temporary x and y coords of current cell + real w1,w2 ! weights for Gauss-weighted average + real wtot1,wtot2 ! sum of weights + real ftot1,ftot2 ! accumulators for values, corrections + real dsq ! delx**2 + dely**2 + double precision xa,ya ! x, y coords of current station + double precision xb,yb ! x, y coords of current station + real dvar(nstns_max) ! estimated error + + real xkappa_1 ! Gauss constant for first pass + real xkappa_2 ! Gauss constant for second pass + real rmax_1 ! maximum scanning radii, for first + real rmax_2 ! and second passes + real anum_1 ! numerator, beyond scanning radius, + real anum_2 ! for first and second passes + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Compute the first and second pass values of the scaling parameter +! and the maximum scanning radius used by the Barnes scheme. +! Values above this maximum will use a 1/r**2 weighting. Here I +! have assumed a gamma value of 0.2. + +! First-round values, Eqn (13). + pi = 2.0 * acos(0.0) + xkappa_1 = 5.052 * (2.0*dn/pi)**2 + +! Define the maximum scanning radius to have weight defined by +! wt = 1.0 x 10**(-30) = exp(-rmax_1/xkappa_1) +! Also scale the 1/r**2 wts so that when dsq = rmax, the wts match. + rmax_1 = xkappa_1 * 30.0 * log(10.0) + anum_1 = 1.0e-30 * rmax_1 + +! Second-round values, Eqn (4). + xkappa_2 = gamma * xkappa_1 + rmax_2 = rmax_1 * gamma + anum_2 = 1.0e-30 * rmax_2 + +! Scan each input data point and construct estimated error, dvar, at +! that point. + do nn=1,nstns + + xa = xstn(nn) + ya = ystn(nn) + wtot1 = 0.0 + ftot1 = 0.0 + + do mm=1,nstns + + xb = xstn(mm) + yb = ystn(mm) + dsq = (xb - xa)**2 + (yb - ya)**2 + + if (dsq.le.rmax_1) then + + w1 = exp((- dsq)/xkappa_1) + + else + +! Assume a 1/r**2 weight. + w1 = anum_1/dsq + + endif + + wtot1 = wtot1 + w1 + ftot1 = ftot1 + w1 * var(mm) + + end do ! end loop on sites m + + if (wtot1.eq.0.0) print *,'stn wt totals zero' + + dvar(nn) = var(nn) - ftot1/wtot1 + + end do ! end prediction loop on sites nn + +! Grid-prediction loop. Generate the estimate using first set of +! weights, and correct using error estimates, dvar, and second +! set of weights. + +! do 666 j=1,ny +! do 555 i=1,nx + +! xcoords of grid nodes at index i,j +! ycoords of grid nodes at index i,j + if (snowmodel_line_flag.eq.1.0) then + xg = xg_line(i,j) + yg = yg_line(i,j) + else + xg = xmn + deltax * (real(i) - 1.0) + yg = ymn + deltay * (real(j) - 1.0) + endif + +! Scan each input data point. + ftot1 = 0.0 + wtot1 = 0.0 + ftot2 = 0.0 + wtot2 = 0.0 + nflag = 0 + + do nn=1,nstns + + xa = xstn(nn) + ya = ystn(nn) + dsq = (xg - xa)**2 + (yg - ya)**2 + + if (dsq.le.rmax_2) then + + w1 = exp((- dsq)/xkappa_1) + w2 = exp((- dsq)/xkappa_2) + + elseif (dsq.le.rmax_1) then + + w1 = exp((- dsq)/xkappa_1) + w2 = anum_2/dsq + + else + +! Assume a 1/r**2 weight. + w1 = anum_1/dsq + nflag = nflag + 1 +! With anum_2/dsq. + w2 = gamma * w1 + + endif + + wtot1 = wtot1 + w1 + wtot2 = wtot2 + w2 + ftot1 = ftot1 + w1 * var(nn) + ftot2 = ftot2 + w2 * dvar(nn) + + end do ! end loop on data sites nn + + if (wtot1.eq.0.0 .or. wtot2.eq.0.0) print *,'wts total zero' + + if (ifill.eq.1) then + grid(i,j) = ftot1/wtot1 + ftot2/wtot2 + else + if (nflag.lt.nstns) then + grid(i,j) = ftot1/wtot1 + ftot2/wtot2 + else + grid(i,j) = undef + endif + endif + +!c 555 continue ! end loop on cols i +!c 666 continue ! end loop on rows j + + return + end subroutine barnes_oi_ij + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine single_stn(nx,ny,nstns,var,grid) + + use snowmodel_inc + implicit none + + integer nstns ! number of input values, all good + integer nx ! number of x output values + integer ny ! number of y output values + + real var(nstns_max) ! input values + real grid(nx,ny) ! output values + integer i,j ! col, row counters + +!c Assign the station value to every grid cell. + do j=1,ny + do i=1,nx + grid(i,j) = var(nstns) + enddo + enddo + + return + end subroutine single_stn + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine pressure(nx,ny,topo,sfc_pressure) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny + + real topo(nx,ny),sfc_pressure(nx,ny) + real one_atmos,scale_ht + + one_atmos = 101300.0 +! scale_ht = 8500.0 + scale_ht = 8000.0 + +! Compute the average station pressure (in Pa). + do j=1,ny + do i=1,nx + sfc_pressure(i,j) = one_atmos * exp((- topo(i,j))/scale_ht) + enddo + enddo + + return + end subroutine pressure + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine shortwave_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,var_grid,iter) + +! This program takes observations as discrete points, compares +! those observations with a gridded model representation of those +! observations, at the corresponding grid cells, computes a +! difference between the observations and modeled values, fits +! a gridded surface through those differences, and adds the +! difference grid to the model grid. Thus, correcting the model +! outputs with the observations. + + use snowmodel_inc + implicit none + + real deltax,deltay,xhour,xhr,elev(nstns_max),undef + real var_grid(nx,ny),delta_var_grid(nx,ny) + real var_obs(nstns_max),elev_orig(nstns_max),var_orig(nstns_max) + + double precision xmn,ymn + double precision xstn(nstns_max),ystn(nstns_max) + double precision xstn_orig(nstns_max),ystn_orig(nstns_max) + + integer nx,ny,k,nstns,iter,iyr,imo,idy,iyear,imonth,iday,& + & idstn_orig,nstns_orig,i,j + +! Open the observation data file. + if (iter.eq.1) open (unit=71,file='extra_met/shortwave.dat') + +! Read the data describing the time, location, and variable values +! for each station, at this time step. Here I have assumed that +! the data file is in the 'non-single-station' format (with a +! station count listed at the begining at each new time step). + read(71,*) nstns_orig + do k=1,nstns_orig + read(71,*) iyr,imo,idy,xhr,idstn_orig,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),var_orig(k) + enddo + +! Compare the observation time with the model time. + if (iyr.ne.iyear .or. imo.ne.imonth .or. idy.ne.iday & + & .or. xhr.ne.xhour) then + print *,'model time does not match obs data input time' + print *,' model =', iyear,imonth,iday,xhour + print *,' obs =', iyr,imo,idy,xhr + stop + endif + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,var_orig,var_obs) + +! If there are no observational data at this time step, use the +! modeled values without any modification. If there are some +! good data, do the correction/data assimilation. + if (nstns.gt.0) then + call DATA_ASSIM(nx,ny,deltax,deltay,xmn,ymn,xstn,ystn,& + & nstns,var_obs,delta_var_grid,var_grid) + endif + +! For incoming shortwave, incoming longwave, and surface pressure, +! make sure no negetive numbers have been produced. + do j=1,ny + do i=1,nx + var_grid(i,j) = max(0.0,var_grid(i,j)) + enddo + enddo + + open (74,file='extra_met/shortwave_grid.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + write (74,rec=iter) ((delta_var_grid(i,j),i=1,nx),j=1,ny) + close(74) + + return + end subroutine shortwave_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine longwave_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,var_grid,iter) + +! This program takes observations as discrete points, compares +! those observations with a gridded model representation of those +! observations, at the corresponding grid cells, computes a +! difference between the observations and modeled values, fits +! a gridded surface through those differences, and adds the +! difference grid to the model grid. Thus, correcting the model +! outputs with the observations. + + use snowmodel_inc + implicit none + + real deltax,deltay,xhour,xhr,elev(nstns_max),undef + real var_grid(nx,ny),delta_var_grid(nx,ny) + real var_obs(nstns_max),elev_orig(nstns_max),var_orig(nstns_max) + + double precision xmn,ymn + double precision xstn(nstns_max),ystn(nstns_max) + double precision xstn_orig(nstns_max),ystn_orig(nstns_max) + + integer nx,ny,k,nstns,iter,iyr,imo,idy,iyear,imonth,iday,& + & idstn_orig,nstns_orig,i,j + +! Open the observation data file. + if (iter.eq.1) open (unit=72,file='extra_met/longwave.dat') + +! Read the data describing the time, location, and variable values +! for each station, at this time step. Here I have assumed that +! the data file is in the 'non-single-station' format (with a +! station count listed at the begining at each new time step). + read(72,*) nstns_orig + do k=1,nstns_orig + read(72,*) iyr,imo,idy,xhr,idstn_orig,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),var_orig(k) + enddo + +! Compare the observation time with the model time. + if (iyr.ne.iyear .or. imo.ne.imonth .or. idy.ne.iday & + & .or. xhr.ne.xhour) then + print *,'model time does not match obs data input time' + print *,' model =', iyear,imonth,iday,xhour + print *,' obs =', iyr,imo,idy,xhr + stop + endif + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,var_orig,var_obs) + +! If there are no observational data at this time step, use the +! modeled values without any modification. If there are some +! good data, do the correction/data assimilation. + if (nstns.gt.0) then + call DATA_ASSIM(nx,ny,deltax,deltay,xmn,ymn,xstn,ystn,& + & nstns,var_obs,delta_var_grid,var_grid) + endif + +! For incoming shortwave, incoming longwave, and surface pressure, +! make sure no negetive numbers have been produced. + do j=1,ny + do i=1,nx + var_grid(i,j) = max(0.0,var_grid(i,j)) + enddo + enddo + +! open (75,file='extra_met/longwave_grid.gdat', +! & form='unformatted',access='direct',recl=4*nx*ny) +! write (75,rec=iter) ((delta_var_grid(i,j),i=1,nx),j=1,ny) +! close(75) + + return + end subroutine longwave_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine sfc_pressure_data(nx,ny,deltax,deltay,xmn,ymn,& + & iyear,imonth,iday,xhour,undef,var_grid,iter) + +! This program takes observations as discrete points, compares +! those observations with a gridded model representation of those +! observations, at the corresponding grid cells, computes a +! difference between the observations and modeled values, fits +! a gridded surface through those differences, and adds the +! difference grid to the model grid. Thus, correcting the model +! outputs with the observations. + + use snowmodel_inc + implicit none + + real deltax,deltay,xhour,xhr,elev(nstns_max),undef + real var_grid(nx,ny),delta_var_grid(nx,ny) + real var_obs(nstns_max),elev_orig(nstns_max),var_orig(nstns_max) + + double precision xmn,ymn + double precision xstn(nstns_max),ystn(nstns_max) + double precision xstn_orig(nstns_max),ystn_orig(nstns_max) + + integer nx,ny,k,nstns,iter,iyr,imo,idy,iyear,imonth,iday,& + & idstn_orig,nstns_orig,i,j + +! Open the observation data file. + if (iter.eq.1) open (unit=73,file='extra_met/sfc_pressure.dat') + +! Read the data describing the time, location, and variable values +! for each station, at this time step. Here I have assumed that +! the data file is in the 'non-single-station' format (with a +! station count listed at the begining at each new time step). + read(73,*) nstns_orig + do k=1,nstns_orig + read(73,*) iyr,imo,idy,xhr,idstn_orig,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),var_orig(k) + enddo + +! Compare the observation time with the model time. + if (iyr.ne.iyear .or. imo.ne.imonth .or. idy.ne.iday & + & .or. xhr.ne.xhour) then + print *,'model time does not match obs data input time' + print *,' model =', iyear,imonth,iday,xhour + print *,' obs =', iyr,imo,idy,xhr + stop + endif + +! Filter through the original input data, and eliminate any +! missing values. + call get_good_values1(nstns_orig,xstn_orig,ystn_orig,& + & elev_orig,undef,nstns,xstn,ystn,elev,var_orig,var_obs) + +! If there are no observational data at this time step, use the +! modeled values without any modification. If there are some +! good data, do the correction/data assimilation. + if (nstns.gt.0) then + call DATA_ASSIM(nx,ny,deltax,deltay,xmn,ymn,xstn,ystn,& + & nstns,var_obs,delta_var_grid,var_grid) + endif + +! For incoming shortwave, incoming longwave, and surface pressure, +! make sure no negetive numbers have been produced. + do j=1,ny + do i=1,nx + var_grid(i,j) = max(0.0,var_grid(i,j)) + enddo + enddo + +! open (76,file='extra_met/sfc_pressure_grid.gdat', +! & form='unformatted',access='direct',recl=4*nx*ny) +! write (76,rec=iter) ((delta_var_grid(i,j),i=1,nx),j=1,ny) +! close(76) + + return + end subroutine sfc_pressure_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine DATA_ASSIM(nx,ny,deltax,deltay,xmn,ymn,xstn,ystn,& + & nstns,var_obs,delta_var_grid,var_grid) + + use snowmodel_inc + implicit none + + real deltax,deltay,undef,dn + real var_grid(nx,ny),delta_var_grid(nx,ny) + real var_model(nstns_max),var_obs(nstns_max),& + & delta_var(nstns_max) + + double precision xmn,ymn + double precision xstn(nstns_max),ystn(nstns_max) + + integer ii(nstns_max),jj(nstns_max) + integer nx,ny,i,j,ifill,iobsint,k,nstns + +! Convert the x and y locations to (ii,jj) locations. + do k=1,nstns + ii(k) = 1 + nint((xstn(k) - xmn) / deltax) + jj(k) = 1 + nint((ystn(k) - ymn) / deltay) + enddo + +! Extract the modeled data at the appropriate grid cells. + do k=1,nstns + var_model(k) = var_grid(ii(k),jj(k)) + enddo + +! Calculate the difference between the modeled variable and the +! observation at each point/grid cell. + do k=1,nstns + delta_var(k) = var_obs(k) - var_model(k) + enddo + +! Now that I have the differences calculated at each observation +! point, interpolate them over the simulation domain. Use the +! barnes oi scheme to create the distribution. If there is +! only a single station, distribute those data uniformly over +! the domain. Make sure that ifill=1, and then undef is not +! really used (so it does not have to be the same as defined in +! the .par file). + undef = -9999.0 + ifill = 1 + iobsint = 0 + + if (nstns.ge.2) then + call get_dn(nx,ny,deltax,deltay,nstns,dn,iobsint) + call barnes_oi(nx,ny,deltax,deltay,xmn,ymn,& + & nstns,xstn,ystn,delta_var,dn,delta_var_grid,undef,ifill) + elseif (nstns.eq.1) then + call single_stn(nx,ny,nstns,delta_var,delta_var_grid) + endif + +! Use the gridded delta surface to correct the modeled variable. + do j=1,ny + do i=1,nx + var_grid(i,j) = var_grid(i,j) + delta_var_grid(i,j) + enddo + enddo + + return + end subroutine DATA_ASSIM + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_lai(J_day,forest_LAI) + + implicit none + + integer J_day,n + integer, parameter :: nftypes = 5 + + real vlai_summer(nftypes),vlai_winter(nftypes),& + & forest_LAI(nftypes) + + real pi,daysinyr,tmax,tmin,peak_jday,dtseason,vtrans,tseason,& + & fseason + +! The five forest types in MicroMet/SnowModel: +! 1 coniferous forest +! 2 deciduous forest +! 3 mixed forest +! 4 scattered short-conifer +! 5 clearcut conifer + + data vlai_summer /2.5, 2.5, 2.5, 1.5, 1.0/ + data vlai_winter /2.5, 0.5, 1.5, 1.5, 1.0/ + +! Note: A maximum forest LAI of 5.0 will give almost zero (like +! 10 W m^2) incoming solar under the canopy. Values for Fraser +! Experimental Forest in Colorado are 2-3 (LSOS site = 1.8, +! Kelly's/Gus' site = 2.3). + +! Calculate a seasonally varying temperature, assuming a max and +! min temperature and a cos distribution peaking in mid July +! (J_day = 200). Then use this to define the seasonal lai +! variation. + pi = 2.0 * acos(0.0) + daysinyr = 366.0 + tmax = 298.0 + tmin = 273.0 + peak_jday = 200.0 + + dtseason = tmax - tmin + vtrans = tmin + dtseason / 2.0 + + tseason = vtrans + dtseason / 2.0 * & + & cos(2.0 * pi / daysinyr * (real(J_day) - peak_jday)) + + fseason = 0.0016 * (tmax - tseason)**2 + + do n=1,nftypes + forest_LAI(n) = (1.0 - fseason) * vlai_summer(n) + & + & fseason * vlai_winter(n) + enddo + +! print *,J_day,(forest_LAI(n),n=1,nftypes) + + return + end subroutine get_lai + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine read_wind_file(nx,ny,iter,uwind_grid,vwind_grid,& + & windspd_grid,winddir_grid,windspd_flag,winddir_flag,& + & windspd_min) + + use snowmodel_inc + implicit none + + integer nx + integer ny + + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + real winddir_grid(nx,ny) + real windspd_grid(nx,ny) + + real pi,deg2rad,rad2deg + integer i,j,iter,irec + real windspd_flag,winddir_flag,u_sum,v_sum,windspd_min + +! Define the required constants. + pi = 2.0 * acos(0.0) + deg2rad = pi / 180.0 + rad2deg = 180.0 / pi + +! Read in the u and v arrays for this time step. + if (iter.eq.1) then + open (66,file='/data10/baffin/nuatmos/wind_spd_dir.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + endif + + irec = (iter - 1) * 2 + read (66,rec=irec+1) ((uwind_grid(i,j),i=1,nx),j=1,ny) + read (66,rec=irec+2) ((vwind_grid(i,j),i=1,nx),j=1,ny) + +! Convert these u and v components to speed and directions. + do j=1,ny + do i=1,nx + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(uwind_grid(i,j)).lt.1e-10) uwind_grid(i,j) = 1e-10 + + winddir_grid(i,j) = rad2deg * & + & atan2(uwind_grid(i,j),vwind_grid(i,j)) + if (winddir_grid(i,j).ge.180.0) then + winddir_grid(i,j) = winddir_grid(i,j) - 180.0 + else + winddir_grid(i,j) = winddir_grid(i,j) + 180.0 + endif + windspd_grid(i,j) = & + & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + enddo + enddo + +! Avoid problems of zero (low) winds (for example, turbulence +! theory, log wind profile, etc., says that we must have some +! wind. Thus, some equations blow up when the wind speed gets +! very small). + do j=1,ny + do i=1,nx + if (windspd_grid(i,j).lt.windspd_min) then + windspd_grid(i,j) = windspd_min + uwind_grid(i,j) = (- windspd_grid(i,j)) * & + & sin(deg2rad*winddir_grid(i,j)) + vwind_grid(i,j) = (- windspd_grid(i,j)) * & + & cos(deg2rad*winddir_grid(i,j)) + endif + enddo + enddo + +! Find the maximum wind speed in the domain, and the +! domain-averaged wind direction. + windspd_flag = 0.0 + u_sum = 0.0 + v_sum = 0.0 + do j=1,ny + do i=1,nx + windspd_flag = max(windspd_flag,windspd_grid(i,j)) + u_sum = u_sum + uwind_grid(i,j) + v_sum = v_sum + vwind_grid(i,j) + enddo + enddo + u_sum = u_sum / real(nx*ny) + v_sum = v_sum / real(nx*ny) + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(u_sum).lt.1e-10) u_sum = 1e-10 + + winddir_flag = rad2deg * atan2(u_sum,v_sum) + if (winddir_flag.ge.180.0) then + winddir_flag = winddir_flag - 180.0 + else + winddir_flag = winddir_flag + 180.0 + endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_daily_irec (iter,dt,irec_day) + + implicit none + + integer iter,irec_day + real dt,secs_in_day,secs_in_sim + + secs_in_day = 60.0 * 60.0 * 24.0 + + secs_in_sim = dt * real(iter - 1) + irec_day = int(secs_in_sim / secs_in_day) + 1 + + return + end subroutine get_daily_irec + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/outputs_user.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/outputs_user.f90 new file mode 100755 index 000000000..33f59ecef --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/outputs_user.f90 @@ -0,0 +1,483 @@ +! outputs_user.f90 + +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + + subroutine OUTPUTS_USER(nx,ny,iter,Tair_grid,rh_grid,& + & uwind_grid,vwind_grid,windspd_grid,winddir_grid,& + & Qsi_grid,Qli_grid,prec_grid,Tsfc,Qle,Qh,Qe,Qc,Qm,Qf,& + & e_balance,snow_depth,xro_snow,swe_depth,ro_nsnow,& + & runoff,rain,sprec,sum_prec,sum_runoff,w_balance,& + & snow_d,topo_land,wbal_qsubl,sum_sprec,wbal_salt,& + & wbal_susp,ro_snow_grid,sum_Qcs,canopy_int,Qcs,& + & iyear,imonth,iday,xhour,undef,deltax,xmn,ymn,& + & wbal_subgrid,canopy_unload,sum_qsubl,sum_trans,& + & sum_unload,sum_glacmelt,glacier_melt,swemelt,& + & sfc_pressure,sum_swemelt,albedo,nrecs_max,& + & icorr_factor_loop,swesublim,vegtype,iter_start,& + & seaice_run,print_inc,cloud_frac_grid,& + & output_path_wo_assim,output_path_wi_assim,print_var,& + & print_outvars,Qsubl_depth,Qsalt,Qsusp) + +! This subroutine is available to provide user-defined outputs. +! These might be special-case situations, like just writing out +! data at the end of every day, writing out a few grid cells, +! saving each data arrays to individual files, etc. + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,iter,max_poly,num_poly,iyear,imonth,iday,& + & icorr_factor_loop,iter_start,icorr_loop_new,& + & individual_files,k,irec + + real Tair_grid(nx,ny),rh_grid(nx,ny),& + & uwind_grid(nx,ny),vwind_grid(nx,ny),& + & windspd_grid(nx,ny),winddir_grid(nx,ny),& + & Qsi_grid(nx,ny),Qli_grid(nx,ny),& + & prec_grid(nx,ny),Tsfc(nx,ny),& + & Qle(nx,ny),Qh(nx,ny),Qe(nx,ny),& + & Qc(nx,ny),Qm(nx,ny),Qf(nx,ny),& + & e_balance(nx,ny),snow_depth(nx,ny),& + & xro_snow(nx,ny),swe_depth(nx,ny),& + & ro_nsnow(nx,ny),runoff(nx,ny),& + & rain(nx,ny),sprec(nx,ny),& + & sum_prec(nx,ny),sum_runoff(nx,ny),& + & w_balance(nx,ny),snow_d(nx,ny),& + & topo_land(nx,ny),wbal_qsubl(nx,ny),& + & sum_sprec(nx,ny),wbal_salt(nx,ny),& + & wbal_susp(nx,ny),ro_snow_grid(nx,ny),& + & sum_Qcs(nx,ny),canopy_int(nx,ny),& + & Qcs(nx,ny),wbal_subgrid(nx,ny),& + & canopy_unload(nx,ny),sum_qsubl(nx,ny),& + & sum_trans(nx,ny),glacier_melt(nx,ny),& + & sum_unload(nx,ny),sum_glacmelt(nx,ny),& + & swemelt(nx,ny),sfc_pressure(nx,ny),& + & sum_swemelt(nx,ny),swesublim(nx,ny),& + & vegtype(nx,ny),albedo(nx,ny),& + & cloud_frac_grid(nx,ny),Qsubl_depth(nx,ny),& + & Qsalt(nx,ny),Qsusp(nx,ny) + + real undef,xhour,deltax,pi,rad2deg,seaice_run,print_inc + double precision xmn,ymn + double precision nrecs_max,nrecs + + real uwnd(nx,ny) + real vwnd(nx,ny) + +! Define the output variable data block. Note that the print_var +! "yes/no" array was generated in readparam_code.f. +! real vars(nx_max,ny_max,n_print_vars) + real vars(nx,ny,n_print_vars) ! KRA + + character*80 output_path_wo_assim,output_path_wi_assim + character*1 print_var(n_print_vars) + character*4 print_outvars(n_print_vars) + +! This was defined in preprocess_code.f, in subroutine mk_ctl_files. +! data print_outvars /'tair','relh','wspd','qsin','qlin', +! & 'qlem','albd','wdir','prec','rpre', +! & 'spre','smlt','ssub','roff','glmt', +! & 'snod','sden','swed','sspr','ssmt', +! & 'cldf','var1','var2','var3','var4', +! & 'var5','var6','var7','var8','var9'/ + +! These now come in from the .par file. +! character path1*(*) +! character path2*(*) + + integer i_trailing_blanks,trailing_blanks,i_len_wo,i_len_wi + +! Calculate how long the paths are. + i_len_wo = 80 - trailing_blanks(output_path_wo_assim) + i_len_wi = 80 - trailing_blanks(output_path_wi_assim) +! print *, i_len_wo,i_len_wi +! print *, output_path_wo_assim(1:i_len_wo) +! print *, output_path_wi_assim(1:i_len_wi) + +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + +! BEGIN USER EDIT SECTION. + +! Define which variables you want to save, whether they will be +! output at every time step or some time-step increment, which +! directories the data will be put in, etc. + +! Define the output file locations (paths). +! These now come in from the .par file. +! parameter (path1 = +! & 'outputs/wo_assim/') +! parameter (path2 = +! & 'outputs/wi_assim/') + +! Write a seperate file for each variable (individual_files = 1). +! No other option has been implemented here. + individual_files = 1 + +! Define the number of time steps you are going to sum or average +! over. If you want to output data at every model time step, set +! print_inc = 1.0. For run with an hourly time step and data +! writes once a day, print_inc = 24.0. For a run with 3-hourly +! time steps and data writes once a day, print_inc = 8.0. +! This now comes in from the .par file. +! print_inc = 24.0 +! print_inc = 1.0 +! print_inc = 8.0 + +! Define the variables you want to save. The following are the +! variables this subroutine is currently set up to output. +! Listed are the output variable name and the corresponding model +! variable name. +! Note that these "yes/no" flags are now defined in snowmodel.par. + +! VALUES AVERAGED OVER THE PERIOD. +! 1 tair(i,j) = Tair_grid(i,j) - 273.15 +! 2 relh(i,j) = rh_grid(i,j) +! 3 wspd(i,j) = windspd_grid(i,j) +! 4 qsin(i,j) = Qsi_grid(i,j) +! 5 qlin(i,j) = Qli_grid(i,j) +! 6 qlem(i,j) = Qle(i,j) +! 7 albd(i,j) = albedo(i,j) +! 8 wdir(i,j) = from uwind_grid(i,j) and vwind_grid(i,j) + +! VALUES SUMMED OVER THE PERIOD. +! 9 prec(i,j) = prec_grid(i,j) +! 10 rpre(i,j) = rain(i,j) +! 11 spre(i,j) = sprec(i,j) +! 12 smlt(i,j) = swemelt(i,j) +! 13 ssub(i,j) = swesublim(i,j) +! 14 roff(i,j) = runoff(i,j) +! 15 glmt(i,j) = glacier_melt(i,j) + +! VALUES SAVED AT THE END OF THE PERIOD. +! 16 snod(i,j) = snow_depth(i,j) +! 17 sden(i,j) = xro_snow(i,j) +! 18 swed(i,j) = swe_depth(i,j) +! 19 sspr(i,j) = sum_sprec(i,j) +! 20 ssmt(i,j) = sum_swemelt(i,j) + +! NEW VARIABLES ADDED TO THE OUTPUT DATA BLOCK. +! (you have to modify the code below to +! do the processing you want for these) +! 21 cldf(i,j) = cloud_fraction_grid(i,j) + +! Define which variables you want to save by placing a yes = 'y' or +! no = 'n' in front of the variable number. + +! VALUES AVERAGED OVER THE PERIOD. +! VALUES AVERAGED OVER THE PERIOD. +! 1 = tair(i,j) = Tair_grid(i,j) - 273.15 +! print_var(1) = 'y' + +! 2 = relh(i,j) = rh_grid(i,j) +! print_var(2) = 'n' + +! 3 = wspd(i,j) = windspd_grid(i,j) +! print_var(3) = 'n' + +! 4 = qsin(i,j) = Qsi_grid(i,j) +! print_var(4) = 'n' + +! 5 = qlin(i,j) = Qli_grid(i,j) +! print_var(5) = 'n' + +! 6 = qlem(i,j) = Qle(i,j) +! print_var(6) = 'n' + +! 7 = albd(i,j) = albedo(i,j) +! print_var(7) = 'n' + +! 8 = wdir(i,j) = from uwind_grid(i,j) and vwind_grid(i,j) +! print_var(8) = 'n' + +! VALUES SUMMED OVER THE PERIOD. +! VALUES SUMMED OVER THE PERIOD. +! 9 = prec(i,j) = prec_grid(i,j) +! print_var(9) = 'y' + +! 10 = rpre(i,j) = rain(i,j) +! print_var(10) = 'y' + +! 11 = spre(i,j) = sprec(i,j) +! print_var(11) = 'y' + +! 12 = smlt(i,j) = swemelt(i,j) +! print_var(12) = 'n' + +! 13 = ssub(i,j) = swesublim(i,j) +! print_var(13) = 'n' + +! 14 = roff(i,j) = runoff(i,j) +! print_var(14) = 'n' + +! 15 = glmt(i,j) = glacier_melt(i,j) +! print_var(15) = 'n' + +! VALUES SAVED AT THE END OF THE PERIOD. +! VALUES SAVED AT THE END OF THE PERIOD. +! 16 = snod(i,j) = snow_depth(i,j) +! print_var(16) = 'y' + +! 17 = sden(i,j) = xro_snow(i,j) +! print_var(17) = 'y' + +! 18 = swed(i,j) = swe_depth(i,j) +! print_var(18) = 'y' + +! 19 = sspr(i,j) = sum_sprec(i,j) +! print_var(19) = 'y' + +! 20 = ssmt(i,j) = sum_swemelt(i,j) +! print_var(20) = 'y' + +! NEW VARIABLES ADDED TO THE OUTPUT DATA BLOCK. +! NEW VARIABLES ADDED TO THE OUTPUT DATA BLOCK. +! (you have to modify the code below to +! do the processing you want for these) +! 21 = cldf(i,j) = cloud_fraction_grid(i,j) +! print_var(21) = 'n' + +! Extra variables. +! print_var(22) = 'n' +! print_var(23) = 'n' +! print_var(24) = 'n' +! print_var(25) = 'n' +! print_var(26) = 'n' +! print_var(27) = 'n' +! print_var(28) = 'n' +! print_var(29) = 'n' +! print_var(30) = 'n' + +! Note that this data output implementation is currently configured +! to mask out the ocean points (vegtype.eq.24.0) if this is a +! land run (seaice_run = 0.0); mask out all land points (vegtype. +! ne.24.0) if this is an ocean/sea ice run (seaice_run = 1.0, 3.0, +! or 4.0); and to not mask out anything if this is a combined land +! and sea ice run (seaice_run = 2.0). + +! END USER EDIT SECTION. + +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + +! Define the constants used in the wind-direction averaging. + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + + uwnd = 0.0 + vwnd = 0.0 + +! Use individual output files for each variable. + if (individual_files.eq.1) then + + if (iter.eq.iter_start) then + nrecs = nx * ny + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the .gdat files like the write statements' + print *,'are currently configured. You will have to change' + print *,'them to look like:' + print *,' do j=1,ny' + print *,' write (51,rec=j) (var(i,j),i=1,nx)' + print *,' enddo' + stop + endif + endif + +! Open individual output files for each variable. + if (iter.eq.iter_start) then + if (icorr_factor_loop.eq.1) then + do k=1,n_print_vars + if (print_var(k).eq.'y') then + open (220+k,& + &file=output_path_wo_assim(1:i_len_wo)//print_outvars(k)//'.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny,& + & status='replace') + endif + enddo + endif + + if (icorr_factor_loop.eq.2) then + do k=1,n_print_vars + if (print_var(k).eq.'y') then + open (320+k,& + &file=output_path_wi_assim(1:i_len_wi)//print_outvars(k)//'.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny,& + & status='replace') + endif + enddo + endif + endif + + if (iter.eq.iter_start) then +! Initialize the averaging and summing arrays. + do j=1,ny + do i=1,nx + do k=1,n_print_vars + vars(i,j,k) = 0.0 + enddo + uwnd(i,j) = 0.0 + vwnd(i,j) = 0.0 + enddo + enddo + endif + +! Perform the avaraging, summing, etc. + do j=1,ny + do i=1,nx +! Values averaged over the period. + vars(i,j,1) = vars(i,j,1) + (Tair_grid(i,j) - 273.15) / & + & print_inc + vars(i,j,2) = vars(i,j,2) + rh_grid(i,j) / print_inc + vars(i,j,3) = vars(i,j,3) + windspd_grid(i,j) / print_inc + vars(i,j,4) = vars(i,j,4) + Qsi_grid(i,j) / print_inc + vars(i,j,5) = vars(i,j,5) + Qli_grid(i,j) / print_inc + vars(i,j,6) = vars(i,j,6) + Qle(i,j) / print_inc + vars(i,j,7) = vars(i,j,7) + albedo(i,j) / print_inc + + uwnd(i,j) = uwnd(i,j) + uwind_grid(i,j) / print_inc + vwnd(i,j) = vwnd(i,j) + vwind_grid(i,j) / print_inc + +! Some compilers do not allow both u and v to be 0.0 in +! the atan2 computation. + if (abs(uwnd(i,j)).lt.1e-10) uwnd(i,j) = 1e-10 + + vars(i,j,8) = rad2deg * atan2(uwnd(i,j),vwnd(i,j)) + if (vars(i,j,8).ge.180.0) then + vars(i,j,8) = vars(i,j,8) - 180.0 + else + vars(i,j,8) = vars(i,j,8) + 180.0 + endif + +! Values summed over the period. + vars(i,j,9) = vars(i,j,9) + prec_grid(i,j) + vars(i,j,10) = vars(i,j,10) + rain(i,j) + vars(i,j,11) = vars(i,j,11) + sprec(i,j) + vars(i,j,12) = vars(i,j,12) + swemelt(i,j) + vars(i,j,13) = vars(i,j,13) + swesublim(i,j) + vars(i,j,14) = vars(i,j,14) + runoff(i,j) + vars(i,j,15) = vars(i,j,15) + glacier_melt(i,j) + +! Values saved at the end of the day. + vars(i,j,16) = snow_depth(i,j) + vars(i,j,17) = xro_snow(i,j) + vars(i,j,18) = swe_depth(i,j) + vars(i,j,19) = sum_sprec(i,j) + vars(i,j,20) = sum_swemelt(i,j) + +! Values averaged over the period. + vars(i,j,21) = vars(i,j,21) + cloud_frac_grid(i,j) / print_inc + +! New variables. + vars(i,j,22) = vars(i,j,22) + Qsubl_depth(i,j) + vars(i,j,23) = sum_trans(i,j) + vars(i,j,24) = vars(i,j,24) + Qsalt(i,j) + vars(i,j,25) = vars(i,j,25) + Qsusp(i,j) + + enddo + enddo + +! Check to see whether this is the data-write time step. + if (mod(iter,nint(print_inc)).eq.0) then + +! Mask out the ocean points (vegtype.eq.24.0) if this is +! a land run (seaice_run = 0.0). Mask out all land points +! (vegtype.ne.24.0) if this is an ocean/sea ice run +! (seaice_run = 1.0, 3.0, or 4.0). Do not mask out anything +! if this this is a combined land and sea ice run (seaice_run +! = 2.0). + if (seaice_run.eq.0.0) then + do j=1,ny + do i=1,nx + if (vegtype(i,j).eq.24.0) then + do k=1,n_print_vars + vars(i,j,k) = undef + enddo + endif + enddo + enddo + elseif (seaice_run.eq.1.0 .or. seaice_run.eq.3.0 .or. & + & seaice_run.eq.4.0) then + do j=1,ny + do i=1,nx + if (vegtype(i,j).ne.24.0) then + do k=1,n_print_vars + vars(i,j,k) = undef + enddo + endif + enddo + enddo + endif + +! Write out the data. + irec = iter / nint(print_inc) + if (icorr_factor_loop.eq.1) then + do k=1,n_print_vars + if (print_var(k).eq.'y') then + write (220+k,rec=irec) ((vars(i,j,k),i=1,nx),j=1,ny) + endif + enddo + elseif (icorr_factor_loop.eq.2) then + do k=1,n_print_vars + if (print_var(k).eq.'y') then + write (320+k,rec=irec) ((vars(i,j,k),i=1,nx),j=1,ny) + endif + enddo + endif + +! Reinitialize the averaging and summing arrays. + do j=1,ny + do i=1,nx + do k=1,n_print_vars + vars(i,j,k) = 0.0 + enddo + uwnd(i,j) = 0.0 + vwnd(i,j) = 0.0 + enddo + enddo + endif + +! Use more than one variable in an output file. + else + + print *,'Use more than one variable in an output file:' + print *,' THIS HAS NOT BEEN IMPLEMENTED YET' + + endif + + return + end + +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + +! THIS IS AN EXAMPLE OF SAVING DATA IN ASCII/TEXT FORMAT. + +! I have completely removed this example; I now do this with +! improved codes as part of post-processing steps. It is +! just too slow to do it as part of the model simulation. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! THE CODE BELOW WAS USED TO SAVE AVERAGES OVER POLYGONS. + +! I have completely removed this example; if I were to do this +! again I would do it as a post-processing step. If you really +! want to see what I did here, you can look in one of the pre- +! 2018 code distributions. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/preprocess_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/preprocess_code.f90 new file mode 100755 index 000000000..56355b2ec --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/preprocess_code.f90 @@ -0,0 +1,4328 @@ +! preprocess_code.f90 + +! Perform a variety of preprocessing steps, like read in topography +! and vegetation arrays, open input and output files, etc. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE PREPROCESS_CODE(topoveg_fname,const_veg_flag,& + & vegtype,veg_z0,vegsnowdepth,fetch,xmu,C_z,h_const,& + & wind_min,Up_const,dz_susp,ztop_susp,fall_vel,Ur_const,& + & ro_water,ro_air,gravity,vonKarman,pi,twopio360,snow_z0,& + & nx,ny,sum_sprec,sum_qsubl,sum_trans,sum_unload,topo,& + & topo_land,snow_d,topoflag,snow_d_init,snow_d_init_const,& + & soft_snow_d,met_input_fname,igrads_metfile,deltax,deltay,& + & snowtran_output_fname,micromet_output_fname,& + & enbal_output_fname,snowpack_output_fname,print_micromet,& + & print_enbal,print_snowpack,print_snowtran,run_micromet,& + & run_enbal,run_snowpack,run_snowtran,ro_snow_grid,swe_depth,& + & sum_runoff,sum_prec,ro_snow,twolayer_flag,sum_Qcs,& + & canopy_int,ascii_topoveg,topo_ascii_fname,icorr_factor_loop,& + & veg_ascii_fname,undef,isingle_stn_flag,max_iter,& + & i_tair_flag,i_rh_flag,i_wind_flag,i_prec_flag,sum_glacmelt,& + & snow_depth,sum_d_canopy_int,corr_factor,icorr_factor_index,& + & sum_sfcsublim,barnes_lg_domain,n_stns_used,k_stn,xmn,ymn,& + & ro_soft_snow_old,sum_swemelt,xlat,lat_solar_flag,xlat_grid,& + & xlon_grid,UTC_flag,dt,swe_depth_old,canopy_int_old,& + & vegsnowd_xy,iveg_ht_flag,ihrestart_flag,i_dataassim_loop,& + & multilayer_snowpack,max_layers,multilayer_output_fname,& + & print_multilayer,KK,tslsnowfall,tsls_threshold,& + & irun_data_assim,izero_snow_date,iclear_mn,iclear_dy,& + & xclear_hr,snod_layer,swed_layer,ro_layer,T_old,gamma,& + & icond_flag,curve_lg_scale_flag,curve_wt_lg,check_met_data,& + & seaice_run,snowmodel_line_flag,xg_line,yg_line,print_user,& + & cf_precip_flag,cf_precip,print_inc,xhour_init,Tabler_1_flag,& + & Tabler_2_flag,iyear_init,imonth_init,iday_init,print_var,& + & output_path_wo_assim,output_path_wi_assim,nrecs_max,& + & tabler_sfc_path_name,print_outvars,diam_layer) + + use snowmodel_inc + implicit none + +!KRA + logical snowmodel_masterproc +!KRA + + integer i,j,k,nx,ny,igrads_metfile,n_recs_out,iheader,& + & isingle_stn_flag,max_iter,i_tair_flag,i_rh_flag,i_wind_flag,& + & i_prec_flag,iter,iobs_num,n_stns_used,nveg,iveg_ht_flag,& + & lat_solar_flag,ihrestart_flag,nstns_orig,i_dataassim_loop,& + & multilayer_snowpack,max_layers,irun_data_assim,& + & izero_snow_date,iclear_mn,iclear_dy,icond_flag,& + & iyear_init,imonth_init,iday_init + + real ro_water,ro_air,gravity,vonKarman,snow_z0,& + & fetch,xmu,C_z,h_const,wind_min,Up_const,check_met_data,& + & dz_susp,ztop_susp,fall_vel,Ur_const,pi,twopio360,topoflag,& + & snow_d_init_const,const_veg_flag,ro_snow,twolayer_flag,& + & ascii_topoveg,undef,barnes_lg_domain,xlat,UTC_flag,dt,& + & print_multilayer,xclear_hr,curve_lg_scale_flag,seaice_run,& + & snowmodel_line_flag,print_user,print_inc,xhour_init,& + & Tabler_1_flag,Tabler_2_flag + + real topo_land(nx,ny) + real topo(nx,ny) + real vegtype(nx,ny) + real xlat_grid(nx,ny) + real xlon_grid(nx,ny) + + real snow_d(nx,ny) + real snow_depth(nx,ny) + real snow_d_init(nx,ny) + real canopy_int(nx,ny) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + + real sum_sprec(nx,ny) + real sum_qsubl(nx,ny) + real sum_trans(nx,ny) + real sum_unload(nx,ny) + real soft_snow_d(nx,ny) + real ro_soft_snow_old(nx,ny) + real ro_snow_grid(nx,ny) + real swe_depth(nx,ny) + real sum_prec(nx,ny) + real sum_runoff(nx,ny) + real sum_Qcs(nx,ny) + real sum_glacmelt(nx,ny) + real sum_swemelt(nx,ny) + real sum_d_canopy_int(nx,ny) + real sum_sfcsublim(nx,ny) + + real vegsnowdepth(nvegtypes) + real veg_z0(nx,ny) + real vegsnowd_xy(nx,ny) + + real curve_wt_lg(nx,ny) + + real corr_factor(nx_max,ny_max,max_obs_dates+1) + integer icorr_factor_index(max_time_steps) + integer icorr_factor_loop + + integer k_stn(nx,ny,9) + double precision xmn,ymn + double precision nrecs_max,nrecs + real deltax,deltay + integer icount,iii,jjj + double precision xg_line(nx,ny),yg_line(nx,ny) + + real run_micromet,run_enbal,run_snowpack,run_snowtran + real print_micromet,print_enbal,print_snowpack,print_snowtran + + character*80 topoveg_fname,met_input_fname,topo_ascii_fname,& + & veg_ascii_fname + character*80 snowtran_output_fname,micromet_output_fname,& + & enbal_output_fname,snowpack_output_fname,& + & multilayer_output_fname + + character*80 tabler_sfc_path_name + character*80 output_path_wo_assim,output_path_wi_assim + + character*1 print_var(n_print_vars) + character*4 print_outvars(n_print_vars) + + integer KK(nx,ny) + real tslsnowfall(nx,ny) + real tsls_threshold + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real gamma(nx,ny,nz_max) + real diam_layer(nx,ny,nz_max) + + real cf_precip(nx,ny) + real cf_precip_flag,cf_precip_scalar + + integer ipath_length,i_len_wo,i_len_wi,trailing_blanks + character*80 vege_ht_fname + + integer nyears,nyear,nobs_total,nobs_dates,nstns,krec + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! seaice_run = 3.0 is no longer supported. If seaice_run has been +! set to 3.0 in the .par file, send a message describing your +! options. + if (seaice_run.eq.3.0) then + print *, 'Eulerian sea ice runs are not longer supported' + print *, '(seaice_run = 3.0). If you want to restart this' + print *, 'option, see the notes in here:' + print *, '/sm/misc_programs/Eulerian_incremental_remapper/' + stop + endif + +! Check to see whether the maximum array dimensions defined in +! snowmodel.inc are adequate for the simulation domain defined +! in snowmodel.par. + if (snowmodel_line_flag.eq.0.0) then + if (seaice_run.eq.3.0) then + if (nx.ne.nx_max .or. ny.ne.ny_max) then + print *, 'For a sea ice remapping run, nx==nx_max' + print *, ' and ny==ny_max in the snowmodel.par and' + print *, ' snowmodel.inc.' + stop + endif + else + if (nx+1.gt.nx_max .or. ny+1.gt.ny_max) then + print *, 'Must increase the value of nx_max or ny_max' + print *, ' in snowmodel.inc to be greater than nx+1' + print *, ' and/or ny+1.' + print *, 'nx_max = ',nx_max,' ny_max = ',ny_max + print *, 'nx = ',nx,' ny = ',ny + stop + endif + endif + else + if (nx.ge.nx_max .or. ny.ne.1 .or. ny_max.ne.2) then + print *, 'For snowmodel_line_flag = 1.0, we suggest setting' + print *, 'nx = number of grid cells, ny = 1, nx_max = nx+1,' + print *, 'and ny_max = ny+1 = 2 in snowmodel.inc.' + print *, ' The current values are:' + print *, ' nx_max = ',nx_max,' ny_max = ',ny_max + print *, ' nx = ',nx,' ny = ',ny + stop + endif + endif + + if (multilayer_snowpack.eq.1) then + if (max_layers+1.gt.nz_max) then + print *, 'nz_max in snowmodel.inc must be at least 1 greater' + print *, ' than max_layers in the snowmodel.inc file. So,' + print *, ' if you want to run the multi-layer snowpack model' + print *, ' with a single snow layer, set nz_max=2. If you' + print *, ' want to run the original single-layer snowpack' + print *, ' model, you can set nz_max=1 in snowmodel.inc.' + print *, 'nz_max = ',nz_max + print *, 'max_layers = ',max_layers + stop + endif + endif + + if (max_iter.gt.max_time_steps) then + print *, 'Must increase the value of max_time_steps' + print *, ' in snowmodel.inc to be greater than max_iter.' + print *, 'max_time_steps = ',max_time_steps + print *, 'max_iter = ',max_iter + stop + endif + +! If running the concatenated configuration of the model, check to +! make sure the rest of the model is configured correctly. + if (snowmodel_line_flag.eq.1.0) then + if (run_snowtran.eq.1.0 .and. seaice_run.ne.4.0) then + print *, 'You cannot run snowmodel_line_flag = 1.0 with' + print *, 'run_snowtran = 1.0' + stop + endif + if (barnes_lg_domain.eq.0.0) then + print *, 'If snowmodel_line_flag = 1.0, then you must run' + print *, 'the model with barnes_lg_domain = 1.0' + stop + endif + endif + +! Make sure the time since last snowfall treshold is not less +! than the model time step. + if (multilayer_snowpack.eq.1) then + if (tsls_threshold.lt.dt/3600.0) then + print *,'Need to correct tsls_threshold to' + print *,' be >= dt (in hours).' + stop + endif + endif + +! Check the model dt value, and send an error message if dt < 3600. + if (dt.lt.3600.0) then + print *, 'You must modify the hour fraction calculation' + print *, ' in get_model_time subroutine to handle' + print *, ' dt values less that 3600.0 seconds.' + print *, 'dt = ',dt + stop + endif + +! Define the date on which the snow arrays will be zeroed out. + iclear_mn = izero_snow_date / 10000 + iclear_dy = (izero_snow_date - iclear_mn * 10000) / 100 + xclear_hr = & + & real((izero_snow_date - iclear_mn * 10000) - iclear_dy * 100) + +! Check to see whether there is enough snow layers to calculate +! conductive surface fluxes. + if (icond_flag.eq.1) then + if (multilayer_snowpack.eq.0 .or. max_layers.lt.2) then + print *,'If icond_flag = 1, then multilayer_snowpack = 1' + print *,' and max_layers >= 2.' + stop + endif + endif + +! Read in the topography array. + if (ascii_topoveg.eq.0.0) then + + open (unit=37,file=topoveg_fname, & + & form='unformatted',access='direct',recl=4*nx*ny) + read (37,rec=1) ((topo_land(i,j),i=1,nx),j=1,ny) + + elseif (ascii_topoveg.eq.1.0) then + +! Read off the header lines. I will assume that all of this +! information was input in the .par file correctly. + open (37,file=topo_ascii_fname,form='formatted') + iheader = 6 + do k=1,iheader + read (37,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (37,*) (topo_land(i,j),i=1,nx) + enddo + + endif + +! If vegetation data is not available on the topography grid, +! define the vegetation to be constant. + if (const_veg_flag.ne.0.0) then + do i=1,nx + do j=1,ny + vegtype(i,j) = const_veg_flag + enddo + enddo + +! Read in the vegetation array. + else + + if (ascii_topoveg.eq.0.0) then + read (37,rec=2) ((vegtype(i,j),i=1,nx),j=1,ny) + + elseif (ascii_topoveg.eq.1.0) then + +! Read off the header lines. I will assume that all of this +! information was input in the .par file correctly. + open (38,file=veg_ascii_fname,form='formatted') + do k=1,iheader + read (38,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (38,*) (vegtype(i,j),i=1,nx) + enddo + + endif + + endif + +! Now that we have read in the topo and veg data arrays, check +! whether all of the values look like valid numbers. +! KRA + if (ascii_topoveg.eq.0.0 .or. ascii_topoveg.eq.1.0) then + do i=1,nx + do j=1,ny + if (vegtype(i,j).lt.1.0 .or. vegtype(i,j).gt.30.0) then + print *, 'Found Invalid Vegetation-Type Value' + print *, ' Value =',vegtype(i,j),' at ',i,j + stop + endif + + if (topo_land(i,j).lt.0.0 .or. topo_land(i,j).gt.9000.0) then + print *, 'Found Invalid Topography Value' + print *, ' Value =',topo_land(i,j),' at ',i,j + stop + endif + enddo + enddo +! KRA + endif + +! Fill the the vegetation snow-holding depth array for vegetation +! types 1 through 24 (types 25 through 30 were filled from the +! .par file. + call fill_veg_shd(nvegtypes,vegsnowdepth) + +! Use vegsnowdepth to fill the 2D spatial array, or read in the +! user-provided file of the vegetation heights (in m). + if (iveg_ht_flag.eq.-1) then + +! Find the last occurance of '/' in the topo_vege path. + ipath_length = 0 + do k=1,len(topoveg_fname) + if (topoveg_fname(k:k).eq.'/') then + ipath_length = k + endif + enddo + + if (ipath_length.eq.0) then + print *,'vege_ht_fname path not found; looking' + print *,' in the SnowModel run directory' + endif + + vege_ht_fname = & + & topoveg_fname(1:ipath_length)//'veg_ht.gdat' + + open (191,file=vege_ht_fname, & + & form='unformatted',access='direct',recl=4*nx*ny) + read (191,rec=1) ((vegsnowd_xy(i,j),i=1,nx),j=1,ny) + close(191) + + elseif (iveg_ht_flag.eq.1) then + +! Find the last occurance of '/' in the veg_ascii_fname path. + ipath_length = 0 + do k=1,len(veg_ascii_fname) + if (veg_ascii_fname(k:k).eq.'/') then + ipath_length = k + endif + enddo + + if (ipath_length.eq.0) then + print *,'vege_ht_fname path not found; looking' + print *,' in the SnowModel run directory' + endif + + vege_ht_fname = & + & veg_ascii_fname(1:ipath_length)//'veg_ht.asc' + + open (191,file=vege_ht_fname,form='formatted') + iheader = 6 + do k=1,iheader + read (191,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (191,*) (vegsnowd_xy(i,j),i=1,nx) + enddo + close(191) + + elseif (iveg_ht_flag.eq.0) then + + do i=1,nx + do j=1,ny + nveg = nint(vegtype(i,j)) + vegsnowd_xy(i,j) = vegsnowdepth(nveg) + enddo + enddo + + endif + +! Define the roughness lengths for each of the vegetation types. +! Note that this is pretty arbitrary, because these values are +! really only used when there is no blowing snow, and thus have +! no impact on the simulation except to provide a non-zero value +! for any such parts of the domain. + do i=1,nx + do j=1,ny + veg_z0(i,j) = 0.25 * vegsnowd_xy(i,j) + enddo + enddo + +! Read in the large-scale curvature weighting array, if the run +! requires it. + if (curve_lg_scale_flag.eq.1.0) then + open (444,file='extra_met/large_curvature_wt.gdat', & + & form='unformatted',access='direct',recl=4*nx*ny) + read (444,rec=1) ((curve_wt_lg(i,j),i=1,nx),j=1,ny) + close (444) + endif + +! If this is a sea ice run, open the sea ice concentration file. + if (seaice_run.ne.0.0) then + open (445,file='seaice/ice_conc.gdat', & + & form='unformatted',access='direct',recl=4*nx*ny) + endif + +! If this is a Lagrangian sea ice parcel trajectory simulation, +! do some setup checking. + if (seaice_run.eq.4.0) then + if (barnes_lg_domain.ne.1.0 .or. n_stns_used.ne.1.0 .or. & + & snowmodel_line_flag.ne.1.0) then + print * + print *,'if seaice_run = 4.0, then' + print *,' barnes_lg_domain = 1.0' + print *,' n_stns_used = 1' + print *,' snowmodel_line_flag = 1.0' + print * + stop + endif + endif + +! Check to make sure that if you are running SnowTran-3D and the +! EnBal and SnowPack models, you have also set the flag to run +! the SnowTran-3D two-layer submodel. + if (run_enbal.eq.1.0 .and. run_snowpack.eq.1.0 .and. & + & run_snowtran.eq.1.0) then + if (twolayer_flag.ne.1.0) then + print *, 'For SnowTran-3D with EnBal and SnowPack,' + print *, ' twolayer_flag must equal 1.0' + stop + endif + endif + +! Check to see that the defined domain is large enough to be +! running SnowTran-3D. + if (run_snowtran.eq.1.0 .and. seaice_run.ne.4.0) then + if (nx.lt.3 .or. ny.lt.3) then + print *, 'To run SnowTran-3D, nx and ny must both be 3' + print *, ' or greater (see SnowTran-3D code/notes)' + stop + endif + endif + +! Check to see whether the model is configured correctly to be +! running the multi-layer snow model. + if (multilayer_snowpack.eq.1) then + if (ihrestart_flag.ne.-2 .or. snow_d_init_const.ne.0.0) then + print *, 'The multi-layer snowpack model requires:' + print *, ' ihrestart_flag = -2' + print *, ' snow_d_init_const = 0.0' + stop + endif + endif + +! Get a collection of constants that are not generally modified. + call constants(fetch,xmu,C_z,h_const,wind_min,Up_const, & + & dz_susp,ztop_susp,fall_vel,Ur_const,ro_water,ro_air, & + & gravity,vonKarman,pi,twopio360,snow_z0) + +! Run a check to see if SnowTran-3D is being run with grid +! increments that are too large. + if (deltax.gt.500.0 .or. deltay.gt.500.0) then + if (seaice_run.eq.0.0) then + if (run_snowtran.eq.1.0) then + print * + print *, '!!! deltax,y should not be greater than 500 m' + print *, '!!! if you are also running SnowTran-3D' + print * + stop + endif + endif + endif + +! Initialize the summing arrays, and define the initial snow-depth +! distributions. + call initialize(nx,ny,sum_sprec,sum_qsubl,sum_trans,& + & sum_unload,topo,topo_land,snow_d,topoflag,snow_d_init,& + & snow_d_init_const,soft_snow_d,ro_water,sum_sfcsublim,& + & ro_snow_grid,swe_depth,sum_runoff,sum_prec,ro_snow,& + & sum_Qcs,canopy_int,sum_glacmelt,snow_depth,sum_d_canopy_int,& + & ro_soft_snow_old,sum_swemelt,swe_depth_old,canopy_int_old,& + & ihrestart_flag,i_dataassim_loop,max_iter,corr_factor,& + & icorr_factor_index,KK,tslsnowfall,tsls_threshold,snod_layer,& + & swed_layer,ro_layer,T_old,gamma,diam_layer) + +! Check to see whether the data assimilation has been configured +! correctly. + if (irun_data_assim.eq.1) then + +! Check to see whether the required output files will be created. + if (print_user.ne.1.0) then + print *, 'For a data assimilation run print_user must = 1.0' + stop + endif + + if (print_var(19).ne.'y') then + print *, 'print_var_19 == y for a data assimilation run' + stop + endif + + if (print_var(20).ne.'y') then + print *, 'print_var_20 == y for a data assimilation run' + stop + endif + +! Check to see whether the corr_factor array is defined in the +! snowmodel.inc file to be large enough to do the assimilation. +! max_obs_dates is used in the data assimilation routines. It +! must be greater than or equal to the number of observation +! dates in the entire simulation + (plus) the number of years +! in the simulation. For example, for a 6-year simulation with +! 2 observation dates in each year, you would set max_obs_dates +! to be = 2obs*6yrs+6yrs = 18 or greater. For a 6-year run with +! 4 observation dates in 2 of the years, and 0 observation dates +! in the other 4 years, max_obs_dates = 8obs+6yrs = 14 or +! greater. +! parameter (max_obs_dates=18) + if (icorr_factor_loop.eq.1) then + open (unit=61,file='swe_assim/swe_obs.dat') + read(61,*) nyears + nobs_total = 0 + do nyear=1,nyears + read(61,*) nobs_dates + if (nobs_dates.gt.0) then + nobs_total = nobs_total + nobs_dates + do iobs_num=1,nobs_dates +! read(61,*) iiyr,iimo,iidy + read(61,*) + read(61,*) nstns + do k=1,nstns +! read(61,*) obsid(k),xstn(k),ystn(k),swe_obs(k) + read(61,*) + enddo + enddo + endif + enddo + close (61) + krec = nobs_total + nyears + if (krec.gt.max_obs_dates) then + print * + print *, 'For a DATA ASSIMILATION RUN, MAX_OBS_DATES must be' + print *, 'defined in SNOWMODEL.INC to be greater than the' + print *, 'number of obs dates in the entire simulation +' + print *, '(plus) the number of years in the simulation. For' + print *, 'example, for a 6-year simulation with 2 observation' + print *, 'dates in each year, you would set max_obs_dates to' + print *, 'be = 2obs*6yrs+6yrs = 18 or greater. For a 6-year' + print *, 'run with 4 observation dates in 2 of the years,' + print *, 'and 0 observation dates in the other 4 years,' + print *, 'max_obs_dates = 8obs+6yrs = 14 or greater.' + print * + print *, 'max_obs_dates must be increased in snowmodel.inc' + print *, 'It looks like you should set max_obs_dates = ',krec + print *, 'Right now, max_obs_dates = ',max_obs_dates + print * + stop + endif + endif + endif + +! Initialize the precipitation factor for the first iteration to +! equal 1.0. + if (icorr_factor_loop.eq.1) then + do iobs_num=1,max_obs_dates+1 + do j=1,ny + do i=1,nx + corr_factor(i,j,iobs_num) = 1.0 + enddo + enddo + enddo + do iter=1,max_iter + icorr_factor_index(iter) = 1 + enddo + endif + +! Read or build the latitude array that will be used to do the +! latitude weighting when calculating incoming solar radiation. + if (lat_solar_flag.eq.-1) then + + write(*,*) "SM: Reading in gridded latitude binary file" + open (91,file='extra_met/grid_lat.gdat', & + & form='unformatted',access='direct',recl=4*nx*ny) + read (91,rec=1) ((xlat_grid(i,j),i=1,nx),j=1,ny) + close(91) + + elseif (lat_solar_flag.eq.1) then + + open (91,file='extra_met/grid_lat.asc',form='formatted') + iheader = 6 + do k=1,iheader + read (91,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (91,*) (xlat_grid(i,j),i=1,nx) + enddo + close(91) + + elseif (lat_solar_flag.eq.0) then + +! Print an error if the y-domain is big enough to have important +! solar radiation differences from south to north. + if (ny*deltay.gt.500000.0) then + print * + print *,'YOUR DOMAIN IS PRETTY BIG TO NOT ACCOUNT FOR' + print *,' SOLAR RADIATION VARIATIONS WITH LATITUDE' + print *,' see the "lat_solar_flag" in snowmodel.par' + print * + stop + endif + + do i=1,nx + do j=1,ny + xlat_grid(i,j) = xlat + enddo + enddo + + endif + +! Read or build the longitude array that will be used to do the +! longitude influence when calculating incoming solar radiation. + if (UTC_flag.eq.-1.0) then + + write(*,*) "SM: Reading in gridded longitude binary file" + open (91,file='extra_met/grid_lon.gdat', & + & form='unformatted',access='direct',recl=4*nx*ny) + read (91,rec=1) ((xlon_grid(i,j),i=1,nx),j=1,ny) + close(91) + + elseif (UTC_flag.eq.1.0) then + + open (91,file='extra_met/grid_lon.asc',form='formatted') + iheader = 6 + do k=1,iheader + read (91,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (91,*) (xlon_grid(i,j),i=1,nx) + enddo + close(91) + + elseif (UTC_flag.eq.0.0) then + +! Print an error if the x-domain is big enough to have important +! solar radiation differences from east to west. + if (nx*deltax.gt.500000.0 .and. seaice_run.ne.4) then + print * + print *,'YOUR DOMAIN IS PRETTY BIG TO NOT ACCOUNT FOR' + print *,' SOLAR RADIATION VARIATIONS WITH LONGITUDE' + print *,' see the "UTC_flag" in snowmodel.par' + print * + endif + + endif + +! Open the MicroMet station data input file. + if (igrads_metfile.eq.1) then + open(20,file=met_input_fname,form='unformatted', & + & access='direct',recl=4*13) + else + open (20,file=met_input_fname,form='formatted') + endif + +! Run a check to see whether there are any time slices with no +! valid data. + if (check_met_data.eq.1.0) then + print * + print *,'Checking for sufficient met forcing data to' + print *,' complete the model simulation. This may' + print *,' take a while, depending on how big your met' + print *,' input file is.' + print * + call met_data_check(undef,isingle_stn_flag,igrads_metfile, & + & max_iter,i_tair_flag,i_rh_flag,i_wind_flag,i_prec_flag) + endif + +! If the concatenated configuration of the model is used, read +! in the x and y coordinates for the concatenated grid cells. + if (snowmodel_line_flag.eq.1.0) then + open (1331,file='extra_met/snowmodel_line_pts.dat') + do j=1,ny + do i=1,nx + read (1331,*) icount,iii,jjj,xg_line(i,j),yg_line(i,j) + enddo + enddo + close (1331) + endif + +! If the large-domain barnes oi scheme is used, generate the +! nearest-station indexing array. + if (barnes_lg_domain.eq.1.0) then +! if (barnes_lg_domain.eq.1.0 .and. snowmodel_masterproc) then + print * + print *,'You are running the large-domain Barnes oi scheme' + print *,' This requires:' + print *,' 1) no missing data for the fields of interest' + print *,' 2) no missing stations during the simulation' + print *,' 3) met file must list stations in the same order' + print *,' 4) the number of nearest stations used is 9 or less' + print *,' 5) **** no error checking for this is done ****' + print * + print *,'Generating nearest-station index. Be patient.' + print * + if (n_stns_used.gt.9 .or. n_stns_used.lt.1) then + print *,'invalid n_stns_used value' + stop + endif +! KRA +! call get_nearest_stns_1(nx,ny,xmn,ymn,deltax,deltay, +! & n_stns_used,k_stn,snowmodel_line_flag,xg_line,yg_line) +! KRA + endif + +! If this is a history restart run, advance the micromet input +! file to the restart time. + if (ihrestart_flag.ge.0) then + if (igrads_metfile.eq.0) then + do iter=1,ihrestart_flag + if (isingle_stn_flag.eq.1) then + nstns_orig = 1 + else + read(20,*) nstns_orig + endif + do k=1,nstns_orig + read(20,*) + enddo + enddo + endif + endif + +! Open the files to be used to store model output. + +! nrecs_max corresponds to the approximately 2.1 GB Fortran +! array limit for direct access binary inputs and outputs. +! The number listed here corresponds to nx = ny = 23170. +! "nrecs_max * 4 bytes per number" gives the 2.1 GB limit. + nrecs_max = 536848900 + +! For MicroMet. + if (run_micromet.eq.1.0 .and. print_micromet.eq.1.0) then + n_recs_out = 9 + nrecs = n_recs_out * nx * ny + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the micromet.gdat file. You must set' + print *,'print_micromet = 0.0 and use print_user = 1.0.' + stop + else + if (icorr_factor_loop.eq.2) close (81) + open (81,file=micromet_output_fname,& + & form='unformatted',access='direct',recl=4*n_recs_out*nx*ny,& + & status='replace') + endif + endif + +! For EnBal. + if (run_enbal.eq.1.0 .and. print_enbal.eq.1.0) then + n_recs_out = 11 + nrecs = n_recs_out * nx * ny + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the enbal.gdat file. You must set' + print *,'print_enbal = 0.0 and use print_user = 1.0.' + stop + else + if (icorr_factor_loop.eq.2) close (82) + open (82,file=enbal_output_fname,& + & form='unformatted',access='direct',recl=4*n_recs_out*nx*ny,& + & status='replace') + endif + endif + +! For SnowPack. + if (run_snowpack.eq.1.0 .and. print_snowpack.eq.1.0) then + n_recs_out = 16 + nrecs = n_recs_out * nx * ny + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the snowpack.gdat file. You must set' + print *,'print_snowpack = 0.0 and use print_user = 1.0.' + stop + else + if (icorr_factor_loop.eq.2) close (83) + open (83,file=snowpack_output_fname, & + & form='unformatted',access='direct',recl=4*n_recs_out*nx*ny,& + & status='replace') + endif + endif + +! For SnowTran-3D. + if (run_snowtran.eq.1.0 .and. print_snowtran.eq.1.0) then + n_recs_out = 7 + nrecs = n_recs_out * nx * ny + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the snowtran.gdat file. You must set' + print *,'print_snowtran = 0.0 and use print_user = 1.0.' + stop + else + if (icorr_factor_loop.eq.2) close (84) + open (84,file=snowtran_output_fname,& + & form='unformatted',access='direct',recl=4*n_recs_out*nx*ny,& + & status='replace') + endif + endif + +! For Multi-Layer SnowPack. + if (run_snowpack.eq.1.0 .and. multilayer_snowpack.eq.1 .and.& + & print_multilayer.eq.1.0) then + nrecs = 4 * nx * ny + 4 * nx * ny * nz_max + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the multilayer.gdat file. Since you' + print *,'clearly want this information, it will be written' + print *,'to the directory you defined in the .par file for' + print *,'the parameter "output_path_wo_assim".' + else + if (icorr_factor_loop.eq.2) close (401) + open (401,file=multilayer_output_fname, & + & form='unformatted',access='direct', & + & recl=4*(4*nx*ny+4*nx*ny*nz_max), & + & status='replace') + endif + elseif (run_snowpack.eq.1.0 .and. multilayer_snowpack.eq.1 .and. & + & print_multilayer.eq.2.0) then + nrecs = nx * ny * nz_max + if (nrecs.gt.nrecs_max) then + print *,'Your simulation domain has too many grid cells' + print *,'to print the print_multilayer = 2.0 files. You' + print *,'will have to restructure the write statements.' + print *,'See the example in the outputs_user.f subroutine' + print *,'where it does the "if (nrecs.gt.nrecs_max) then"' + print *,'test.' + stop + else + + if (icorr_factor_loop.eq.1) then + + i_len_wo = 80 - trailing_blanks(output_path_wo_assim) + open (401,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_2Dxy.gdat',& + & form='unformatted',access='direct',& + & recl=4*(4*nx*ny),status='replace') + open (402,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_snod.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (403,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_sden.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (404,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_swed.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (405,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_diam.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (406,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_flux.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (407,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_temp.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (408,& + & file=output_path_wo_assim(1:i_len_wo)//'multilayer_cond.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + + elseif (icorr_factor_loop.eq.2) then + + close (401) + close (402) + close (403) + close (404) + close (405) + close (406) + close (407) + close (408) + + i_len_wi = 80 - trailing_blanks(output_path_wi_assim) + open (401,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_2Dxy.gdat',& + & form='unformatted',access='direct',& + & recl=4*(4*nx*ny),status='replace') + open (402,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_snod.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (403,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_sden.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (404,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_swed.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (405,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_diam.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (406,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_flux.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (407,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_temp.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + open (408,& + & file=output_path_wi_assim(1:i_len_wi)//'multilayer_cond.gdat',& + & form='unformatted',access='direct',& + & recl=4*nx*ny*nz_max,status='replace') + + endif + endif + endif + +! Read in the precipitation correction factor array. + if (cf_precip_flag.eq.1.0) then + + open (unit=144,file='precip_cf/cf_precip.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + read (144,rec=1) ((cf_precip(i,j),i=1,nx),j=1,ny) + + elseif (cf_precip_flag.eq.2.0) then + +! Read off the header lines. I will assume that all of this +! information was input in the .par file correctly. + open (144,file='precip_cf/cf_precip.asc',form='formatted') + iheader = 6 + do k=1,iheader + read (144,*) + enddo +! Read the data in as real numbers, and do the yrev. + do j=ny,1,-1 + read (144,*) (cf_precip(i,j),i=1,nx) + enddo + + elseif (cf_precip_flag.eq.3.0) then + + open (144,file='precip_cf/cf_precip.dat',form='formatted') + read (144,*) cf_precip_scalar + do j=1,ny + do i=1,nx + cf_precip(i,j) = cf_precip_scalar + enddo + enddo + + endif + +! This must be closed so it can be reread if there is a (second) +! data assimilation loop. + close (144) + +! Generate all of the GrADS control (.ctl) files that correspond +! to all of the GrADS output (.gdat) files that were generated as +! part of this model run. They are (mostly) all placed in a +! directory called "ctl_files". + call mk_ctl_files(nx,ny,deltax,deltay,xmn,ymn,dt,& + & print_inc,iyear_init,imonth_init,iday_init,xhour_init,& + & max_iter,undef,output_path_wo_assim,output_path_wi_assim,& + & print_micromet,micromet_output_fname,print_enbal,& + & enbal_output_fname,print_snowpack,snowpack_output_fname,& + & print_snowtran,snowtran_output_fname,Tabler_1_flag,& + & tabler_sfc_path_name,Tabler_2_flag,irun_data_assim,& + & print_var,print_outvars,print_multilayer,& + & multilayer_output_fname) + +! If this is going to be a SnowTran-3D run, print the Copyright +! header. + if (run_snowtran.eq.1.0) then + print * + print *,& + & 'cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' + print *,& + & 'c Snow-Transport Modeling System - 3D (SnowTran-3D) c' + print *,& + & 'c Copyright (C) 1998 c' + print *,& + & 'c by Glen E. Liston, InterWorks Consulting c' + print *,& + & 'c All Rights Reserved c' + print *,& + & 'cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' + print * + print * + endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine initialize(nx,ny,sum_sprec,sum_qsubl,sum_trans,& + & sum_unload,topo,topo_land,snow_d,topoflag,snow_d_init,& + & snow_d_init_const,soft_snow_d,ro_water,sum_sfcsublim,& + & ro_snow_grid,swe_depth,sum_runoff,sum_prec,ro_snow,& + & sum_Qcs,canopy_int,sum_glacmelt,snow_depth,sum_d_canopy_int,& + & ro_soft_snow_old,sum_swemelt,swe_depth_old,canopy_int_old,& + & ihrestart_flag,i_dataassim_loop,max_iter,corr_factor,& + & icorr_factor_index,KK,tslsnowfall,tsls_threshold,snod_layer,& + & swed_layer,ro_layer,T_old,gamma,diam_layer) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,ihrestart_flag,i_dataassim_loop,max_iter,k + + real topoflag,snow_d_init_const,ro_water,ro_snow + real sum_sprec(nx,ny) + real sum_qsubl(nx,ny) + real sum_trans(nx,ny) + real sum_unload(nx,ny) + real topo(nx,ny) + real topo_land(nx,ny) + real snow_d(nx,ny) + real snow_depth(nx,ny) + real soft_snow_d(nx,ny) + real ro_soft_snow_old(nx,ny) + real ro_snow_grid(nx,ny) + real swe_depth(nx,ny) + real sum_prec(nx,ny) + real sum_runoff(nx,ny) + real sum_Qcs(nx,ny) + real canopy_int(nx,ny) + real sum_glacmelt(nx,ny) + real sum_swemelt(nx,ny) + real sum_d_canopy_int(nx,ny) + real sum_sfcsublim(nx,ny) + real snow_d_init(nx,ny) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + + integer KK(nx,ny) + real tslsnowfall(nx,ny) + real tsls_threshold + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real gamma(nx,ny,nz_max) + real diam_layer(nx,ny,nz_max) + + integer icorr_factor_index(max_time_steps) + real corr_factor(nx_max,ny_max,max_obs_dates+1) + + if (ihrestart_flag.ge.0) then + +! Read in the saved data. + CALL HRESTART_READ(nx,ny,snow_d,snow_depth,& + & canopy_int,soft_snow_d,ro_snow_grid,swe_depth,& + & ro_soft_snow_old,snow_d_init,swe_depth_old,& + & canopy_int_old,topo,sum_sprec,ihrestart_flag,& + & i_dataassim_loop) + + if (i_dataassim_loop.lt.0.0) then + CALL HRESTART_READ_DA(nx,ny,max_iter,corr_factor,& + & icorr_factor_index,i_dataassim_loop) + endif + + do i=1,nx + do j=1,ny +! Fill the summing arrays. + sum_runoff(i,j) = 0.0 + sum_prec(i,j) = 0.0 +! sum_sprec(i,j) = 0.0 + sum_qsubl(i,j) = 0.0 + sum_trans(i,j) = 0.0 + sum_unload(i,j) = 0.0 + sum_Qcs(i,j) = 0.0 + sum_glacmelt(i,j) = 0.0 + sum_swemelt(i,j) = 0.0 + sum_d_canopy_int(i,j) = 0.0 + sum_sfcsublim(i,j) = 0.0 + +! Define the initial snow-depth distributions. +! snow_d_init(i,j) = snow_d_init_const +! snow_d(i,j) = snow_d_init(i,j) +! snow_depth(i,j) = snow_d_init(i,j) +! canopy_int(i,j) = 0.0 +! soft_snow_d(i,j) = snow_d(i,j) +! ro_snow_grid(i,j) = ro_snow +! swe_depth(i,j) = snow_d(i,j) * ro_snow_grid(i,j) / ro_water +! ro_soft_snow_old(i,j) = 50.0 +! swe_depth_old(i,j) = swe_depth(i,j) +! canopy_int_old(i,j) = canopy_int(i,j) + enddo + enddo + + else + + do i=1,nx + do j=1,ny +! Fill the summing arrays. + sum_runoff(i,j) = 0.0 + sum_prec(i,j) = 0.0 + sum_sprec(i,j) = 0.0 + sum_qsubl(i,j) = 0.0 + sum_trans(i,j) = 0.0 + sum_unload(i,j) = 0.0 + sum_Qcs(i,j) = 0.0 + sum_glacmelt(i,j) = 0.0 + sum_swemelt(i,j) = 0.0 + sum_d_canopy_int(i,j) = 0.0 + sum_sfcsublim(i,j) = 0.0 + +! Define the initial snow-depth distributions. + snow_d_init(i,j) = snow_d_init_const + snow_d(i,j) = snow_d_init(i,j) + snow_depth(i,j) = snow_d_init(i,j) + canopy_int(i,j) = 0.0 + soft_snow_d(i,j) = snow_d(i,j) + ro_snow_grid(i,j) = ro_snow + swe_depth(i,j) = snow_d(i,j) * ro_snow_grid(i,j) / ro_water + ro_soft_snow_old(i,j) = 50.0 + swe_depth_old(i,j) = swe_depth(i,j) + canopy_int_old(i,j) = canopy_int(i,j) + +! Initialize the multi-layer snowpack arrays. + KK(i,j) = 0 + tslsnowfall(i,j) = tsls_threshold + enddo + enddo + + do i=1,nx + do j=1,ny + do k=1,nz_max + snod_layer(i,j,k) = 0.0 + swed_layer(i,j,k) = 0.0 + ro_layer(i,j,k) = ro_snow + T_old(i,j,k) = 273.15 + gamma(i,j,k) = 0.138 - 1.01 * (ro_layer(i,j,k)/1000.0) + & + & 3.233 * (ro_layer(i,j,k)/1000.0)**2 + diam_layer(i,j,k) = 0.5 / 1000.0 + enddo + enddo + enddo + + if (topoflag.eq.1.0) then + do i=1,nx + do j=1,ny + topo(i,j) = topo_land(i,j) + snow_d(i,j) + enddo + enddo + elseif (topoflag.eq.0.0) then + do i=1,nx + do j=1,ny + topo(i,j) = topo_land(i,j) + enddo + enddo + endif + + endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine constants(fetch,xmu,C_z,h_const,wind_min,Up_const,& + & dz_susp,ztop_susp,fall_vel,Ur_const,ro_water,ro_air,& + & gravity,vonKarman,pi,twopio360,snow_z0) + + implicit none + + real fetch,xmu,C_z,h_const,wind_min,Up_const,& + & dz_susp,ztop_susp,fall_vel,Ur_const,ro_water,ro_air,& + & gravity,vonKarman,pi,twopio360,snow_z0 + +! These constants are not generally modified for a particular model +! run. + +! Snow surface roughness length. + snow_z0 = 0.001 + +! Constants related to surface shear stress and saltation +! transport. + fetch = 500.0 + xmu = 3.0 + C_z = 0.12 + h_const = 1.6 + wind_min = 4.0 + +! Constants related to suspended snow profile. + Up_const = 2.8 + dz_susp = 0.20 + ztop_susp = 2.0 + fall_vel = 0.3 + Ur_const = 0.5 + +! General constants. + ro_water = 1000.0 + ro_air = 1.275 + gravity = 9.81 + vonKarman = 0.4 + pi = 2.0 * acos(0.0) + twopio360 = 2.0 * pi / 360.0 + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine fill_veg_shd(nvegtypes,vegsnowdepth) + + implicit none + + integer k,nvegtypes,nvegtypes_fixed + + parameter (nvegtypes_fixed=24) + + real vegsnowdepth(nvegtypes),vegsnowdepth_fixed(nvegtypes_fixed) + +! Fill the the vegetation snow-holding depth array for +! vegetation types 1 through 24 (types 25 through 30 were filled +! from the .par file. +! +! The following summary was taken from the .par file. +! +! The vegetation types are assumed to range from 1 through 30. The +! last 6 types are available to be user-defined vegetation types +! and vegetation snow-holding depth. The first 24 vegetation +! types, and the associated vegetation snow-holding depth +! (meters), are hard-coded to be: +! +! code description veg_shd example class +! +! 1 coniferous forest 15.00 spruce-fir/taiga/lodgepole forest +! 2 deciduous forest 12.00 aspen forest forest +! 3 mixed forest 14.00 aspen/spruce-fir/low taiga forest +! 4 scattered short-conifer 8.00 pinyon-juniper forest +! 5 clearcut conifer 4.00 stumps and regenerating forest +! +! 6 mesic upland shrub 0.50 deeper soils, less rocky shrub +! 7 xeric upland shrub 0.25 rocky, windblown soils shrub +! 8 playa shrubland 1.00 greasewood, saltbush shrub +! 9 shrub wetland/riparian 1.75 willow along streams shrub +! 10 erect shrub tundra 0.65 arctic shrubland shrub +! 11 low shrub tundra 0.30 low to medium arctic shrubs shrub +! +! 12 grassland rangeland 0.15 graminoids and forbs grass +! 13 subalpine meadow 0.25 meadows below treeline grass +! 14 tundra (non-tussock) 0.15 alpine, high arctic grass +! 15 tundra (tussock) 0.20 graminoid and dwarf shrubs grass +! 16 prostrate shrub tundra 0.10 graminoid dominated grass +! 17 arctic gram. wetland 0.20 grassy wetlands, wet tundra grass +! +! 18 bare 0.01 bare +! +! 19 water/possibly frozen 0.01 water +! 20 permanent snow/glacier 0.01 water +! +! 21 residential/urban 0.01 human +! 22 tall crops 0.40 e.g., corn stubble human +! 23 short crops 0.25 e.g., wheat stubble human +! 24 ocean 0.01 water +! +! 25 user defined (see below) +! 26 user defined (see below) +! 27 user defined (see below) +! 28 user defined (see below) +! 29 user defined (see below) +! 30 user defined (see below) +! +! Define the vegetation snow-holding depth (meters) for each +! of the user-defined vegetation types. The numbers in the +! list below correspond to the vegetation-type numbers in the +! vegetation-type data array (veg type 25.0 -> veg_shd_25). Note +! that even if these are not used, they cannot be commented out +! or you will get an error message. +! veg_shd_25 = 0.10 +! veg_shd_26 = 0.10 +! veg_shd_27 = 0.10 +! veg_shd_28 = 0.10 +! veg_shd_29 = 0.10 +! veg_shd_30 = 0.10 + + data vegsnowdepth_fixed/15.00, 12.00, 14.00, 8.00, 4.00, & + & 0.50, 0.25, 1.00, 1.75, 0.65, 0.30,& + & 0.15, 0.25, 0.15, 0.20, 0.10, 0.20,& + & 0.01, 0.01, 0.01, 0.01, 0.40, 0.25,& + & 0.01/ + + do k=1,nvegtypes_fixed + vegsnowdepth(k) = vegsnowdepth_fixed(k) + enddo + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine met_data_check(undef,isingle_stn_flag,igrads_metfile,& + & max_iter,i_tair_flag,i_rh_flag,i_wind_flag,i_prec_flag) + + use snowmodel_inc + implicit none + + integer iyr,imo,idy ! year, month, and day of data + real xhr ! decimal hour + integer idstn ! station id number + + integer k,nstns_orig,isingle_stn_flag,igrads_metfile,iter,& + & n_good_Tair,n_good_rh,n_good_wspd,n_good_wdir,n_good_prec,& + & n_notgood_vars,i_tair_flag,i_rh_flag,i_wind_flag,i_prec_flag,& + & max_iter + + real Tair_orig(nstns_max),rh_orig(nstns_max) + real winddir_orig(nstns_max),windspd_orig(nstns_max) + double precision xstn_orig(nstns_max),ystn_orig(nstns_max) + real elev_orig(nstns_max),prec_orig(nstns_max) + real undef ! undefined value + real elevation_flag + + n_notgood_vars = 0 + elevation_flag = 0.0 + + do iter=1,max_iter + + n_good_Tair = 0 + n_good_rh = 0 + n_good_wspd = 0 + n_good_wdir = 0 + n_good_prec = 0 + + if (igrads_metfile.eq.1) then + nstns_orig = 1 + else + if (isingle_stn_flag.eq.1) then + nstns_orig = 1 + else + read(20,*) nstns_orig + endif + endif + + if (nstns_orig.gt.nstns_max) then + print *, 'The number of met stations in your MicroMet' + print *, 'input file exceeds nstns_max in snowmodel.inc.' + print *, 'This occurs at iter =',iter + stop + endif + + do k=1,nstns_orig + + if (igrads_metfile.eq.1) then + read(20,rec=iter) iyr,imo,idy,xhr,idstn,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),Tair_orig(k),rh_orig(k),& + & windspd_orig(k),winddir_orig(k),prec_orig(k) + else + read(20,*) iyr,imo,idy,xhr,idstn,xstn_orig(k),& + & ystn_orig(k),elev_orig(k),Tair_orig(k),rh_orig(k),& + & windspd_orig(k),winddir_orig(k),prec_orig(k) + endif + +! Check for any NaN values. They are not allowed. + if (Tair_orig(k).ne.Tair_orig(k) .or.& + & rh_orig(k).ne.rh_orig(k) .or.& + & windspd_orig(k).ne.windspd_orig(k) .or.& + & winddir_orig(k).ne.winddir_orig(k) .or.& + & prec_orig(k).ne.prec_orig(k)) then + print * + print *,' YOU HAVE NaN VALUES IN YOUR MET FORCING INPUT' + print *,' FILE. THEY ARE NOT ALLOWED ANYWHERE IN THE' + print *,' MicroMet INPUT FILE. THIS MUST BE CORRECTED' + print *,' BEFORE YOU CAN CONTINUE.' + print * + stop + endif + +! Count the good values at this time. + if (Tair_orig(k).ne.undef) n_good_Tair = n_good_Tair + 1 + if (rh_orig(k).ne.undef) n_good_rh = n_good_rh + 1 + if (windspd_orig(k).ne.undef) n_good_wspd = n_good_wspd + 1 + if (winddir_orig(k).ne.undef) n_good_wdir = n_good_wdir + 1 + if (prec_orig(k).ne.undef) n_good_prec = n_good_prec + 1 + + if (elev_orig(k).lt.0.0) then + elevation_flag = 1.0 + print *,'elevation = ',elev_orig(k),' for stn id = ',idstn + endif + + enddo + +! Check to see whether there are any variables with no valid data +! at this time slice. + if (n_good_Tair.eq.0 .and. i_tair_flag.eq.1) then + n_notgood_vars = n_notgood_vars + 1 + print *,'no good Tair data at ',iyr,imo,idy,xhr + endif + + if (n_good_rh.eq.0 .and. i_rh_flag.eq.1) then + n_notgood_vars = n_notgood_vars + 1 + print *,'no good rh data at ',iyr,imo,idy,xhr + endif + + if (n_good_wspd.eq.0 .and. i_wind_flag.eq.1) then + n_notgood_vars = n_notgood_vars + 1 + print *,'no good wind speed data at ',iyr,imo,idy,xhr + endif + + if (n_good_wdir.eq.0 .and. i_wind_flag.eq.1) then + n_notgood_vars = n_notgood_vars + 1 + print *,'no good wind direction data at ',iyr,imo,idy,xhr + endif + + if (n_good_prec.eq.0 .and. i_prec_flag.eq.1) then + n_notgood_vars = n_notgood_vars + 1 + print *,'no good precipitation data at ',iyr,imo,idy,xhr + endif + + enddo + + if (n_notgood_vars.gt.0) then + print * + print *,' FOUND TIMES WITH NO VALID MET OBSERVATIONS' + print *,'NEED TO CORRECT THE PROBLEM BEFORE CONTINUING' + stop + endif + + if (elevation_flag.eq.1.0) then + print * + print *,' FOUND A NEGATIVE OR UNDEFINED STATION ELEVATION.' + print *,'STATION ELEVATIONS CANNOT BE UNDEFINED, BUT THEY.' + print *,'CAN BE NEGATIVE FOR A PLACE LIKE DEATH VALLEY.' + print *,'YOU NEED TO CORRECT ANY PROBLEMS BEFORE CONTINUING.' + stop + endif + + if (igrads_metfile.eq.0) rewind (20) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_nearest_stns_1(nx,ny,xmn,ymn,deltax,deltay,& + & n_stns_used,k_stn,snowmodel_line_flag,xg_line,yg_line) + + use snowmodel_inc + implicit none + + double precision xstn(nstns_max) + double precision ystn(nstns_max) + double precision dsq(nstns_max) + double precision xg_line(nx,ny),yg_line(nx,ny) + real snowmodel_line_flag + + double precision xg,yg,xmn,ymn,dist_min + real deltax,deltay,x1,x2,x3,x4,x5,x6,x7 + + integer i,j,k,kk,nstns,n_stns_used,nx,ny,i1,i2,i3,i4 + integer k_stn(nx,ny,9) + +! Read the station information for the first (and all) time step(s). + read(20,*) nstns + do k=1,nstns + read(20,*) i1,i2,i3,x1,i4,xstn(k),ystn(k),& + & x2,x3,x4,x5,x6,x7 + enddo + rewind (20) + + do j=1,ny + do i=1,nx + +! xcoords of grid nodes at index i,j +! ycoords of grid nodes at index i,j + if (snowmodel_line_flag.eq.1.0) then + xg = xg_line(i,j) + yg = yg_line(i,j) + else + xg = xmn + deltax * (real(i) - 1.0) + yg = ymn + deltay * (real(j) - 1.0) + endif + +! Loop through all of the stations, calculating the distance +! between the current grid point and each of the stations. + do k=1,nstns + dsq(k) = (xg - xstn(k))**2 + (yg - ystn(k))**2 + enddo + +! Loop through each of the station distances and find the +! stations closest to the grid point in question. + do kk=1,n_stns_used + dist_min = 1.0e30 + do k=1,nstns + if (dsq(k).le.dist_min) then + k_stn(i,j,kk) = k + dist_min = dsq(k) + endif + enddo + +! Eliminate the last found minimum from the next search by making +! its distance a big number. + dsq(k_stn(i,j,kk)) = 1.0e30 + enddo + + enddo + enddo + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine HRESTART_SAVE(nx,ny,iter,snow_d,snow_depth,& + & canopy_int,soft_snow_d,ro_snow_grid,swe_depth,& + & ro_soft_snow_old,snow_d_init,swe_depth_old,& + & canopy_int_old,topo,sum_sprec,icorr_factor_loop,& + & max_iter) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,iter,icorr_factor_loop,max_iter + real snow_d(nx,ny) + real snow_depth(nx,ny) + real canopy_int(nx,ny) + real soft_snow_d(nx,ny) + real ro_snow_grid(nx,ny) + real swe_depth(nx,ny) + real ro_soft_snow_old(nx,ny) + real snow_d_init(nx,ny) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real topo(nx,ny) + real sum_sprec(nx,ny) + + character*18 name1 + character*1 name2 + character*5 name3 + character*5 niter + character*1 iloop + character*30 fname + +! Build the file name so it includes the interation number. + name1 = 'hrestart/hrestart_' + name2 = '_' + name3 = '.gdat' + + write(niter,'(i5.5)') iter + write(iloop,'(i1.1)') icorr_factor_loop + fname = name1//niter//name2//iloop//name3 + +! Save the data. + open(151,file=fname,& + & form='unformatted',access='direct',recl=4*nx*ny) + + write (151,rec=1) ((snow_d(i,j),i=1,nx),j=1,ny) + write (151,rec=2) ((snow_depth(i,j),i=1,nx),j=1,ny) + write (151,rec=3) ((canopy_int(i,j),i=1,nx),j=1,ny) + write (151,rec=4) ((soft_snow_d(i,j),i=1,nx),j=1,ny) + write (151,rec=5) ((ro_snow_grid(i,j),i=1,nx),j=1,ny) + write (151,rec=6) ((swe_depth(i,j),i=1,nx),j=1,ny) + write (151,rec=7) ((ro_soft_snow_old(i,j),i=1,nx),j=1,ny) + write (151,rec=8) ((snow_d_init(i,j),i=1,nx),j=1,ny) + write (151,rec=9) ((swe_depth_old(i,j),i=1,nx),j=1,ny) + write (151,rec=10) ((canopy_int_old(i,j),i=1,nx),j=1,ny) + write (151,rec=11) ((topo(i,j),i=1,nx),j=1,ny) + write (151,rec=12) ((sum_sprec(i,j),i=1,nx),j=1,ny) + + close (151) + +! Save a copy that can be used as the initial condition for the +! start of the second data assimilation loop. + if (iter.eq.max_iter) then + write(niter,'(i5.5)') 0 + write(iloop,'(i1.1)') 2 + fname = name1//niter//name2//iloop//name3 + +! Save the data. + open(151,file=fname,& + & form='unformatted',access='direct',recl=4*nx*ny) + + write (151,rec=1) ((snow_d(i,j),i=1,nx),j=1,ny) + write (151,rec=2) ((snow_depth(i,j),i=1,nx),j=1,ny) + write (151,rec=3) ((canopy_int(i,j),i=1,nx),j=1,ny) + write (151,rec=4) ((soft_snow_d(i,j),i=1,nx),j=1,ny) + write (151,rec=5) ((ro_snow_grid(i,j),i=1,nx),j=1,ny) + write (151,rec=6) ((swe_depth(i,j),i=1,nx),j=1,ny) + write (151,rec=7) ((ro_soft_snow_old(i,j),i=1,nx),j=1,ny) + write (151,rec=8) ((snow_d_init(i,j),i=1,nx),j=1,ny) + write (151,rec=9) ((swe_depth_old(i,j),i=1,nx),j=1,ny) + write (151,rec=10) ((canopy_int_old(i,j),i=1,nx),j=1,ny) + write (151,rec=11) ((topo(i,j),i=1,nx),j=1,ny) + write (151,rec=12) ((sum_sprec(i,j),i=1,nx),j=1,ny) + + close (151) + endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine HRESTART_SAVE_DA(nx,ny,max_iter,corr_factor,& + & icorr_factor_index,nobs_dates) + + use snowmodel_inc + implicit none + + integer iobs_num,nobs_dates,nx,ny,i,j,max_iter,iter + integer icorr_factor_index(max_time_steps) + real corr_factor(nx_max,ny_max,max_obs_dates+1) + + +! Save the correction factors for each observation date. + open(152,file='hrestart/hrestart_corr_factor.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + + do iobs_num=1,nobs_dates+1 + write(152,rec=iobs_num)& + & ((corr_factor(i,j,iobs_num),i=1,nx),j=1,ny) + enddo + + close (152) + +! Save the correction factor index. + open(153,file='hrestart/hrestart_corr_factor_index.dat') + + do iter=1,max_iter + write (153,*) iter,icorr_factor_index(iter) + enddo + + close (153) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine HRESTART_READ(nx,ny,snow_d,snow_depth,& + & canopy_int,soft_snow_d,ro_snow_grid,swe_depth,& + & ro_soft_snow_old,snow_d_init,swe_depth_old,& + & canopy_int_old,topo,sum_sprec,ihrestart_flag,& + & i_dataassim_loop) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,ihrestart_flag,i_dataassim_loop,& + & i_dataassim_loop_tmp + real snow_d(nx,ny) + real snow_depth(nx,ny) + real canopy_int(nx,ny) + real soft_snow_d(nx,ny) + real ro_snow_grid(nx,ny) + real swe_depth(nx,ny) + real ro_soft_snow_old(nx,ny) + real snow_d_init(nx,ny) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real topo(nx,ny) + real sum_sprec(nx,ny) + + character*18 name1 + character*1 name2 + character*5 name3 + character*5 niter + character*1 iloop + character*30 fname + +! Build the file name so it includes the interation number. + name1 = 'hrestart/hrestart_' + name2 = '_' + name3 = '.gdat' + + if (i_dataassim_loop.lt.0.0) then + i_dataassim_loop_tmp = 2 + else + i_dataassim_loop_tmp = 1 + endif + + write(niter,'(i5.5)') ihrestart_flag + write(iloop,'(i1.1)') i_dataassim_loop_tmp + fname = name1//niter//name2//iloop//name3 + +! Save the data. + open(152,file=fname,& + & form='unformatted',access='direct',recl=4*nx*ny) + + read (152,rec=1) ((snow_d(i,j),i=1,nx),j=1,ny) + read (152,rec=2) ((snow_depth(i,j),i=1,nx),j=1,ny) + read (152,rec=3) ((canopy_int(i,j),i=1,nx),j=1,ny) + read (152,rec=4) ((soft_snow_d(i,j),i=1,nx),j=1,ny) + read (152,rec=5) ((ro_snow_grid(i,j),i=1,nx),j=1,ny) + read (152,rec=6) ((swe_depth(i,j),i=1,nx),j=1,ny) + read (152,rec=7) ((ro_soft_snow_old(i,j),i=1,nx),j=1,ny) + read (152,rec=8) ((snow_d_init(i,j),i=1,nx),j=1,ny) + read (152,rec=9) ((swe_depth_old(i,j),i=1,nx),j=1,ny) + read (152,rec=10) ((canopy_int_old(i,j),i=1,nx),j=1,ny) + read (152,rec=11) ((topo(i,j),i=1,nx),j=1,ny) + read (152,rec=12) ((sum_sprec(i,j),i=1,nx),j=1,ny) + + close (152) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine HRESTART_READ_DA(nx,ny,max_iter,corr_factor,& + & icorr_factor_index,i_dataassim_loop) + + use snowmodel_inc + implicit none + + integer iobs_num,nobs_dates,nx,ny,i,j,max_iter,iter,dummy,& + & i_dataassim_loop + integer icorr_factor_index(max_time_steps) + real corr_factor(nx_max,ny_max,max_obs_dates+1) + +! Read the correction factors for each observation date. + open(152,file='hrestart/hrestart_corr_factor.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + + if (i_dataassim_loop.lt.0.0) nobs_dates = - i_dataassim_loop + + do iobs_num=1,nobs_dates+1 + read(152,rec=iobs_num)& + & ((corr_factor(i,j,iobs_num),i=1,nx),j=1,ny) + enddo + + close (152) + +! Read the correction factor index. + open(153,file='hrestart/hrestart_corr_factor_index.dat') + + do iter=1,max_iter + read (153,*) dummy,icorr_factor_index(iter) + enddo + + close (153) + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_ctl_files(nx,ny,deltax,deltay,xmn,ymn,dt,& + & print_inc,iyear_init,imonth_init,iday_init,xhour_init,& + & max_iter,undef,output_path_wo_assim,output_path_wi_assim,& + & print_micromet,micromet_output_fname,print_enbal,& + & enbal_output_fname,print_snowpack,snowpack_output_fname,& + & print_snowtran,snowtran_output_fname,Tabler_1_flag,& + & tabler_sfc_path_name,Tabler_2_flag,irun_data_assim,& + & print_var,print_outvars,print_multilayer,& + & multilayer_output_fname) + + use snowmodel_inc + implicit none + + real deltax,deltay,dt,print_inc,xhour_init,print_micromet,& + & print_enbal,print_snowpack,print_snowtran,Tabler_1_flag,& + & Tabler_2_flag,undef,print_multilayer + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & irun_data_assim,k,kk + + double precision xmn,ymn + + character*1 print_var(n_print_vars) + + character*80 micromet_output_fname + character*80 enbal_output_fname + character*80 snowpack_output_fname + character*80 snowtran_output_fname + character*80 multilayer_output_fname + character*80 tabler_sfc_path_name + character*80 output_path + character*80 output_path_wo_assim,output_path_wi_assim + + character*4 print_outvars(n_print_vars) + character*80 description(n_print_vars) + +! This is done below to avoid some array definition conflict (you +! cannot use the "data" statement like this when the array is +! being passed in and out of differet subroutines. +! data print_outvars /'tair','relh','wspd','qsin','qlin', +! & 'qlem','albd','wdir','prec','rpre', +! & 'spre','smlt','ssub','roff','glmt', +! & 'snod','sden','swed','sspr','ssmt', +! & 'cldf','var1','var2','var3','var4', +! & 'var5','var6','var7','var8','var9'/ + + data description / & + & 'tair 0 0 air temperature (deg C)',& + & 'relh 0 0 relative humidity (%)',& + & 'wspd 0 0 wind speed (m/s)',& + & 'qsin 0 0 incoming solar rad at the surface (W/m2)',& + & 'qlin 0 0 incoming longwave rad at the surface (W/m2)',& + + & 'qlem 0 0 emitted longwave radiation (W/m2)',& + & 'albd 0 0 albedo (0-1)',& + & 'wdir 0 0 wind direction (0-360, true N)',& + & 'prec 0 0 water-equivalent precipitation (m/time_step)',& + & 'rpre 0 0 liquid precipitation, rain (m/time_step)',& + + & 'spre 0 0 solid precipitation, snowfall (m/time_step)',& + & 'smlt 0 0 snow-water-equivalent melt (m)',& + & 'ssub 0 0 static-surface sublimation (m)',& + & 'roff 0 0 runoff from snowpack base (m/time_step)',& + & 'glmt 0 0 snow-water-equivalent melt from glacier ice (m)',& + + & 'snod 0 0 snow depth (m)',& + & 'sden 0 0 snow density (kg/m3)',& + & 'swed 0 0 snow-water-equivalent depth (m)',& + & 'sspr 0 0 summed snow precip during year (m)',& + & 'ssmt 0 0 summed snow-water-equivalent melt (m)',& + + & 'cldf 0 0 cloud fraction (0-1)',& + & 'var1 0 0 to be defined in future applications',& + & 'var2 0 0 to be defined in future applications',& + & 'var3 0 0 to be defined in future applications',& + & 'var4 0 0 to be defined in future applications',& + + & 'var5 0 0 to be defined in future applications',& + & 'var6 0 0 to be defined in future applications',& + & 'var7 0 0 to be defined in future applications',& + & 'var8 0 0 to be defined in future applications',& + & 'var9 0 0 to be defined in future applications'/ + + character*14 den_outvars(3) + character*80 den_description(3) + + data den_outvars / & + & 'dden_den_assim','sden_den_assim','snod_den_assim'/ + + data den_description / & + & 'dden 0 0 assimilated snow density difference (kg/m^3)',& + & 'sden 0 0 snow density after the assimilation (kg/m^3)',& + & 'snod 0 0 snow depth with assimilated snow density (m)'/ + + print_outvars(1) = 'tair' + print_outvars(2) = 'relh' + print_outvars(3) = 'wspd' + print_outvars(4) = 'qsin' + print_outvars(5) = 'qlin' + print_outvars(6) = 'qlem' + print_outvars(7) = 'albd' + print_outvars(8) = 'wdir' + print_outvars(9) = 'prec' + print_outvars(10) = 'rpre' + print_outvars(11) = 'spre' + print_outvars(12) = 'smlt' + print_outvars(13) = 'ssub' + print_outvars(14) = 'roff' + print_outvars(15) = 'glmt' + print_outvars(16) = 'snod' + print_outvars(17) = 'sden' + print_outvars(18) = 'swed' + print_outvars(19) = 'sspr' + print_outvars(20) = 'ssmt' + print_outvars(21) = 'cldf' + print_outvars(22) = 'var1' + print_outvars(23) = 'var2' + print_outvars(24) = 'var3' + print_outvars(25) = 'var4' + print_outvars(26) = 'var5' + print_outvars(27) = 'var6' + print_outvars(28) = 'var7' + print_outvars(29) = 'var8' + print_outvars(30) = 'var9' + +! Create the GrADS .ctl (control) files to go with the GrADS +! .gdat output files that were generated by this model run. + if (print_micromet.eq.1.0) then + call mk_micromet_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,micromet_output_fname) + endif + + if (print_enbal.eq.1.0) then + call mk_enbal_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,enbal_output_fname) + endif + + if (print_snowpack.eq.1.0) then + call mk_snowpack_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,snowpack_output_fname) + endif + + if (print_snowtran.eq.1.0) then + call mk_snowtran_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,snowtran_output_fname) + endif + + if (Tabler_1_flag.eq.1.0) then + call mk_tabler_1_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & undef,tabler_sfc_path_name) + endif + + if (print_multilayer.eq.1.0) then + call mk_multilayer_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,multilayer_output_fname) + endif + +! If you are not doing data assimilation, then you just need .ctl +! files for the wo_assim directory. If you are also doing the +! data assimilation, then you also need .ctl files for the .gdat +! data files that are in the wi_assim directory. + do k=1,irun_data_assim+1 + if (k.eq.1) then + output_path = output_path_wo_assim + elseif (k.eq.2) then + output_path = output_path_wi_assim + endif + + if (Tabler_2_flag.eq.1.0) then + call mk_tabler_2_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k,print_inc) + endif + + do kk=1,n_print_vars + if (print_var(kk).eq.'y') then + call mk_4char_vars_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k,print_outvars(kk),description(kk),& + & print_inc) + endif + enddo + + if (print_multilayer.eq.2.0) then + call mk_multilayer_2Dxy_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + call mk_multilayer_snod_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_sden_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_swed_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_diam_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_flux_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_temp_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + call mk_multilayer_cond_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + endif + + enddo + +! if (irun_density_assim.eq.1) then +! call mk_density_assim_sfc_ctl(nx,ny,deltax,deltay,xmn,ymn, +! & undef,den_outvars(1),den_description(1)) +! do kk=2,3 +! call mk_density_assim_ctl(nx,ny,deltax,deltay,xmn,ymn, +! & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter, +! & undef,output_path_wi_assim,print_inc,den_outvars(kk), +! & den_description(kk)) +! enddo +! endif + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_density_assim_sfc_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & undef,den_outvars,den_description) + + implicit none + + integer nx,ny,igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,undef + + integer len_name,len_path,len_desc,trailing_blanks + + character*80 output_fname,filename,den_description + character*80 output_path_tmp + character*14 den_outvars + character*3 cmo + character*2 cdt + + data cmo /'jan'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + + igrads_dt = 1 + cdt = 'yr' + + filename = 'data/'//den_outvars//'.ctl' + + output_path_tmp = '^' + + len_path = 80 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//den_outvars//'.gdat' + len_name = 80 - trailing_blanks(output_fname) + len_desc = 80 - trailing_blanks(den_description) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) 1,12,1,cmo,9999,igrads_dt,cdt + write (71,58) + write (71,59) den_description(1:len_desc) + write (71,60) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE SnowModel Density Assimilation correction file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 59 format (a) + 60 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_density_assim_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,print_inc,den_outvars,& + & den_description) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef,& + & print_inc + + integer len_name,len_path,len_desc,trailing_blanks + + character*105 output_fname + character*80 filename,den_description + character*80 output_path + character*86 output_path_tmp + character*14 den_outvars + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert the write interval from seconds to hours or a day. + if (dt*print_inc.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt*print_inc.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt*print_inc.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'This mk_ctl program has not been set up to deal' + print *, 'with this combination of dt and print_inc values:' + print *, 'dt =',dt,' print_inc =',print_inc + stop + endif + + filename = 'ctl_files/wi_assim/'//den_outvars//'.ctl' + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//den_outvars//'.gdat' + len_name = 105 - trailing_blanks(output_fname) + len_desc = 80 - trailing_blanks(den_description) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) den_description(1:len_desc) + write (71,60) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE SnowModel Density Assimilation output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 59 format (a) + 60 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_4char_vars_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k,print_outvars,description,& + & print_inc) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef,& + & print_inc + + integer len_name,len_path,len_desc,trailing_blanks + + character*95 output_fname + character*80 filename,description + character*80 output_path + character*86 output_path_tmp + character*4 print_outvars + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert the write interval from seconds to hours or a day. + if (dt*print_inc.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt*print_inc.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt*print_inc.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'This mk_ctl program has not been set up to deal' + print *, 'with this combination of dt and print_inc values:' + print *, 'dt =',dt,' print_inc =',print_inc + stop + endif + + if (k.eq.1) then + filename = 'ctl_files/wo_assim/'//print_outvars//'.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/'//print_outvars//'.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//print_outvars//'.gdat' + len_name = 95 - trailing_blanks(output_fname) + len_desc = 80 - trailing_blanks(description) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) int(real(max_iter)/print_inc),nint(xhour_init),& + & iday_init,cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) description(1:len_desc) + write (71,60) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE SnowModel single-variable output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 59 format (a) + 60 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_micromet_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_fname) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*80 output_fname,filename + character*83 output_fname_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + + filename = 'ctl_files/micromet.ctl' + +! Deal with the case with relative paths. + if (output_fname(1:1).ne.'/') then + output_fname_tmp = '../'//output_fname + else + output_fname_tmp = output_fname//' ' + endif + + len_name = 83 - trailing_blanks(output_fname_tmp) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname_tmp(1:len_name) + else + write (71,51) output_fname_tmp(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) + write (71,64) + write (71,65) + write (71,66) + write (71,67) + write (71,68) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE MicroMet output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 9') + 59 format ('tair 0 0 air temperature (deg C)') + 60 format ('relh 0 0 relative humidity (%)') + 61 format ('uwnd 0 0 meridional wind component (m/s)') + 62 format ('vwnd 0 0 zonal wind component (m/s)') + 63 format ('wspd 0 0 wind speed (m/s)') + 64 format ('wdir 0 0 wind direction (0-360, true N)') + 65 format ('qsin 0 0 incoming solar rad at the surface (W/m2)') + 66 format ('qlin 0 0 incoming longwave rad at the surface (W/m2)') + 67 format ('prec 0 0 precipitation (m/time_step)') + 68 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_enbal_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_fname) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*80 output_fname,filename + character*83 output_fname_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + + filename = 'ctl_files/enbal.ctl' + +! Deal with the case with relative paths. + if (output_fname(1:1).ne.'/') then + output_fname_tmp = '../'//output_fname + else + output_fname_tmp = output_fname//' ' + endif + + len_name = 83 - trailing_blanks(output_fname_tmp) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname_tmp(1:len_name) + else + write (71,51) output_fname_tmp(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) + write (71,64) + write (71,65) + write (71,66) + write (71,67) + write (71,68) + write (71,69) + write (71,70) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE EnBal output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 11') + 59 format ('tair 0 0 air temperature (deg C)') + 60 format ('tsfc 0 0 surface (skin) temperature (deg C)') + 61 format ('qsin 0 0 incoming solar rad at the surface (W/m2)') + 62 format ('qlin 0 0 incoming longwave rad at the surface (W/m2)') + 63 format ('qlem 0 0 emitted longwave radiation (W/m2)') + 64 format ('qh 0 0 sensible heat flux (W/m2)') + 65 format ('qe 0 0 latent heat flux (W/m2)') + 66 format ('qc 0 0 conductive heat flux (W/m2)') + 67 format ('qm 0 0 melt energy flux (W/m2)') + 68 format ('albd 0 0 albedo (0-1)') + 69 format ('ebal 0 0 energy balance error (W/m2)') + 70 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_snowpack_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_fname) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*80 output_fname,filename + character*83 output_fname_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + + filename = 'ctl_files/snowpack.ctl' + +! Deal with the case with relative paths. + if (output_fname(1:1).ne.'/') then + output_fname_tmp = '../'//output_fname + else + output_fname_tmp = output_fname//' ' + endif + + len_name = 83 - trailing_blanks(output_fname_tmp) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname_tmp(1:len_name) + else + write (71,51) output_fname_tmp(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) + write (71,64) + write (71,65) + write (71,66) + write (71,67) + write (71,68) + write (71,69) + write (71,70) + write (71,71) + write (71,72) + write (71,73) + write (71,74) + write (71,75) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE SnowPack output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 16') + 59 format ('snod 0 0 snow depth (m)') + 60 format ('sden 0 0 snow density (kg/m3)') + 61 format ('swed 0 0 snow-water-equivalent depth (m)') + 62 format ('roff 0 0 runoff from snowpack base (m/time_step)') + 63 format ('rain 0 0 liquid precipitation (m/time_step)') + 64 format ('spre 0 0 solid precipitation (m/time_step)') + 65 format ('qcs 0 0 canopy sublimation (m/time_step)') + 66 format ('canopy 0 0 canopy interception store (m)') + 67 format ('sumqcs 0 0 summed canopy sublim during year (m)') + 68 format ('sumprec 0 0 summed precipitation during year (m)') + 69 format ('sumsprec 0 0 summed snow precip during year (m)') + 70 format ('sumunload 0 0 summed canopy unloading during year (m)') + 71 format ('sumroff 0 0 summed runoff during the year (m)') + 72 format ('sumswemelt 0 0 summed snow-water-equivalent melt (m)') + 73 format ('sumsublim 0 0 summed static-surface sublimation (m)') + 74 format ('wbal 0 0 summed water bal error during year (m)') + 75 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_snowtran_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_fname) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*80 output_fname,filename + character*83 output_fname_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + + filename = 'ctl_files/snowtran.ctl' + +! Deal with the case with relative paths. + if (output_fname(1:1).ne.'/') then + output_fname_tmp = '../'//output_fname + else + output_fname_tmp = output_fname//' ' + endif + + len_name = 83 - trailing_blanks(output_fname_tmp) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname_tmp(1:len_name) + else + write (71,51) output_fname_tmp(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) + write (71,64) + write (71,65) + write (71,66) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE SnowTran output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 7') + 59 format ('snod 0 0 snow depth (m)') + 60 format ('subl 0 0 sublimation at this time step (m)') + 61 format ('salt 0 0 saltation transport at this time step (m)') + 62 format ('susp 0 0 suspended transport at this time step (m)') + 63 format ('subgrid 0 0 tabler snow redist at this time step (m)') + 64 format ('sumsubl 0 0 summed sublimation during the year (m)') + 65 format ('sumtran 0 0 summed blowing-snow transport for year (m)') + 66 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_tabler_1_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & undef,output_path) + + implicit none + + integer nx,ny,igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,undef + + integer len_name,len_path,trailing_blanks + + character*99 output_fname + character*80 filename + character*80 output_path + character*83 output_path_tmp + character*3 cmo + character*2 cdt + + data cmo /'jan'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + + igrads_dt = 1 + cdt = 'yr' + + filename = 'ctl_files/tabler_sfcs.ctl' + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 83 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'tabler_sfcs.gdat' + len_name = 99 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) 1,12,1,cmo,9999,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) + write (71,64) + write (71,65) + write (71,66) + write (71,67) + write (71,68) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Tabler Equilibrium Surfaces for snow-free land') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 9') + 59 format ('nn 0 0 tabler surface from north winds (m)') + 60 format ('ne 0 0 tabler surface from northeast winds (m)') + 61 format ('ee 0 0 tabler surface from east winds (m)') + 62 format ('se 0 0 tabler surface from southeast winds (m)') + 63 format ('ss 0 0 tabler surface from south winds (m)') + 64 format ('sw 0 0 tabler surface from southwest winds (m)') + 65 format ('ww 0 0 tabler surface from west winds (m)') + 66 format ('nw 0 0 tabler surface from northwest winds (m)') + 67 format ('topo 0 0 topography (m)') + 68 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_tabler_2_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k,print_inc) + + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef,& + & print_inc + + integer len_name,len_path,trailing_blanks + + character*97 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert the write interval from seconds to hours or a day. + if (dt*print_inc.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt*print_inc.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt*print_inc.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'This mk_ctl program has not been set up to deal' + print *, 'with this combination of dt and print_inc values:' + print *, 'dt =',dt,' print_inc =',print_inc + stop + endif + + if (k.eq.1) then + filename = 'ctl_files/wo_assim/tabler_sfc_iter.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/tabler_sfc_iter.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname=output_path_tmp(1:len_path)//'tabler_sfcs_iter.gdat' + len_name = 97 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Tabler Equilibrium Surface output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF 1 LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 59 format ('tablersfc 0 0 Tabler equilibrium surface (m)') + 60 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_ctl(nx,ny,deltax,deltay,xmn,ymn,dt,& + & iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_fname) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*80 output_fname,filename + character*83 output_fname_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + + filename = 'ctl_files/multilayer.ctl' + +! Deal with the case with relative paths. + if (output_fname(1:1).ne.'/') then + output_fname_tmp = '../'//output_fname + else + output_fname_tmp = output_fname//' ' + endif + + len_name = 83 - trailing_blanks(output_fname_tmp) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname_tmp(1:len_name) + else + write (71,51) output_fname_tmp(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,63) nz_max + write (71,64) nz_max + write (71,65) nz_max + write (71,66) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 8') + 59 format ('KK 1 0 number of snow layers') + 60 format ('snod 1 0 snow depth (m)') + 61 format ('sden 1 0 snow density (kg/m3)') + 62 format ('swed 1 0 snow-water-equivalent depth (m)') + 63 format ('snodz ',i6,' 0 layer-specific snow depth (m)') + 64 format ('sdenz ',i6,' 0 layer-specific snow density (kg/m3)') + 65 format ('swedz ',i6,' 0 layer-specific swe depth (m)') + 66 format ('diamz ',i6,' 0 layer-specific grain diameter (m)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_2Dxy_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_2Dxy.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_2Dxy.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_2Dxy.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,59) + write (71,60) + write (71,61) + write (71,62) + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 4') + 59 format ('KK 1 0 number of snow layers') + 60 format ('snod 1 0 snow depth (m)') + 61 format ('sden 1 0 snow density (kg/m3)') + 62 format ('swed 1 0 snow-water-equivalent depth (m)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_snod_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_snod.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_snod.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_snod.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,63) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 63 format ('snodz ',i6,' 0 layer-specific snow depth (m)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_sden_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_sden.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_sden.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_sden.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,64) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 64 format ('sdenz ',i6,' 0 layer-specific snow density (kg/m3)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_swed_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_swed.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_swed.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_swed.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,65) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 65 format ('swedz ',i6,' 0 layer-specific swe depth (m)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_diam_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_diam.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_diam.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_diam.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,66) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 66 format ('diamz ',i6,' 0 layer-specific grain diameter (m)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_flux_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_flux.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_flux.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_flux.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,66) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 66 format ('fluxz ',i6,' 0 layer-specific vapor flux (kg m-2 dt-1)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_temp_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_temp.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_temp.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_temp.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,66) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 66 format ('tempz ',i6,' 0 layer-specific snow temperature (deg K)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine mk_multilayer_cond_ctl(nx,ny,deltax,deltay,xmn,ymn,& + & dt,iyear_init,imonth_init,iday_init,xhour_init,max_iter,& + & undef,output_path,k) + + use snowmodel_inc + implicit none + + integer nx,ny,iyear_init,imonth_init,iday_init,max_iter,& + & igrads_dt,len_path,k + double precision xmn,ymn,xmn_km,ymn_km + real deltax,deltay,deltax_km,deltay_km,xhour_init,dt,undef + + integer len_name,trailing_blanks + + character*106 output_fname + character*80 filename + character*80 output_path + character*86 output_path_tmp + character*3 cmo(12) + character*2 cdt + + data cmo /'jan','feb','mar','apr','may','jun',& + & 'jul','aug','sep','oct','nov','dec'/ + + deltax_km = deltax / 1000.0 + deltay_km = deltay / 1000.0 + xmn_km = xmn / 1000.0 + ymn_km = ymn / 1000.0 + +! Convert dt from seconds to hours or a day. + if (dt.eq.86400.0) then + igrads_dt = 1 + cdt = 'dy' + elseif (dt.eq.10800.0) then + igrads_dt = 3 + cdt = 'hr' + elseif (dt.eq.3600.0) then + igrads_dt = 1 + cdt = 'hr' + else + print *, 'the mk_ctl program cannot deal with this dt value' + stop + endif + +! Define the name and location of the .ctl file. + if (k.eq.1) then + filename = 'ctl_files/wo_assim/multilayer_cond.ctl' + elseif (k.eq.2) then + filename = 'ctl_files/wi_assim/multilayer_cond.ctl' + endif + +! Deal with the case with relative paths. + if (output_path(1:1).ne.'/') then + output_path_tmp = '../../'//output_path + else + output_path_tmp = output_path//' ' + endif + + len_path = 86 - trailing_blanks(output_path_tmp) + output_fname = output_path_tmp(1:len_path)//'multilayer_cond.gdat' + len_name = 106 - trailing_blanks(output_fname) + + open (71,file=filename) + + if (output_fname(1:1).eq.'/') then + write (71,50) output_fname(1:len_name) + else + write (71,51) output_fname(1:len_name) + endif + + write (71,52) + write (71,53) undef +! (i,j) indexing. + write (71,54) nx,1.0,1.0 + write (71,55) ny,1.0,1.0 +! (meters,meters) indexing, with (zero,zero) origin. + write (71,541) nx,0.0,deltax + write (71,551) ny,0.0,deltay +! (km,km) indexing, with (zero,zero) origin. + write (71,542) nx,0.0,deltax_km + write (71,552) ny,0.0,deltay_km +! (meters,meters) indexing, with (xmn,ymn) origin. + write (71,543) nx,xmn,deltax + write (71,553) ny,ymn,deltay +! (km,km) indexing, with (xmn,ymn) origin. + write (71,544) nx,xmn_km,deltax_km + write (71,554) ny,ymn_km,deltay_km + + write (71,56) nz_max + write (71,57) max_iter,nint(xhour_init),iday_init,& + & cmo(imonth_init),iyear_init,igrads_dt,cdt + write (71,58) + write (71,66) nz_max + write (71,67) + + close (71) + +! This "a" by itself clips the trailing blanks in the a80 string. + 50 format ('DSET ',a) + 51 format ('DSET ^',a) + 52 format ('TITLE Multi-Layer output file') + 53 format ('UNDEF ',f10.1) + + 54 format ('XDEF ',i8,' LINEAR ',2f20.8) + 55 format ('YDEF ',i8,' LINEAR ',2f20.8) + 541 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 551 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 542 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 552 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 543 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 553 format ('#YDEF ',i8,' LINEAR ',2f20.8) + 544 format ('#XDEF ',i8,' LINEAR ',2f20.8) + 554 format ('#YDEF ',i8,' LINEAR ',2f20.8) + + 56 format ('ZDEF ',i6,' LINEAR 1 1') +! This i2.2 puts a zero in front of single digit numbers like 1. + 57 format ('TDEF ',i8,' LINEAR ',i2.2,'Z',i2.2,a3,i4,' ',i2,a2) + 58 format ('VARS 1') + 66 format ('condz ',i6,' 0 layer thermal conductivity (W m-1 K-1)') + 67 format ('ENDVARS') + + return + end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/readparam_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/readparam_code.f90 new file mode 100755 index 000000000..816fef876 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/readparam_code.f90 @@ -0,0 +1,2043 @@ +! readparam_code.f + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine READPARAM_CODE(dt,deltax,deltay,Utau_t_flag,& + & subgrid_flag,twolayer_flag,snowmodel_dot_par_fname,& + & bc_flag,curve_len_scale,slopewt,curvewt,ht_windobs,& + & ht_rhobs,ro_snow,snow_d_init_const,const_veg_flag,& + & vegsnowdepth,nx,ny,max_iter,met_input_fname,xmn,ymn,& + & iyear_init,imonth_init,iday_init,xhour_init,undef,ifill,& + & iobsint,dn,xlat,i_tair_flag,i_rh_flag,i_wind_flag,& + & i_solar_flag,i_prec_flag,isingle_stn_flag,igrads_metfile,& + & windspd_min,icond_flag,run_micromet,run_enbal,run_snowpack,& + & run_snowtran,topoflag,topoveg_fname,snowtran_output_fname,& + & micromet_output_fname,enbal_output_fname,Utau_t_const,& + & snowpack_output_fname,print_micromet,print_enbal,& + & print_snowpack,print_snowtran,i_longwave_flag,print_user,& + & ascii_topoveg,topo_ascii_fname,veg_ascii_fname,& + & irun_data_assim,lapse_rate_user_flag,& + & iprecip_lapse_rate_user_flag,use_shortwave_obs,& + & use_longwave_obs,use_sfc_pressure_obs,calc_subcanopy_met,& + & sfc_sublim_flag,gap_frac,cloud_frac_factor,& + & albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + & barnes_lg_domain,n_stns_used,tabler_dir,slope_adjust,& + & lat_solar_flag,UTC_flag,iveg_ht_flag,ihrestart_flag,& + & ihrestart_inc,i_dataassim_loop,tsls_threshold,dz_snow_min,& + & print_multilayer,multilayer_snowpack,max_layers,& + & multilayer_output_fname,izero_snow_date,curve_lg_scale_flag,& + & check_met_data,seaice_run,snowmodel_line_flag,wind_lapse_rate,& + & iprecip_scheme,cf_precip_flag,snowfall_frac,print_inc,& + & output_path_wo_assim,output_path_wi_assim,Tabler_1_flag,& + & Tabler_2_flag,tabler_sfc_path_name,print_var) + +! These programs read and process the input parameter data. +! +! The following must be true: +! +! All comment lines start with a ! in the first position. +! +! Blank lines are permitted. +! +! All parameter statements start with the parameter name, followed +! by a space, followed by an =, followed by a space, followed by +! the actual value, with nothing after that. These statements can +! have leading blanks, and must fit within 120 columns, and the +! parameter value cannot be longer than 80 characters (so, for +! example, your paths/file_names to the right of the "=" sign +! cannot be longer than 80 characters). +! +! It is set up to deal with integer, real, and string (character) +! input values. + + use snowmodel_vars, only: allocate_arrays + use snowmodel_inc + implicit none + +! Put parameter names here: + real dt,deltax,deltay,Utau_t_flag,topoflag,Utau_t_const,& + & subgrid_flag,twolayer_flag,& + & bc_flag,curve_len_scale,slopewt,curvewt,ht_windobs,& + & ht_rhobs,ro_snow,snow_d_init_const,const_veg_flag,& + & windspd_min,ascii_topoveg,gap_frac,cloud_frac_factor,& + & albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + & barnes_lg_domain,tabler_dir,slope_adjust,UTC_flag,& + & tsls_threshold,dz_snow_min,print_multilayer,& + & curve_lg_scale_flag,check_met_data,seaice_run,& + & snowmodel_line_flag,wind_lapse_rate,cf_precip_flag,& + & snowfall_frac,Tabler_1_flag,Tabler_2_flag + + character*1 print_var(n_print_vars) + + character*1 print_var_01,print_var_02,print_var_03,& + & print_var_04,print_var_05,print_var_06,print_var_07,& + & print_var_08,print_var_09,print_var_10,print_var_11,& + & print_var_12,print_var_13,print_var_14,print_var_15,& + & print_var_16,print_var_17,print_var_18,print_var_19,& + & print_var_20,print_var_21,print_var_22,print_var_23,& + & print_var_24,print_var_25,print_var_26,print_var_27,& + & print_var_28,print_var_29,print_var_30 + + real vegsnowdepth(nvegtypes) + real run_micromet,run_enbal,run_snowpack,run_snowtran,& + & print_micromet,print_enbal,print_snowpack,print_snowtran,& + & print_user,use_shortwave_obs,use_longwave_obs,print_inc,& + & use_sfc_pressure_obs,calc_subcanopy_met,sfc_sublim_flag + + integer nx,ny,max_iter,icond_flag,irun_data_assim + + character*80 topoveg_fname,met_input_fname,topo_ascii_fname,& + & veg_ascii_fname + + character*80 snowtran_output_fname,micromet_output_fname,& + & enbal_output_fname,snowpack_output_fname,multilayer_output_fname + + character*80 output_path_wo_assim,output_path_wi_assim,& + & tabler_sfc_path_name + + integer iyear_init,imonth_init,iday_init,& + & i_tair_flag,i_rh_flag,i_wind_flag,i_solar_flag,i_prec_flag,& + & i_longwave_flag,isingle_stn_flag,igrads_metfile,& + & lapse_rate_user_flag,iprecip_lapse_rate_user_flag,& + & n_stns_used,iveg_ht_flag,lat_solar_flag,ihrestart_inc,& + & ihrestart_flag,i_dataassim_loop,multilayer_snowpack,max_layers,& + & izero_snow_date,iprecip_scheme, metforce_opt + + double precision xmn,ymn + real xhour_init,dn + real undef ! undefined value + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + real xlat ! approx. latitude of domain center, decimal deg + + character*100 snowmodel_dot_par_fname + +! Working parameters. + character*120 input_string + character*80 c_param + character*80 c_value + integer k,max_par_lines,i_param_chars,i_value_chars,& + & icomment_flag,ipar_flag + +! integer, parameter :: npars=139 + integer, parameter :: npars=140 + integer ipar_count + character*40 cpar_name(npars) + + max_par_lines = 1500 + +! open (40,file='snowmodel.par') + open (40,file=snowmodel_dot_par_fname) + +! Initialize the input-parameter counting array. This is used to +! make sure all of the input parameters are read in correctly. +! Also initialize a array that will collect the variable names +! that have been read in, so it can be compared against the .par +! file to help figure out which variables have not been defined +! before the model simulation starts. + ipar_count = 0 + do k=1,npars + cpar_name(k) = ' BLANK: SOMETHING IS NOT DEFINED' + enddo + + do k=1,max_par_lines + read (40,'(a120)',end=99) input_string + + call get_param_data(input_string,c_param,c_value,& + & i_param_chars,i_value_chars,icomment_flag) + +! Process the string if it is not a comment. + if (icomment_flag.eq.0) then + +! GENERAL MODEL SETUP. + if (c_param(1:i_param_chars).eq.'nx') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) +! KRA +! call char2int(nx,i_value_chars,c_value,& +! & c_param(1:i_param_chars)) + if (nx.le.0) then + print *,'nx cannot be less than or equal to 0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ny') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) +! KRA +! call char2int(ny,i_value_chars,c_value,& +! & c_param(1:i_param_chars)) + if (ny.le.0) then + print *,'ny cannot be less than or equal to 0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'deltax') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(deltax,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (deltax.le.0.0) then + print *,'deltax cannot be less than or equal to 0.0' + stop + endif + endif + + !Subroutine effective only on first invocation. + !Check performed inside the routine. + if(nx /= 0 .and. ny /= 0) call allocate_arrays(nx,ny) + + if (c_param(1:i_param_chars).eq.'deltay') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(deltay,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (deltay.le.0.0) then + print *,'deltay cannot be less than or equal to 0.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'xmn') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2double(xmn,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'ymn') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2double(ymn,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'dt') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(dt,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (dt.le.0.0 .or. dt.gt.86400.0) then + print *,'dt out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'iyear_init') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iyear_init,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (iyear_init.lt.1900 .or. iyear_init.gt.2100) then + print *,'iyear_init out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'imonth_init') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(imonth_init,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (imonth_init.lt.1 .or. imonth_init.gt.12) then + print *,'imonth_init out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'iday_init') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iday_init,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (iday_init.lt.1 .or. iday_init.gt.31) then + print *,'iday_init out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'xhour_init') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(xhour_init,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (xhour_init.lt.0.0 .or. xhour_init.ge.24.0) then + print *,'xhour_init out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'max_iter') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(max_iter,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (max_iter.le.0 .or. max_iter.gt.300000) then + print *,'max_iter out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'isingle_stn_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(isingle_stn_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (isingle_stn_flag.ne.0 .and. isingle_stn_flag.ne.1) then + print *,'isingle_stn_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'metforce_opt') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(metforce_opt,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (metforce_opt.ne.0 .and. metforce_opt.ne.1) then + print *,'metforce_opt not 0 or 1' + stop + endif + endif + + + if (c_param(1:i_param_chars).eq.'igrads_metfile') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(igrads_metfile,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (igrads_metfile.ne.0 .and. igrads_metfile.ne.1) then + print *,'igrads_metfile not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'met_input_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(met_input_fname,c_value,i_value_chars,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'undef') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(undef,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'ascii_topoveg') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(ascii_topoveg,i_value_chars,c_value,& + & c_param(1:i_param_chars)) +! KRA +! Update here to allow for fields to be read in from LDT (KRA; 2020-07-16) + if (ascii_topoveg.lt.0.0 .and. ascii_topoveg.gt.2.0) then + print *,'ascii_topoveg not 0.0, 1.0, or 2.0' +! if (ascii_topoveg.ne.0.0 .and. ascii_topoveg.ne.1.0) then +! print *,'ascii_topoveg not 0.0 or 1.0' +! KRA + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'topoveg_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(topoveg_fname,c_value,i_value_chars,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'topo_ascii_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(topo_ascii_fname,c_value,i_value_chars,& + & c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'veg_ascii_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(veg_ascii_fname,c_value,i_value_chars,& + & c_param(1:i_param_chars)) + endif + +! if (c_param(1:i_param_chars).eq.'veg_shd_24') then +! call char2real(vegsnowdepth(24),i_value_chars,c_value,& +! & c_param(1:i_param_chars)) +! if (vegsnowdepth(24).lt.0.0 .or. vegsnowdepth(24).gt.20.0) +! & then +! print *,'veg_shd_24 out of range' +! stop +! endif +! endif + + if (c_param(1:i_param_chars).eq.'veg_shd_25') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(25),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(25).lt.0.0 .or. vegsnowdepth(25).gt.20.0)& + & then + print *,'veg_shd_25 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'veg_shd_26') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(26),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(26).lt.0.0 .or. vegsnowdepth(26).gt.20.0)& + & then + print *,'veg_shd_26 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'veg_shd_27') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(27),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(27).lt.0.0 .or. vegsnowdepth(27).gt.20.0)& + & then + print *,'veg_shd_27 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'veg_shd_28') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(28),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(28).lt.0.0 .or. vegsnowdepth(28).gt.20.0)& + & then + print *,'veg_shd_28 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'veg_shd_29') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(29),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(29).lt.0.0 .or. vegsnowdepth(29).gt.20.0)& + & then + print *,'veg_shd_29 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'veg_shd_30') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(vegsnowdepth(30),i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (vegsnowdepth(30).lt.0.0 .or. vegsnowdepth(30).gt.20.0)& + & then + print *,'veg_shd_30 out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'const_veg_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(const_veg_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (const_veg_flag.lt.0.0 .or. const_veg_flag.gt.30.0) then + print *,'const_veg_flag out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'iveg_ht_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iveg_ht_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (iveg_ht_flag.lt.-1 .or. iveg_ht_flag.gt.1) then + print *,'iveg_ht_flag out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'xlat') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(xlat,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (xlat.lt.-90.0 .or. xlat.gt.90.0) then + print *,'xlat out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'lat_solar_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(lat_solar_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (lat_solar_flag.lt.-1 .or. lat_solar_flag.gt.1) then + print *,'lat_solar_flag out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'UTC_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(UTC_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (UTC_flag.lt.-1 .or. UTC_flag.gt.1) then + print *,'UTC_flag out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'run_micromet') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(run_micromet,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (run_micromet.ne.0.0 .and. run_micromet.ne.1.0) then + print *,'run_micromet not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'run_enbal') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(run_enbal,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (run_enbal.ne.0.0 .and. run_enbal.ne.1.0) then + print *,'run_enbal not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'run_snowpack') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(run_snowpack,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (run_snowpack.ne.0.0 .and. run_snowpack.ne.1.0) then + print *,'run_snowpack not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'run_snowtran') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(run_snowtran,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (run_snowtran.ne.0.0 .and. run_snowtran.ne.1.0) then + print *,'run_snowtran not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'irun_data_assim') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(irun_data_assim,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (irun_data_assim.ne.0 .and. irun_data_assim.ne.1) then + print *,'irun_data_assim not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ihrestart_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(ihrestart_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ihrestart_flag.lt.-2 .or. ihrestart_flag.gt.300000) then + print *,'ihrestart_flag out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_dataassim_loop') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_dataassim_loop,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_dataassim_loop.lt.-366 .or. i_dataassim_loop.gt.1)& + & then + print *,'i_dataassim_loop out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ihrestart_inc') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(ihrestart_inc,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ihrestart_inc.lt.0 .or. ihrestart_inc.gt.8784) then + print *,'ihrestart_inc out of range' + stop + endif + endif + +! MICROMET MODEL SETUP. + if (c_param(1:i_param_chars).eq.'i_tair_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_tair_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_tair_flag.ne.0 .and. i_tair_flag.ne.1) then + print *,'i_tair_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_rh_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_rh_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_rh_flag.ne.0 .and. i_rh_flag.ne.1) then + print *,'i_rh_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_wind_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_wind_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_wind_flag.ne.-1 .and. i_wind_flag.ne.0 .and. & + & i_wind_flag.ne.1) then + print *,'i_wind_flag not -1, 0, or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_solar_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_solar_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_solar_flag.ne.0 .and. i_solar_flag.ne.1) then + print *,'i_solar_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_longwave_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_longwave_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_longwave_flag.ne.0 .and. i_longwave_flag.ne.1) then + print *,'i_longwave_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'i_prec_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(i_prec_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (i_prec_flag.ne.0 .and. i_prec_flag.ne.1) then + print *,'i_prec_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ifill') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(ifill,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ifill.ne.0 .and. ifill.ne.1) then + print *,'ifill not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'iobsint') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iobsint,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (iobsint.ne.0 .and. iobsint.ne.1) then + print *,'iobsint not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'dn') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(dn,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (dn.lt.1.0 .or. dn.gt.10000.0) then + print *,'dn out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'barnes_lg_domain') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(barnes_lg_domain,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (barnes_lg_domain.ne.0.0 .and. barnes_lg_domain.ne.1.0& + & .and. barnes_lg_domain.ne.2.0) then + print *,'barnes_lg_domain not 0.0 or 1.0 or 2.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'n_stns_used') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(n_stns_used,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (n_stns_used.lt.1 .or. n_stns_used.gt.9) then + print *,'n_stns_used out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'snowmodel_line_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(snowmodel_line_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (snowmodel_line_flag.ne.0.0 .and.& + & snowmodel_line_flag.ne.1.0)& + & then + print *,'snowmodel_line_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'check_met_data') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(check_met_data,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (check_met_data.ne.0.0 .and. check_met_data.ne.1.0)& + & then + print *,'check_met_data not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'curve_len_scale') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(curve_len_scale,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (curve_len_scale.le.0.0 .or. curve_len_scale.gt.5000.0)& + & then + print *,'curve_len_scale out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'slopewt') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(slopewt,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (slopewt.lt.0.0 .or. slopewt.gt.1.0) then + print *,'slopewt out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'curvewt') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(curvewt,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (curvewt.lt.0.0 .or. curvewt.gt.1.0) then + print *,'curvewt out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'curve_lg_scale_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(curve_lg_scale_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (curve_lg_scale_flag.ne.0.0 .and. & + & curve_lg_scale_flag.ne.1.0) then + print *,'curve_lg_scale_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'windspd_min') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(windspd_min,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (windspd_min.lt.0.1 .or. windspd_min.gt.2.0) then + print *,'windspd_min out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'lapse_rate_user_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(lapse_rate_user_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (lapse_rate_user_flag.ne.0 .and. & + & lapse_rate_user_flag.ne.1) then + print *,'lapse_rate_user_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq. & + & 'iprecip_lapse_rate_user_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iprecip_lapse_rate_user_flag,i_value_chars, & + & c_value,c_param(1:i_param_chars)) + if (iprecip_lapse_rate_user_flag.ne.0 .and. & + & iprecip_lapse_rate_user_flag.ne.1) then + print *,'iprecip_lapse_rate_user_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'iprecip_scheme') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(iprecip_scheme,i_value_chars, & + & c_value,c_param(1:i_param_chars)) + if (iprecip_scheme.ne.1 .and. iprecip_scheme.ne.2) then + print *,'iprecip_scheme not 1 or 2' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'snowfall_frac') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(snowfall_frac,i_value_chars,c_value, & + & c_param(1:i_param_chars)) + if (snowfall_frac.ne.1.0 .and. snowfall_frac.ne.2.0 & + & .and. snowfall_frac.ne.3.0) then + print *,'snowfall_frac must be = 1.0, 2.0, or 3.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'wind_lapse_rate') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(wind_lapse_rate,i_value_chars,c_value, & + & c_param(1:i_param_chars)) + if (wind_lapse_rate.lt.0.0) then + print *,'wind_lapse_rate must be >= 0.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'calc_subcanopy_met') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(calc_subcanopy_met,i_value_chars,c_value, & + & c_param(1:i_param_chars)) + if (calc_subcanopy_met.ne.0.0 .and. & + & calc_subcanopy_met.ne.1.0) then + print *,'calc_subcanopy_met not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'gap_frac') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(gap_frac,i_value_chars,c_value, & + & c_param(1:i_param_chars)) + if (gap_frac.lt.0.0 .or. gap_frac.gt.1.0) then + print *,'gap_frac out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'cloud_frac_factor') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(cloud_frac_factor,i_value_chars,c_value, & + & c_param(1:i_param_chars)) + if (cloud_frac_factor.lt.0.0 .or. cloud_frac_factor.gt.1.0) & + & then + print *,'cloud_frac_factor out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'use_shortwave_obs') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(use_shortwave_obs,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (use_shortwave_obs.ne.0.0 .and. use_shortwave_obs.ne.1.0) & + & then + print *,'use_shortwave_obs not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'use_longwave_obs') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(use_longwave_obs,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (use_longwave_obs.ne.0.0 .and. use_longwave_obs.ne.1.0) & + & then + print *,'use_longwave_obs not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'use_sfc_pressure_obs') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(use_sfc_pressure_obs,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (use_sfc_pressure_obs.ne.0.0 .and. & + & use_sfc_pressure_obs.ne.1.0) then + print *,'use_sfc_pressure_obs not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'cf_precip_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(cf_precip_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (cf_precip_flag.ne.0.0 .and. cf_precip_flag.ne.1.0 .and. & + & cf_precip_flag.ne.2.0 .and. cf_precip_flag.ne.3.0) then + print *,'cf_precip_flag not 0.0, 1.0, 2.0, or 3.0' + stop + endif + endif + +! SNOWTRAN-3D MODEL SETUP. + if (c_param(1:i_param_chars).eq.'Utau_t_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(Utau_t_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (Utau_t_flag.ne.0.0 .and. Utau_t_flag.ne.1.0) then + print *,'Utau_t_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'Utau_t_const') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(Utau_t_const,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (Utau_t_const.le.0.0 .and. Utau_t_const.gt.1.0) then + print *,'Utau_t_const out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'subgrid_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(subgrid_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (subgrid_flag.ne.0.0 .and. subgrid_flag.ne.1.0) then + print *,'subgrid_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'tabler_dir') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(tabler_dir,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (tabler_dir.lt.-360.0 .or. tabler_dir.gt.360.0) then + print *,'tabler_dir out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'slope_adjust') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(slope_adjust,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (slope_adjust.lt.0.0 .or. slope_adjust.gt.3.0) then + print *,'slope_adjust out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'twolayer_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(twolayer_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (twolayer_flag.ne.0.0 .and. twolayer_flag.ne.1.0) then + print *,'twolayer_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'bc_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(bc_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (bc_flag.ne.0.0 .and. bc_flag.ne.1.0) then + print *,'bc_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ht_windobs') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(ht_windobs,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ht_windobs.le.0.0 .or. ht_windobs.gt.20.0) then + print *,'ht_windobs out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ht_rhobs') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(ht_rhobs,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ht_rhobs.le.0.0 .or. ht_rhobs.gt.20.0) then + print *,'ht_rhobs out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'ro_snow') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(ro_snow,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (ro_snow.le.100.0 .or. ro_snow.gt.550.0) then + print *,'ro_snow out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'snow_d_init_const') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(snow_d_init_const,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (snow_d_init_const.lt.0.0 .or. & + & snow_d_init_const.gt.5.0) then + print *,'snow_d_init_const out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'topoflag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(topoflag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (topoflag.ne.0.0 .and. topoflag.ne.1.0) then + print *,'topoflag not 0.0 or 1.0' + stop + endif + endif + +! ENBAL MODEL SETUP. + if (c_param(1:i_param_chars).eq.'icond_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(icond_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (icond_flag.ne.0 .and. icond_flag.ne.1) then + print *,'icond_flag not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'albedo_snow_forest') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(albedo_snow_forest,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (albedo_snow_forest.lt.0.3 .or. & + & albedo_snow_forest.gt.0.8) then + print *,'albedo_snow_forest out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'albedo_snow_clearing') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(albedo_snow_clearing,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (albedo_snow_clearing.lt.0.4 .or. & + & albedo_snow_clearing.gt.0.8) then + print *,'albedo_snow_clearing out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'albedo_glacier') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(albedo_glacier,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (albedo_glacier.lt.0.3 .or. albedo_glacier.gt.0.8) then + print *,'albedo_glacier out of range' + stop + endif + endif + +! SNOWPACK MODEL SETUP. + if (c_param(1:i_param_chars).eq.'sfc_sublim_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(sfc_sublim_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (sfc_sublim_flag.ne.0.0 .and. sfc_sublim_flag.ne.1.0)& + & then + print *,'sfc_sublim_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'multilayer_snowpack') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(multilayer_snowpack,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (multilayer_snowpack.ne.0 .and. multilayer_snowpack.ne.1)& + & then + print *,'multilayer_snowpack not 0 or 1' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'tsls_threshold') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(tsls_threshold,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (tsls_threshold.lt.1.0 .or. tsls_threshold.gt.8760.0) & + & then + print *,'tsls_threshold out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'max_layers') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(max_layers,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (max_layers.lt.1 .or. max_layers.gt.100) then + print *,'max_layers out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'dz_snow_min') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(dz_snow_min,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (dz_snow_min.lt.0.0 .or. dz_snow_min.gt.5.0) then + print *,'dz_snow_min out of range' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'izero_snow_date') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2int(izero_snow_date,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (izero_snow_date.lt.10100 .or. & + & izero_snow_date.gt.999999) then + print *,'izero_snow_date out of range' + stop + endif + endif + +! SEAICE MODEL SETUP. + if (c_param(1:i_param_chars).eq.'seaice_run') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(seaice_run,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (seaice_run.ne.0.0 .and. seaice_run.ne.1.0 .and. & + & seaice_run.ne.2.0 .and. seaice_run.ne.3.0 .and. & + & seaice_run.ne.4.0) then + print *,'seaice_run not 0.0, 1.0, 2.0, 3.0, or 4.0' + stop + endif + endif + +! PRINTING OUTPUT FILES. + if (c_param(1:i_param_chars).eq.'print_micromet') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_micromet,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_micromet.ne.0.0 .and. print_micromet.ne.1.0) then + print *,'print_micromet not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'micromet_output_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(micromet_output_fname,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'print_snowtran') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_snowtran,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_snowtran.ne.0.0 .and. print_snowtran.ne.1.0) then + print *,'print_snowtran not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'snowtran_output_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(snowtran_output_fname,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'Tabler_1_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(Tabler_1_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (Tabler_1_flag.ne.0.0 .and. Tabler_1_flag.ne.1.0) then + print *,'Tabler_1_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'tabler_sfc_path_name') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(tabler_sfc_path_name,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'Tabler_2_flag') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(Tabler_2_flag,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (Tabler_2_flag.ne.0.0 .and. Tabler_2_flag.ne.1.0) then + print *,'Tabler_2_flag not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_enbal') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_enbal,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_enbal.ne.0.0 .and. print_enbal.ne.1.0) then + print *,'print_enbal not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'enbal_output_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(enbal_output_fname,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'print_snowpack') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_snowpack,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_snowpack.ne.0.0 .and. print_snowpack.ne.1.0) then + print *,'print_snowpack not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'snowpack_output_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(snowpack_output_fname,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'print_multilayer') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_multilayer,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_multilayer.ne.0.0 .and. print_multilayer.ne.1.0& + & .and. print_multilayer.ne.2.0) & + & then + print *,'print_multilayer not 0.0 or 1.0 or 2.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq. & + & 'multilayer_output_fname') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(multilayer_output_fname,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'print_user') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_user,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_user.ne.0.0 .and. print_user.ne.1.0) then + print *,'print_user not 0.0 or 1.0' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_inc') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2real(print_inc,i_value_chars,c_value,& + & c_param(1:i_param_chars)) + if (print_inc.ne.1.0 .and. print_inc.ne.8.0 .and.& + & print_inc.ne.24.0) then + print *,'print_inc not 1.0 or 8.0 or 24.0. You are' + print *,'using some number that is not typical and' + print *,'should make certain you and the code are' + print *,'doing exactly what you think it is and want' + print *,'to do.' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'output_path_wo_assim') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(output_path_wo_assim,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + + if (c_param(1:i_param_chars).eq.'output_path_wi_assim') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(output_path_wi_assim,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + endif + +! THESE ARE THE 30 PRINT_VAR_## FLAGS. + if (c_param(1:i_param_chars).eq.'print_var_01') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_01,c_value, & + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_01.ne.'y' .and. print_var_01.ne.'n') then + print *,'print_var_01 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_02') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_02,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_02.ne.'y' .and. print_var_02.ne.'n') then + print *,'print_var_02 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_03') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_03,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_03.ne.'y' .and. print_var_03.ne.'n') then + print *,'print_var_03 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_04') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_04,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_04.ne.'y' .and. print_var_04.ne.'n') then + print *,'print_var_04 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_05') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_05,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_05.ne.'y' .and. print_var_05.ne.'n') then + print *,'print_var_05 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_06') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_06,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_06.ne.'y' .and. print_var_06.ne.'n') then + print *,'print_var_06 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_07') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_07,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_07.ne.'y' .and. print_var_07.ne.'n') then + print *,'print_var_07 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_08') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_08,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_08.ne.'y' .and. print_var_08.ne.'n') then + print *,'print_var_08 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_09') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_09,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_09.ne.'y' .and. print_var_09.ne.'n') then + print *,'print_var_09 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_10') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_10,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_10.ne.'y' .and. print_var_10.ne.'n') then + print *,'print_var_10 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_11') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_11,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_11.ne.'y' .and. print_var_11.ne.'n') then + print *,'print_var_11 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_12') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_12,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_12.ne.'y' .and. print_var_12.ne.'n') then + print *,'print_var_12 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_13') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_13,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_13.ne.'y' .and. print_var_13.ne.'n') then + print *,'print_var_13 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_14') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_14,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_14.ne.'y' .and. print_var_14.ne.'n') then + print *,'print_var_14 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_15') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_15,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_15.ne.'y' .and. print_var_15.ne.'n') then + print *,'print_var_15 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_16') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_16,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_16.ne.'y' .and. print_var_16.ne.'n') then + print *,'print_var_16 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_17') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_17,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_17.ne.'y' .and. print_var_17.ne.'n') then + print *,'print_var_17 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_18') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_18,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_18.ne.'y' .and. print_var_18.ne.'n') then + print *,'print_var_18 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_19') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_19,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_19.ne.'y' .and. print_var_19.ne.'n') then + print *,'print_var_19 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_20') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_20,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_20.ne.'y' .and. print_var_20.ne.'n') then + print *,'print_var_20 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_21') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_21,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_21.ne.'y' .and. print_var_21.ne.'n') then + print *,'print_var_21 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_22') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_22,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_22.ne.'y' .and. print_var_22.ne.'n') then + print *,'print_var_22 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_23') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_23,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_23.ne.'y' .and. print_var_23.ne.'n') then + print *,'print_var_23 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_24') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_24,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_24.ne.'y' .and. print_var_24.ne.'n') then + print *,'print_var_24 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_25') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_25,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_25.ne.'y' .and. print_var_25.ne.'n') then + print *,'print_var_25 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_26') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_26,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_26.ne.'y' .and. print_var_26.ne.'n') then + print *,'print_var_26 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_27') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_27,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_27.ne.'y' .and. print_var_27.ne.'n') then + print *,'print_var_27 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_28') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_28,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_28.ne.'y' .and. print_var_28.ne.'n') then + print *,'print_var_28 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_29') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_29,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_29.ne.'y' .and. print_var_29.ne.'n') then + print *,'print_var_29 not y or n' + stop + endif + endif + + if (c_param(1:i_param_chars).eq.'print_var_30') then + ipar_count = ipar_count + 1 + cpar_name(ipar_count) = c_param(1:i_param_chars) + call char2char(print_var_30,c_value,& + & i_value_chars,c_param(1:i_param_chars)) + if (print_var_30.ne.'y' .and. print_var_30.ne.'n') then + print *,'print_var_30 not y or n' + stop + endif + endif + +! Real example +! if (c_param(1:i_param_chars).eq.'') +! & call char2real(,i_value_chars,c_value, +! & c_param(1:i_param_chars)) + +! Integer example. +! if (c_param(1:i_param_chars).eq.'nx') +! & call char2int(nx,i_value_chars,c_value, +! & c_param(1:i_param_chars)) + +! Character example. +! if (c_param(1:i_param_chars).eq.'fname_out') +! & call char2char(fname_out,c_value,i_value_chars, +! & c_param(1:i_param_chars)) + + endif + enddo + + 99 continue + +! Use the print_var_## parameters to build the print control +! array "print_var(n_print_vars)" used in output_user.f. + print_var(1) = print_var_01 + print_var(2) = print_var_02 + print_var(3) = print_var_03 + print_var(4) = print_var_04 + print_var(5) = print_var_05 + print_var(6) = print_var_06 + print_var(7) = print_var_07 + print_var(8) = print_var_08 + print_var(9) = print_var_09 + print_var(10) = print_var_10 + print_var(11) = print_var_11 + print_var(12) = print_var_12 + print_var(13) = print_var_13 + print_var(14) = print_var_14 + print_var(15) = print_var_15 + print_var(16) = print_var_16 + print_var(17) = print_var_17 + print_var(18) = print_var_18 + print_var(19) = print_var_19 + print_var(20) = print_var_20 + print_var(21) = print_var_21 + print_var(22) = print_var_22 + print_var(23) = print_var_23 + print_var(24) = print_var_24 + print_var(25) = print_var_25 + print_var(26) = print_var_26 + print_var(27) = print_var_27 + print_var(28) = print_var_28 + print_var(29) = print_var_29 + print_var(30) = print_var_30 + +! Check the input-parameter counting array to be sure that all +! parameters have been defined. + ipar_flag = npars - ipar_count + if (ipar_flag.ne.0) then + print * + print * + print *,'THERE ARE MISSING VARIABLES IN THE .PAR FILE.' + print * + print *,' THIS MANY VARIABLES ARE MISSING:',ipar_flag + print * + print *,' THESE ARE THE VARIABLES THAT HAVE BEEN READ IN:' + + do k=1,npars + print *,'VARIABLE NAME =',k,' ',cpar_name(k) + enddo + + print * + print *,'ALL .PAR VARIABLES MUST BE DEFINED BEFORE' + print *,' YOU CAN CONTINUE.' + print * + + stop + endif + +! Put some space at the end of the parameter printouts. + print * + + return + end subroutine READPARAM_CODE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine char2char(cvar,c_value,i_value_chars,& + & c_param) + + implicit none + + character*(*) c_value,c_param,cvar + integer i_value_chars + + cvar = c_value(1:i_value_chars) + +!KRA +! print *,c_param,' = ',cvar(1:i_value_chars) + + return + end subroutine char2char + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine char2real(rvar,i_value_chars,c_value,& + & c_param) + + implicit none + + character*(*) c_value,c_param + integer i_value_chars + real rvar + character*8 form + +! Read an real value (rvar) from the character string (c_value). + write (form,90) i_value_chars + 90 format ('(f',i2,'.0)') + read (c_value,form) rvar + +!KRA +! print *,c_param,' =',rvar + + return + end subroutine char2real + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine char2double(dvar,i_value_chars,c_value,& + & c_param) + + implicit none + + character*(*) c_value,c_param + integer i_value_chars + double precision dvar + character*8 form + +! Read an double precision value (dvar) from the character +! string (c_value). + write (form,90) i_value_chars + 90 format ('(f',i2,'.0)') + read (c_value,form) dvar + +!KRA +! print *,c_param,' =',dvar + + return + end subroutine char2double + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine char2int(ivar,i_value_chars,c_value,& + & c_param) + + implicit none + + character*(*) c_value,c_param + integer i_value_chars,ivar + character*8 form + +! Read an integer value (ivar) from the character string (c_value). + write (form,90) i_value_chars + 90 format ('(i',i2,')') + read (c_value,form) ivar + +!KRA +! print *,c_param,' =',ivar + + return + end subroutine char2int + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine get_param_data(input_string,c_param,c_value,& + & i_param_chars,i_value_chars,icomment_flag) + + implicit none + + character*(*) input_string,c_param,c_value + + integer leading_blanks,trailing_blanks + integer i,icomment_flag + integer i_param_start,i_equals_position,i_param_end,& + & i_value_start,i_value_end,i_param_chars,i_value_chars,& + & i_loc,i_leading_blanks,i_trailing_blanks + +! If the input string is not a comment line, process the data. + if (input_string(1:1).ne.'!') then + +! First count the number of leading and trailing blanks. + i_leading_blanks = leading_blanks(input_string) + i_trailing_blanks = trailing_blanks(input_string) + +! If the input string is not completely blank, process the data. + if (i_leading_blanks.ne.len(input_string)) then + icomment_flag = 0 + +! Define the starting and ending points of the parameter name and +! parameter value. + i_param_start = i_leading_blanks + 1 + i_equals_position = index(input_string,'=') + i_param_end = i_equals_position - 2 + i_value_start = i_equals_position + 2 + i_value_end = len(input_string) - i_trailing_blanks + i_param_chars = i_param_end - i_param_start + 1 + i_value_chars = i_value_end - i_value_start + 1 + +! Pull out the parameter name and value. + do i=1,i_param_chars + i_loc = i + i_param_start - 1 + c_param(i:i) = input_string(i_loc:i_loc) + enddo + + do i=1,i_value_chars + i_loc = i + i_value_start - 1 + c_value(i:i) = input_string(i_loc:i_loc) + enddo + +! Check to see whether we have found any paths/fnames that are +! longer than 80 characters. + if (i_value_chars.gt.80) then + print * + print *, input_string + print *, 'Number of characters found =',i_value_chars + print * + print *, 'Found path/fname longer than 80 characters;' + print *, 'the limit is 80 characters for the string' + print *, 'starting in the second character position' + print *, 'after the "=" sign.' + print * + stop + endif + + else + icomment_flag = 1 + endif + + else + icomment_flag = 1 + endif + + return + end subroutine get_param_data + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + integer function leading_blanks(input_string) + + implicit none + + integer k + character*(*) input_string + +! Count the number of blanks preceeding the first non-blank +! character. + leading_blanks = 0 + do k=1,len(input_string) + if (input_string(k:k).eq.' ') then + leading_blanks = leading_blanks + 1 + else + return + endif + enddo + + return + end function leading_blanks + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + integer function trailing_blanks(input_string) + + implicit none + + integer k + character*(*) input_string + +! Count the number of blanks following the last non-blank +! character. + trailing_blanks = 0 + do k=len(input_string),1,-1 + if (input_string(k:k).eq.' ') then + trailing_blanks = trailing_blanks + 1 + else + return + endif + enddo + + return + end function trailing_blanks + + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine GET_DOT_PAR_PATH_LOCATION(snowmodel_dot_par_fname) + +! The following provides the ability to read in a 'snowmodel.par' +! file that is called something other than 'snowmodel.par' and/or +! located somewhere different than the directory where the +! 'snowmodel' executable file is located. If you run: +! snowmodel +! it assumes the .par file is called 'snowmodel.par' and is +! located in the default location. You can also run the code as +! follows: +! snowmodel parpath/parname.par +! and it will look for the .par file in the different location +! and/or the different name. + + implicit none + + integer nargs,iargc + character*100 snowmodel_dot_par_fname + + snowmodel_dot_par_fname = "snowmodel.par" + + nargs = iargc() + + if (nargs.eq.1) then + call getarg (1,snowmodel_dot_par_fname) + endif + + print * + print *, snowmodel_dot_par_fname + + return + end subroutine GET_DOT_PAR_PATH_LOCATION + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_inc.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_inc.f90 new file mode 100755 index 000000000..593666819 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_inc.f90 @@ -0,0 +1,60 @@ +module snowmodel_inc + public + ! THESE FIRST THREE PARAMETER VALUES OFTEN NEED TO BE CHANGED + ! FOR BIG AND LONG MODEL SIMULATIONS. + + ! nx_max and ny_max define the maximum nx and ny grid points + ! that you can have in your model run. If you want to run a + ! larger domain, then you have to change these numbers and + ! recompile the code. + +! integer,parameter :: nx_max=1001,ny_max=1001 +! integer,parameter :: nx_max=3131,ny_max=3603 +! integer,parameter :: nx_max=10001,ny_max=10001 +! integer,parameter :: nx_max=17636,ny_max=17784 + integer,parameter :: nx_max=22001,ny_max=22001 + + ! max_time_steps defines the maximum number of time steps that + ! will be used in the current compliled version of the code. + ! If you want to run a longer time domain, then you have to + ! change this number and recompile the code. + + integer, parameter :: max_time_steps=8784 + + ! nstns_max is the maximum number of stations that can be used + ! in the data assimilation routines. +! integer, parameter :: nstns_max=10000 + integer, parameter :: nstns_max=22894 + + ! max_obs_dates is used in the data assimilation routines. It + ! must be greater than or equal to the number of observation + ! dates in the entire simulation + (plus) the number of years + ! in the simulation. For example, for a 6-year simulation with + ! 2 observation dates in each year, you would set max_obs_dates + ! to be = 2obs*6yrs+6yrs = 18 or greater. For a 6-year run with + ! 4 observation dates in 2 of the years, and 0 observation dates + ! in the other 4 years, max_obs_dates = 8obs+6yrs = 14 or + ! greater. + integer, parameter :: max_obs_dates=12 + + ! If you are running the multi-layer snow model (even with a single + ! layer) nz_max must be at least one greater than max_layers in + ! snowmodel.par. This is because the model will build a new layer + ! with the new snowfall and then it is merged with the layer below + ! if you only want a single snow layer. If you are running + ! SnowModel's original single layer model, nz_max can be 1 (but if + ! nz_max=2 it will avoid a warning message if you are compiling + ! the code with gfortran). + ! parameter (nz_max=25) + integer, parameter :: nz_max=2 + + ! This is the number of print variables that are controlled by + ! the variable list in snowmodel.par. + integer, parameter :: n_print_vars=30 + + ! nvegtypes is the number of vegetation types used in the model + ! run. If you change this then you have made some big changes + ! in the codes' vegetation description. + integer, parameter :: nvegtypes=30 + +end module snowmodel_inc diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_vars.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_vars.f90 new file mode 100755 index 000000000..8474d6897 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowmodel_vars.f90 @@ -0,0 +1,393 @@ +module snowmodel_vars + + use snowmodel_inc + implicit none + +! Misc variables. + character*100 snowmodel_dot_par_fname + +! SnowTran-3D variables. + integer max_iter + +! Add top-level log message flag (master processor); for parallel runs !KRA + logical snowmodel_masterproc !KRA + +! integer nx_max, ny_max ! KRA + + integer i,j,iter,nx,ny + + real ro_snow,ro_water,ro_air,gravity,vonKarman,snow_z0 + real deltax,deltay,dt,curvewt,utau_t_flag + real fetch,xmu,C_z,h_const,wind_min,windspd_flag + real Up_const,dz_susp,ztop_susp,fall_vel,Ur_const + real pi,twopio360,bc_flag,topoflag,Utau_t_const + real ht_windobs,ht_rhobs,slopewt,bs_flag,twolayer_flag + real subgrid_flag,curve_len_scale + real snow_d_init_const,const_veg_flag,winddir_flag + real windspd_min,tabler_dir,slope_adjust + + real, allocatable :: topo_land(:,:) + real, allocatable :: tabler_nn(:,:) + real, allocatable :: tabler_ss(:,:) + real, allocatable :: tabler_ee(:,:) + real, allocatable :: tabler_ww(:,:) + real, allocatable :: tabler_ne(:,:) + real, allocatable :: tabler_se(:,:) + real, allocatable :: tabler_sw(:,:) + real, allocatable :: tabler_nw(:,:) + real, allocatable :: topo(:,:) + real, allocatable :: vegtype(:,:) + + real, allocatable :: uwind_grid(:,:),vwind_grid(:,:) + real, allocatable :: windspd_grid(:,:),winddir_grid(:,:) + real, allocatable :: tair_grid(:,:),sprec(:,:) + real, allocatable :: rh_grid(:,:), curvature(:,:) + + real, allocatable :: slope_az(:,:) + real, allocatable :: terrain_slope(:,:) + + !Not dynamic + integer index_ue(ny_max,2*nx_max+1),index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1),index_vs(nx_max,2*ny_max+1) + + real, allocatable :: snow_d(:,:) + real, allocatable :: snow_d_init(:,:) + real, allocatable :: Utau(:,:) + real, allocatable :: Utau_t(:,:) + real, allocatable :: z_0(:,:) + real, allocatable :: h_star(:,:) + real, allocatable :: conc_salt(:,:) + + real, allocatable :: Qsalt_max(:,:) + real, allocatable :: Qsalt_maxu(:,:),Qsalt_maxv(:,:) + real, allocatable :: Qsalt(:,:) + real, allocatable :: Qsalt_u(:,:),Qsalt_v(:,:) + real, allocatable :: dh_salt(:,:) + real, allocatable :: dh_salt_u(:,:),dh_salt_v(:,:) + + real, allocatable :: Qsusp(:,:) + real, allocatable :: Qsusp_u(:,:),Qsusp_v(:,:) + real, allocatable :: dh_susp(:,:) + real, allocatable :: dh_susp_u(:,:),dh_susp_v(:,:) + + real, allocatable :: Qsubl(:,:) + real, allocatable :: Qsubl_depth(:,:) + + real, allocatable :: sum_sprec(:,:) + + real, allocatable :: wbal_qsubl(:,:) + real, allocatable :: wbal_salt(:,:) + real, allocatable :: wbal_susp(:,:) + real, allocatable :: wbal_subgrid(:,:) + real, allocatable :: sum_qsubl(:,:) + real, allocatable :: sum_trans(:,:) + real, allocatable :: soft_snow_d(:,:) + real, allocatable :: ro_soft_snow(:,:) + real, allocatable :: ro_soft_snow_old(:,:) + + real vegsnowdepth(nvegtypes) + real, allocatable :: veg_z0(:,:) + real, allocatable :: vegsnowd_xy(:,:) + integer iveg_ht_flag + + real run_micromet,run_enbal,run_snowpack,run_snowtran + + character*80 topoveg_fname,met_input_fname,topo_ascii_fname,& + & veg_ascii_fname + + real curve_lg_scale_flag + real, allocatable :: curve_wt_lg(:,:) + + character*80 tabler_sfc_path_name + real Tabler_1_flag,Tabler_2_flag +! End SnowTran-3D variables. + +! MicroMet variables. + double precision xmn ! center x coords of lower left grid cell + double precision ymn ! center y coords of lower left grid cell + !double precision xg_line(nx_max,ny_max),yg_line(nx_max,ny_max) + double precision, allocatable :: xg_line(:,:),yg_line(:,:) + + real dn ! average observation spacing + + real, allocatable :: Qsi_grid(:,:) ! output + real, allocatable :: Qli_grid(:,:) ! output + real, allocatable :: prec_grid(:,:) ! output + real, allocatable :: xlat_grid(:,:) ! lat (dec deg) of cell centers + real, allocatable :: xlon_grid(:,:) ! lon (dec deg) of cell centers + + integer iyear_init ! model start year + integer imonth_init ! model start month + integer iday_init ! model start day + real xhour_init ! model start hour + real xlat ! approx. latitude of domain center, decimal deg + + real undef ! undefined value + integer ifill ! flag (=1) forces a value in every cell + integer iobsint ! flag (=1) use dn value from .par file + + integer i_tair_flag,i_rh_flag,i_wind_flag,i_solar_flag,& + & i_prec_flag,i_longwave_flag,isingle_stn_flag,igrads_metfile,& + & lapse_rate_user_flag,iprecip_lapse_rate_user_flag,n_stns_used,& + & lat_solar_flag,ihrestart_inc,iter_start,ihrestart_flag,& + & iprecip_scheme, metforce_opt + + real xhour,ascii_topoveg,use_shortwave_obs,gap_frac,& + & use_longwave_obs,use_sfc_pressure_obs,calc_subcanopy_met,& + & cloud_frac_factor,barnes_lg_domain,UTC_flag,check_met_data,& + & snowmodel_line_flag,wind_lapse_rate + + integer, parameter :: nftypes = 5 + real forest_LAI(nftypes) + + integer iyear,imonth,iday + !integer k_stn(nx_max,ny_max,9) + integer, allocatable :: k_stn(:,:,:)!Last dim is 9 + + real, allocatable :: cf_precip(:,:) + real cf_precip_flag + + real, allocatable :: cloud_frac_grid(:,:) + real snowfall_frac +! End MicroMet variables. + +! EnBal variables. + integer icond_flag + + real, allocatable :: Tsfc(:,:),Qle(:,:),& + & Qh(:,:),Qe(:,:),Qc(:,:),& + & Qm(:,:),e_balance(:,:),Qf(:,:),& + & swe_depth(:,:),sfc_pressure(:,:),& + & albedo(:,:) + + real albedo_snow_forest,albedo_snow_clearing,albedo_glacier +! End EnBal variables. + + ! SnowPack variables. + + real, allocatable :: ro_nsnow(:,:),w_balance(:,:),& + & runoff(:,:),rain(:,:),& + & sum_prec(:,:),sum_runoff(:,:),& + & xro_snow(:,:),ro_snow_grid(:,:),& + & sum_Qcs(:,:),canopy_int(:,:),& + & Qcs(:,:),canopy_unload(:,:),& + & snow_depth(:,:),glacier_melt(:,:),& + & sum_unload(:,:),sum_glacmelt(:,:),& + & swemelt(:,:),d_canopy_int(:,:),& + & sum_d_canopy_int(:,:),sum_sfcsublim(:,:),& + & sum_swemelt(:,:),swesublim(:,:),& + & swe_depth_old(:,:),canopy_int_old(:,:),& + & windspd_2m_grid(:,:) + + real sfc_sublim_flag + + integer max_layers,multilayer_snowpack,k + integer, allocatable :: KK(:,:) + integer, allocatable :: melt_flag(:,:,:)!nz_max + + + real ro_snowmax,tsls_threshold,dz_snow_min + real, allocatable :: tslsnowfall(:,:) + real, allocatable :: change_layer(:,:) + real, allocatable :: snod_layer(:,:,:) + real, allocatable :: swed_layer(:,:,:) + real, allocatable :: ro_layer(:,:,:) + real, allocatable :: T_old(:,:,:) + real, allocatable :: gamma(:,:,:) + real, allocatable :: diam_layer(:,:,:) + real, allocatable :: flux_layer(:,:,:) + + integer iclear_mn,iclear_dy,izero_snow_date + real xclear_hr +! End SnowPack variables. + +! SeaIce variables. + real seaice_run + real, allocatable :: seaice_conc(:,:,:) +! End SeaIce variables. + +! Data assimilaion (precipitation and melt) factor variables. + real corr_factor(nx_max,ny_max,max_obs_dates+1) + integer icorr_factor_index(max_time_steps) + + integer icorr_factor_loop,irun_data_assim,nobs_dates,& + & i_dataassim_loop,i_corr_start + +! End data assimilaion (precipitation and melt) factor variables. + +! Print output variables. + real print_micromet,print_enbal,print_snowpack,print_snowtran,& + & print_multilayer + real print_user,print_inc + double precision nrecs_max + + character*80 micromet_output_fname + character*80 enbal_output_fname + character*80 snowtran_output_fname + character*80 snowpack_output_fname + character*80 multilayer_output_fname + character*80 output_path_wo_assim,output_path_wi_assim + + character*1 print_var(n_print_vars) + character*4 print_outvars(n_print_vars) +! End print output variables. +contains + + subroutine allocate_arrays(nx,ny) + implicit none + + integer, intent(in) :: nx,ny + integer, save :: first = 1 + + real,dimension(nx,ny) :: zero_real + + zero_real = 0.0 + + if(first == 0) return + first = 0 + + allocate(topo_land(nx,ny),source=zero_real) + allocate(tabler_nn(nx,ny),source=zero_real) + allocate( tabler_ss(nx,ny),source=zero_real) + allocate( tabler_ee(nx,ny),source=zero_real) + allocate( tabler_ww(nx,ny),source=zero_real) + allocate( tabler_ne(nx,ny),source=zero_real) + allocate( tabler_se(nx,ny),source=zero_real) + allocate( tabler_sw(nx,ny),source=zero_real) + allocate( tabler_nw(nx,ny),source=zero_real) + allocate( topo(nx,ny),source=zero_real) + allocate( vegtype(nx,ny),source=zero_real) + allocate( uwind_grid(nx,ny),source=zero_real) + allocate( vwind_grid(nx,ny),source=zero_real) + allocate( windspd_grid(nx,ny),source=zero_real) + allocate( winddir_grid(nx,ny),source=zero_real) + allocate( tair_grid(nx,ny),source=zero_real) + allocate( sprec(nx,ny),source=zero_real) + allocate( rh_grid(nx,ny),source=zero_real) + allocate( curvature(nx,ny),source=zero_real) + + allocate( slope_az(nx,ny),source=zero_real) + allocate( terrain_slope(nx,ny),source=zero_real) + + ! The following 2 variables have nx and ny swapped. + ! Nx (cols) is also doubled + !integer,allocatable :: index_ue(:,:),index_uw(:,:) + ! The following 2 variables have ny (cols) doubled + !integer,allocatable :: index_vn(:,:),index_vs(:,:) + + allocate( snow_d(nx,ny),source=zero_real) + + allocate( snow_d_init(nx,ny),source=zero_real) + allocate( Utau(nx,ny),source=zero_real) + allocate( Utau_t(nx,ny),source=zero_real) + allocate( z_0(nx,ny),source=zero_real) + allocate( h_star(nx,ny),source=zero_real) + allocate( conc_salt(nx,ny),source=zero_real) + + allocate( Qsalt_max(nx,ny),source=zero_real) + allocate( Qsalt_maxu(nx,ny),source=zero_real) + allocate( Qsalt_maxv(nx,ny),source=zero_real) + allocate( Qsalt(nx,ny),source=zero_real) + allocate( Qsalt_u(nx,ny),source=zero_real) + allocate( Qsalt_v(nx,ny),source=zero_real) + allocate( dh_salt(nx,ny),source=zero_real) + allocate( dh_salt_u(nx,ny),source=zero_real) + allocate( dh_salt_v(nx,ny),source=zero_real) + + allocate( Qsusp(nx,ny),source=zero_real) + allocate( Qsusp_u(nx,ny),source=zero_real) + allocate( Qsusp_v(nx,ny),source=zero_real) + allocate( dh_susp(nx,ny),source=zero_real) + allocate( dh_susp_u(nx,ny),source=zero_real) + allocate( dh_susp_v(nx,ny),source=zero_real) + + allocate( Qsubl(nx,ny),source=zero_real) + allocate( Qsubl_depth(nx,ny),source=zero_real) + + allocate( sum_sprec(nx,ny),source=zero_real) + + allocate( wbal_qsubl(nx,ny),source=zero_real) + allocate( wbal_salt(nx,ny),source=zero_real) + allocate( wbal_susp(nx,ny),source=zero_real) + allocate( wbal_subgrid(nx,ny),source=zero_real) + allocate( sum_qsubl(nx,ny),source=zero_real) + allocate( sum_trans(nx,ny),source=zero_real) + + allocate( soft_snow_d(nx,ny),source=zero_real) + allocate( ro_soft_snow(nx,ny),source=zero_real) + allocate( ro_soft_snow_old(nx,ny),source=zero_real) + + allocate( veg_z0(nx,ny),source=zero_real) + allocate( vegsnowd_xy(nx,ny),source=zero_real) + + allocate( curve_wt_lg(nx,ny),source=zero_real) + + allocate (xg_line(nx,ny),yg_line(nx,ny)) + xg_line = 0.0 + yg_line = 0.0 + allocate( Qsi_grid(nx,ny),source=zero_real) ! output + allocate( Qli_grid(nx,ny),source=zero_real) ! output + + allocate( prec_grid(nx,ny),source=zero_real) ! output + allocate( xlat_grid(nx,ny),source=zero_real) ! lat (dec deg) of cell centers + allocate( xlon_grid(nx,ny),source=zero_real) ! lon (dec deg) of cell centers + + allocate( cf_precip(nx,ny),source=zero_real) + + allocate(k_stn(nx,ny,9))!Last dim is 9 + k_stn = 0 + + allocate( cloud_frac_grid(nx,ny),source=zero_real) + + allocate(Tsfc(nx,ny),Qle(nx,ny),& + & Qh(nx,ny),Qe(nx,ny),Qc(nx,ny),& + & Qm(nx,ny),e_balance(nx,ny),Qf(nx,ny),& + & swe_depth(nx,ny),sfc_pressure(nx,ny),& + & albedo(nx,ny),source=zero_real) + + allocate(ro_nsnow(nx,ny),w_balance(nx,ny),& + & runoff(nx,ny),rain(nx,ny),& + & sum_prec(nx,ny),sum_runoff(nx,ny),& + & xro_snow(nx,ny),ro_snow_grid(nx,ny),& + & sum_Qcs(nx,ny),canopy_int(nx,ny),& + & Qcs(nx,ny),canopy_unload(nx,ny),& + & snow_depth(nx,ny),glacier_melt(nx,ny),& + & sum_unload(nx,ny),sum_glacmelt(nx,ny),& + & swemelt(nx,ny),d_canopy_int(nx,ny),& + & sum_d_canopy_int(nx,ny),sum_sfcsublim(nx,ny),& + & sum_swemelt(nx,ny),swesublim(nx,ny),& + & swe_depth_old(nx,ny),canopy_int_old(nx,ny),& + & windspd_2m_grid(nx,ny), source=zero_real) + + allocate(KK(nx,ny)) + KK = 0 + allocate(melt_flag(nx,ny,nz_max))!nz_max + melt_flag = 0 + + allocate( tslsnowfall(nx,ny),source=zero_real) + + allocate( change_layer(nx,ny),source=zero_real) + allocate( snod_layer(nx,ny,nz_max)) + snod_layer = 0.0 + allocate( swed_layer(nx,ny,nz_max)) + swed_layer = 0.0 + allocate( ro_layer(nx,ny,nz_max)) + ro_layer = 0.0 + allocate( T_old(nx,ny,nz_max)) + T_old = 0.0 + allocate( gamma(nx,ny,nz_max)) + gamma = 0.0 + allocate( diam_layer(nx,ny,nz_max)) + diam_layer = 0.0 + allocate( flux_layer(nx,ny,nz_max)) + flux_layer = 0.0 + allocate(seaice_conc(nx,ny,nz_max)) + seaice_conc = 0.0 + +!KRA + snowmodel_masterproc = .true. +!KRA + + end subroutine allocate_arrays + +end module snowmodel_vars diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/snowpack_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowpack_code.f90 new file mode 100755 index 000000000..a39707228 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowpack_code.f90 @@ -0,0 +1,3211 @@ +! snowpack_code.f + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SNOWPACK_CODE(nx,ny,Tair_grid,rh_grid,ro_nsnow,& + & dt,swe_depth,Tsfc,snow_d,prec_grid,runoff,Qm,rain,& + & sprec,iter,w_balance,sum_prec,sum_runoff,xro_snow,& + & undef,ro_snow,ro_snow_grid,soft_snow_d,sum_sprec,& + & snow_depth,windspd_grid,Qsi_grid,sum_Qcs,canopy_int,& + & Qcs,vegtype,forest_LAI,albedo,glacier_melt,& + & canopy_unload,sum_unload,sum_glacmelt,run_snowtran,& + & swemelt,d_canopy_int,sum_d_canopy_int,snow_d_init,& + & sfc_pressure,Qe,sfc_sublim_flag,sum_sfcsublim,& + & sum_swemelt,corr_factor,icorr_factor_index,swesublim,& + & swe_depth_old,canopy_int_old,KK,max_layers,melt_flag,& + & ro_snowmax,tsls_threshold,dz_snow_min,tslsnowfall,& + & change_layer,snod_layer,swed_layer,ro_layer,T_old,gamma,& + & multilayer_snowpack,seaice_run,seaice_conc,ht_windobs,& + & windspd_2m_grid,diam_layer,flux_layer,sum_trans) + + use snowmodel_inc + implicit none + + integer nx,ny,iter,i,j + + integer max_layers,multilayer_snowpack,k,n_tsteps_in_day,irec + integer KK(nx,ny) + integer melt_flag(nx,ny,nz_max) + + real ro_snowmax,tsls_threshold,dz_snow_min,Cp_snow + real tslsnowfall(nx,ny) + real change_layer(nx,ny) + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real gamma(nx,ny,nz_max) + real diam_layer(nx,ny,nz_max) + real flux_layer(nx,ny,nz_max) + + integer melt_flag_z(nz_max) + real snod_layer_z(nz_max) + real swed_layer_z(nz_max) + real ro_layer_z(nz_max) + real T_old_z(nz_max) + real gamma_z(nz_max) + real diam_z(nz_max) + real flux_z(nz_max) + + real Tair_grid(nx,ny) + real rh_grid(nx,ny) + real prec_grid(nx,ny) + real windspd_grid(nx,ny) + real windspd_2m_grid(nx,ny) + real Qsi_grid(nx,ny) + real vegtype(nx,ny) + real albedo(nx,ny) + real glacier_melt(nx,ny) + real canopy_unload(nx,ny) + real sum_unload(nx,ny) + real sum_glacmelt(nx,ny) + real sum_swemelt(nx,ny) + real swemelt(nx,ny) + real swesublim(nx,ny) + real snow_d_init(nx,ny) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real seaice_conc(nx,ny) + real sum_trans(nx,ny) + real ro_snow + + real, dimension(nx,ny) :: ro_nsnow,snow_d,& + & runoff,rain, & + & sprec,w_balance,& + & sum_prec,sum_runoff,& + & xro_snow,sfc_pressure,& + & ro_snow_grid,swe_depth,& + & Tsfc,Qm,& + & soft_snow_d,sum_sprec,& + & snow_depth,sum_Qcs,& + & canopy_int,Qcs,& + & d_canopy_int,sum_d_canopy_int,& + & Qe,sum_sfcsublim + + real dt,undef,Cp,xLf,Tf,A1,A2,ro_water,xLs,ro_ice,Twb,& + & run_snowtran,sfc_sublim_flag,seaice_run,ht_windobs + + real corr_factor(nx_max,ny_max,max_obs_dates+1) + real corr_factor_ij + integer icorr_factor_index(max_time_steps) + + integer, parameter :: nftypes = 5 + real forest_LAI(nftypes) + +! print *,' solving the snow-cover evolution' + +! Define the constants used in the computations. + CALL CONSTS_SNOWPACK(Cp,xLs,ro_ice,xLf,Tf,A1,A2,ro_water,& + & Cp_snow,ro_snowmax) + +! Run the snowpack evolution sub-model. + do j=1,ny + do i=1,nx + +! Extract the vertical column for this i,j point, and send it +! to the subroutine. *** Note that I should use f95, then I would +! not have to do this (I could pass in subsections of the arrays). + if (multilayer_snowpack.eq.1) then + do k=1,nz_max + melt_flag_z(k) = melt_flag(i,j,k) + snod_layer_z(k) = snod_layer(i,j,k) + swed_layer_z(k) = swed_layer(i,j,k) + ro_layer_z(k) = ro_layer(i,j,k) + T_old_z(k) = T_old(i,j,k) + gamma_z(k) = gamma(i,j,k) + diam_z(k) = diam_layer(i,j,k) + enddo + endif + +! Extract the correction factor from the data assimilation array +! so it can be passed into the SnowPack routines without the +! negative array index. + if (icorr_factor_index(iter).lt.0) then + k = -icorr_factor_index(iter) + corr_factor_ij = corr_factor(i,j,k) + else + corr_factor_ij = undef + endif + + CALL SNOWPACK_CORE(Twb,Tf,Tair_grid(i,j),rh_grid(i,j),xLs,& + & Cp,sfc_pressure(i,j),ro_nsnow(i,j),dt,ro_snow,& + & swe_depth(i,j),Tsfc(i,j),A1,A2,snow_d(i,j),ro_water,& + & ro_ice,prec_grid(i,j),runoff(i,j),Qm(i,j),xLf,rain(i,j),& + & sprec(i,j),iter,w_balance(i,j),sum_prec(i,j),& + & sum_runoff(i,j),xro_snow(i,j),undef,& + & soft_snow_d(i,j),sum_sprec(i,j),ro_snow_grid(i,j),& + & snow_depth(i,j),windspd_grid(i,j),Qsi_grid(i,j),& + & sum_Qcs(i,j),canopy_int(i,j),Qcs(i,j),vegtype(i,j),& + & forest_LAI,albedo(i,j),canopy_unload(i,j),& + & sum_unload(i,j),sum_glacmelt(i,j),run_snowtran,& + & swemelt(i,j),d_canopy_int(i,j),sum_d_canopy_int(i,j),& + & snow_d_init(i,j),Qe(i,j),glacier_melt(i,j),& + & sfc_sublim_flag,sum_sfcsublim(i,j),sum_swemelt(i,j),& + & corr_factor_ij,icorr_factor_index(iter),swesublim(i,j),& + & swe_depth_old(i,j),canopy_int_old(i,j),KK(i,j),& + & max_layers,melt_flag_z,ro_snowmax,tsls_threshold,& + & dz_snow_min,tslsnowfall(i,j),change_layer(i,j),snod_layer_z,& + & swed_layer_z,ro_layer_z,T_old_z,gamma_z,multilayer_snowpack,& + & Cp_snow,seaice_run,ht_windobs,windspd_2m_grid(i,j),& + & diam_z,flux_z) + +! Re-build the 3-D arrays. See note above about using f95 to avoid this. + if (multilayer_snowpack.eq.1) then + do k=1,nz_max + melt_flag(i,j,k) = melt_flag_z(k) + snod_layer(i,j,k) = snod_layer_z(k) + swed_layer(i,j,k) = swed_layer_z(k) + ro_layer(i,j,k) = ro_layer_z(k) + T_old(i,j,k) = T_old_z(k) + gamma(i,j,k) = gamma_z(k) + diam_layer(i,j,k) = diam_z(k) + flux_layer(i,j,k) = flux_z(k) + enddo + endif + + enddo + enddo + + if (run_snowtran.eq.0.0) then + do j=1,ny + do i=1,nx + swe_depth_old(i,j) = swe_depth(i,j) + canopy_int_old(i,j) = canopy_int(i,j) + enddo + enddo + endif + +! Read in the sea ice concentration. These are daily data, so +! first calculate which record in the data file this time step +! corresponds to. + if (seaice_run.ne.0.0) then + n_tsteps_in_day = nint(86400.0 / dt) + if (mod(iter-1,n_tsteps_in_day).eq.0) then + irec = int((real(iter) - 0.5) * dt / 86400.0) + 1 + print *,'sea ice irec =',irec + read (445,rec=irec) ((seaice_conc(i,j),i=1,nx),j=1,ny) + endif + endif + +! If this simulation is not running SnowTran-3D, then zero out +! the ocean grid cells that have no sea ice here. If it is +! running with SnowTran-3D, then do this in the SnowTran-3D +! subroutine. + if (run_snowtran.eq.0.0) then + if (seaice_run.ne.0.0) then + CALL ZERO_SEAICE_SNOW(nx,ny,snow_depth,ro_snow_grid,& + & ro_snow,swe_depth,swe_depth_old,canopy_int_old,KK,& + & tslsnowfall,snod_layer,swed_layer,ro_layer,T_old,& + & multilayer_snowpack,tsls_threshold,seaice_conc,& + & sum_sprec,sum_trans) + endif + endif + + return + end SUBROUTINE SNOWPACK_CODE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SNOWPACK_CORE(Twb,Tf,Tair,rh,xLs,& + & Cp,sfc_pressure,ro_nsnow,dt,ro_snow,& + & swe_depth,Tsfc,A1,A2,snow_d,ro_water,& + & ro_ice,prec,runoff,Qm,xLf,rain,& + & sprec,iter,w_balance,sum_prec,& + & sum_runoff,xro_snow,undef,& + & soft_snow_d,sum_sprec,ro_snow_grid,& + & snow_depth,windspd,Qsi,& + & sum_Qcs,canopy_int,Qcs,vegtype,& + & forest_LAI,albedo,canopy_unload,& + & sum_unload,sum_glacmelt,run_snowtran,& + & swemelt,d_canopy_int,sum_d_canopy_int,& + & snow_d_init,Qe,glacier_melt,& + & sfc_sublim_flag,sum_sfcsublim,sum_swemelt,& + & corr_factor,icorr_factor_index,swesublim,& + & swe_depth_old,canopy_int_old,KK,& + & max_layers,melt_flag,ro_snowmax,tsls_threshold,& + & dz_snow_min,tslsnowfall,change_layer,snod_layer,& + & swed_layer,ro_layer,T_old,gamma,multilayer_snowpack,& + & Cp_snow,seaice_run,ht_windobs,windspd_2m,& + & diam_layer,flux_layer) + + use snowmodel_inc + implicit none + + integer iter,icorr_factor_index + + integer KK,max_layers,multilayer_snowpack + + real ro_snowmax,tsls_threshold,dz_snow_min,tslsnowfall,Cp_snow + + integer melt_flag(nz_max) + real change_layer + real snod_layer(nz_max) + real swed_layer(nz_max) + real ro_layer(nz_max) + real T_old(nz_max) + real gamma(nz_max) + real diam_layer(nz_max) + real flux_layer(nz_max) + + real Twb,Tf,Tair,rh,xLs,Cp,ro_nsnow,dt,ro_snow,swe_depth,& + & Tsfc,A1,A2,snow_d,ro_water,ro_ice,prec,runoff,Qm,xLf,rain,& + & sprec,w_balance,sum_prec,sum_runoff,xro_snow,undef,& + & soft_snow_d,sum_sprec,ro_snow_grid,snow_depth,sprec_grnd,& + & windspd,Qsi,sum_Qcs,canopy_int,Qcs,canopy_unload,& + & vegtype,albedo,glacier_melt,sum_unload,sum_glacmelt,& + & run_snowtran,swemelt,d_canopy_int,sfc_pressure,& + & sum_d_canopy_int,snow_d_init,Qe,sfc_sublim_flag,& + & sum_sfcsublim,sum_swemelt,corr_factor,swesublim,& + & swe_depth_old,canopy_int_old,sprec_grnd_ml,seaice_run,& + & ro_nsnow_wind,ht_windobs,windspd_2m + + integer,parameter :: nftypes = 5 + real forest_LAI(nftypes) + +! Calculate the canopy sublimation, loading and unloading. Note +! that here I have assumed that trees are type 1-5. + if (vegtype.le.5.0) then + CALL CANOPY_SNOW(rh,Tair,windspd,Qsi,sum_Qcs,albedo,& + & canopy_int,sprec,Qcs,dt,canopy_unload,& + & forest_LAI(nint(vegtype)),sum_unload,d_canopy_int,& + & sum_d_canopy_int) + sprec_grnd = sprec + canopy_unload - d_canopy_int + sprec_grnd_ml = sprec - d_canopy_int + else + Qcs = 0.0 + sprec_grnd = sprec + sprec_grnd_ml = sprec + endif + +! Calculate the wind speed at 2 meters. + CALL WINDSPEED_2M(windspd,ht_windobs,windspd_2m) + +! Solve for the wet bulb temperature. + CALL SOLVEWB(Twb,Tf,Tair,rh,xLs,Cp,sfc_pressure) + +! Compute the new snow density. + CALL NSNOWDEN(ro_nsnow,Twb,Tf,dt) + +! Call the subroutine that increases the snow density due to +! blowing snow wind speeds during a snowfall event. Here we +! are only calculating a increment to the previous NSNOWDEN +! new snow density calculation. + CALL NSNOW_DENSITY_FROM_BLOWING_SNOW(windspd_2m,sprec,dt,& + & ro_nsnow_wind) + +! Update the new snow density with the wind contribution. + ro_nsnow = ro_nsnow + ro_nsnow_wind + +! Make sure the snow density falls within reasonable limits. + ro_nsnow = min(ro_nsnow,ro_snowmax) + +! Call the multi-layer snowpack model. + if (multilayer_snowpack.eq.1) then + + CALL MULTI_LAYER_SNOW(KK,ro_layer,Tf,dt,ro_water,& + & ro_ice,T_old,snod_layer,swed_layer,Qm,ro_snowmax,rain,& + & xLf,Cp_snow,melt_flag,runoff,tslsnowfall,ro_nsnow,& + & sprec,Tsfc,tsls_threshold,gamma,max_layers,change_layer,& + & dz_snow_min,snow_depth,swe_depth,undef,canopy_unload,& + & vegtype,glacier_melt,sum_glacmelt,sum_swemelt,snow_d,& + & Qe,sfc_sublim_flag,sum_sfcsublim,soft_snow_d,ro_snow,& + & sum_sprec,sprec_grnd_ml,sum_prec,prec,sum_runoff,& + & ro_snow_grid,xro_snow,swesublim,A1,A2,windspd_2m,& + & sfc_pressure,diam_layer,flux_layer,corr_factor,& + & icorr_factor_index) + +! Call the original single-layer snowpack model. + else + +! Compute the snow density change due to settling. + CALL DDENSITY(ro_snow_grid,swe_depth,Tf,Tsfc,dt,A1,A2,& + & snow_depth,ro_water,ro_snowmax) + +! Compute the melt, rain, and snow contributions to modifying +! the snowpack depth, density, and snow water equivalent. + CALL SNOWPACK(swe_depth,snow_d,ro_snow_grid,& + & prec,ro_water,ro_nsnow,runoff,Qm,xLf,dt,rain,sprec,& + & sum_prec,sum_runoff,soft_snow_d,sum_sprec,ro_snow,& + & snow_depth,sprec_grnd,vegtype,glacier_melt,sum_glacmelt,& + & swemelt,canopy_unload,Qe,sfc_sublim_flag,sum_sfcsublim,& + & sum_swemelt,corr_factor,icorr_factor_index,swesublim,& + & ro_snowmax) + +! Post process the data for output. + CALL POSTPROC(ro_snow_grid,xro_snow,snow_depth,undef) + + endif + +! Perform a water balance check (see notes in this subroutine). + if (seaice_run.eq.0.0) then + if (run_snowtran.eq.0.0) then + CALL WATERBAL_SNOWPACK(w_balance,prec,Qcs,runoff,& + & d_canopy_int,swe_depth,glacier_melt,swe_depth_old,iter,& + & swesublim,canopy_unload,canopy_int_old,canopy_int) + endif + endif + + return + end SUBROUTINE SNOWPACK_CORE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE CANOPY_SNOW(rh,Tair,windspd,Qsi,sum_Qcs,albedo,& + & canopy_int,sprec,Qcs,dt,canopy_unload,& + & forest_LAI,sum_unload,d_canopy_int,& + & sum_d_canopy_int) + + implicit none + + real rh,Tair,windspd,V_s,Qsi,forest_LAI,dt,xImax,canopy_int,& + & d_canopy_int,Qcs,Ce,sprec,C_0,unload_melt,canopy_unload,& + & sum_Qcs,albedo,sum_unload,sum_d_canopy_int + +! Note that all of this must deal with the (kg/m2)=(mm), => (m) +! issues. Precip is in (m), all of these equations are in +! (kg/m2), and I want the outputs to be in (m). + +! Compute the sublimation loss rate coefficient for canopy snow. + CALL SUBLIM_COEF(rh,Tair,windspd,V_s,Qsi,albedo) + +! Maximum interception storage. + xImax = 4.4 * forest_LAI + +! Change in canopy load due to snow precipitation during this time +! step. Convert the canopy interception to mm. + canopy_int = 1000.0 * canopy_int + d_canopy_int = 0.7 * (xImax - canopy_int) * & + & ( 1.0 - exp((- sprec)*1000.0/xImax)) + +! Update the interception load. + canopy_int = canopy_int + d_canopy_int + +! Canopy exposure coefficient. + if (canopy_int.eq.0.0) then + Ce = 0.0 + else +! Pomeroy's k_c value +! Ce = 0.0114 * (canopy_int/xImax)**(-0.4) +! My k_c value. + Ce = 0.00995 * (canopy_int/xImax)**(-0.4) + endif + +! Canopy sublimation (kg/m2), (a negative mumber). Make sure that +! you don't sublimate more than is available. + Qcs = Ce * canopy_int * V_s * dt + Qcs = -min(canopy_int,-Qcs) + +! Remove the sublimated moisture from the canopy store. + canopy_int = canopy_int + Qcs + +! Save the sublimation in (m). + Qcs = Qcs / 1000.0 + sum_Qcs = sum_Qcs + Qcs + +! Perform a second unloading due to melt. Assume an unloading rate +! of 5.0 mm/day/C. + C_0 = 5.0 / 86400.0 + unload_melt = C_0 * max(0.0,Tair-273.15) * dt + unload_melt = min(canopy_int,unload_melt) + canopy_int = canopy_int - unload_melt + +! Keep track of the unloaded snow that reached the ground during +! this time step (m) (this will add to the snow depth). + canopy_unload = unload_melt / 1000.0 + d_canopy_int = d_canopy_int / 1000.0 + +! Save a summing array of this unloaded snow. + sum_unload = sum_unload + canopy_unload + +! Save a summing array of the change in canopy load. + sum_d_canopy_int = sum_d_canopy_int + d_canopy_int + +! Save the interception load for the next time step. Convert to m. + canopy_int = canopy_int / 1000.0 + + return + end SUBROUTINE CANOPY_SNOW + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SUBLIM_COEF(rh,Tair,windspd,V_s,Qsi,albedo) + +! Compute the sublimation loss rate coefficient for canopy snow. + + implicit none + + real pi,ro_ice,xM,R,R_dryair,vonKarman,visc_air,h_s,xlamdaT,& + & D,ro_sat,sigma,V_s,radius,xmass,windspd,rh,Tair,Qsi,Sp,& + & xN_r,xNu,xSh,top,bottom,omega,albedo + +! Constants. + pi = 2.0 * acos(0.0) + ro_ice = 917.0 + xM = 18.01 + R = 8313. + R_dryair = 287. + vonKarman = 0.4 + visc_air = 13.e-6 + h_s = 2.838e6 + xlamdaT = 0.024 + +! Particle radius. + radius = 5.0e-4 + +! Particle mass. + xmass = 4.0/3.0 * pi * ro_ice * radius**3 + +! Diffusivity of water vapor in the atmosphere. + D = 2.06e-5 * (Tair/273.0)**(1.75) + +! Saturation density of water vapor. + ro_sat = 0.622 / (R_dryair * Tair) * & + & 611.15 * exp(22.452 * (Tair - 273.15) / (Tair - 0.61)) + +! Humidity deficit. + sigma = 0.01 * rh - 1.0 + sigma = min(0.0,sigma) + sigma = max(-1.0,sigma) + +! Reynolds, Nusselt, and Sherwood numbers. + xN_r = 2.0 * radius * windspd / visc_air + xNu = 1.79 + 0.606 * xN_r**(0.5) + xSh = xNu + +! Solar radiation absorbed by the snow particle. Here assume that +! the general snow albedo is the same as the snow particle albedo. + Sp = pi * radius**2 * (1.0 - albedo) * Qsi + +! Sublimation-loss rate coefficient for an ice sphere. + omega = ((h_s * xM)/(R * Tair) - 1.0) / (xlamdaT * Tair * xNu) + top = 2.0 * pi * radius * sigma - Sp * omega + bottom = h_s * omega + 1.0/(D * ro_sat * xSh) + V_s = (top/bottom)/xmass + + return + end SUBROUTINE SUBLIM_COEF + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE WATERBAL_SNOWPACK(w_balance,prec,Qcs,runoff,& + & d_canopy_int,swe_depth,glacier_melt,swe_depth_old,iter,& + & swesublim,canopy_unload,canopy_int_old,canopy_int) + + implicit none + + integer iter + + real w_balance,prec,Qcs,runoff,d_canopy_int,swe_depth_old,& + & swe_depth,glacier_melt,swesublim,canopy_unload,canopy_int_old,& + & canopy_int + +! Note that the following balances should hold. These aren't quite +! right, but it is a place to start. +! Canopy Balance (forest): +! canopy = sprec - unload + Qcs ==> unload = sprec - canopy + Qcs +! +! Snowpack Balance (forest): +! swe_d = unload + rain - runoff ==> +! canopy + swe_d = sprec + rain + Qcs - runoff +! prec = sprec + rain +! sum_rain = sum_sprec - sum_prec +! +! Snowpack Balance (non-forest): +! swe_d = sprec + rain - runoff + subl + salt + susp + subgrid + +! glaciermelt +! +! Everywhere: +! w_balance = sum_prec + sum_Qcs - sum_runoff + sum_subl + +! sum_trans - canopy_int - swe_depth + sum_glacmelt +! +! The related variables that would need to be brought in are: +! d_canopy_int,sum_d_canopy_int,sum_unload + +! This subroutine is called for the case where SnowTran-3D is not +! run. The subroutine WATERBAL_SNOWTRAN is used if the model +! simulation includes SnowTran-3D. +! w_balance = swe_depth_old - swe_depth + prec - runoff + +! & glacier_melt - swesublim + canopy_int_old - canopy_int - +! & d_canopy_int + Qcs + canopy_unload + +! Do the snowpack. +! w_balance = swe_depth_old - swe_depth + prec - runoff - +! & glacier_melt - swesublim + +! Do the canopy. +! w_balance = canopy_int_old - canopy_int + d_canopy_int + +! & Qcs - canopy_unload + +! Do the snowpack and canopy store. + w_balance = swe_depth_old - swe_depth + prec - runoff + & + & glacier_melt - swesublim + canopy_int_old - canopy_int + & + & Qcs + + if (abs(w_balance).gt.1.0e-5) & + & print*,'water imbalance found, iter =',iter,' ',w_balance + + return + end SUBROUTINE WATERBAL_SNOWPACK + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SNOWPACK(swe_depth,snow_d,ro_snow_grid,& + & prec,ro_water,ro_nsnow,runoff,Qm,xLf,dt,rain,sprec,& + & sum_prec,sum_runoff,soft_snow_d,sum_sprec,ro_snow,& + & snow_depth,sprec_grnd,vegtype,glacier_melt,sum_glacmelt,& + & swemelt,canopy_unload,Qe,sfc_sublim_flag,sum_sfcsublim,& + & sum_swemelt,corr_factor,icorr_factor_index,swesublim,& + & ro_snowmax) + + implicit none + + real ro_snowmax,runoff,Qm,swe_depth,potmelt,swemelt,dt,& + & ro_water,xLf,snow_depth,ro_snow_grid,snow_d_melt,dz_water,& + & soft_snow_d,prec,rain,snow_d,sum_sprec,sum_prec,& + & sum_runoff,ro_nsnow,sprec,ro_snow,snow_d_new,sprec_grnd,& + & vegtype,glacier_melt,sum_glacmelt,canopy_unload,Qe,& + & xLsublim,potsublim,swesublim,snow_d_sublim,sfc_sublim_flag,& + & sum_sfcsublim,sum_swemelt,corr_factor,potmelt_tmp + integer icorr_factor_index + + runoff = 0.0 + +! SURFACE SUBLIMATION. + +! Whether static-surface (non-blowing snow) sublimation is included +! in the model calculations is controlled by the sfc_sublim_flag. +! I am waiting for the flux-tower data Matthew and I are collecting +! in Alaska, to compare with the model simulations, before +! including this part of the model in all simulations. + +! If the sfc_sublim_flag is turned on, the latent heat flux (Qe) +! calculated in ENBAL is used to add/remove snow from the snowpack. +! xLsublim = xLf + xLv = 2.5104x10^6 J/kg + 3.334x10^5 J/kg, and +! potsublim is in m swe. + + if (swe_depth.gt.0.0 .and. sfc_sublim_flag.eq.1.0) then + if (Qe.lt.0.0) then + +! Compute the snow-surface sublimation (m, swe). + xLsublim = 2.844e6 + potsublim = (- dt) * Qe / (ro_water * xLsublim) + swesublim = min(potsublim,swe_depth) + +! Save a summing array of the static surface snow sublimation. + sum_sfcsublim = sum_sfcsublim + swesublim + +! Compute the change in snow depth. Assume that this sublimated +! snow does not change the snow density and does not change the +! soft snow depth. It only reduces the snow depth and the +! associated swe depth. + swe_depth = swe_depth - swesublim + if (swe_depth.eq.0.0) then + snow_depth = 0.0 + else + snow_d_sublim = swesublim * ro_water / ro_snow_grid + snow_depth = snow_depth - snow_d_sublim + endif + else + swesublim = 0.0 + endif + else + swesublim = 0.0 + endif + +! MELTING. + +! If melting occurs, decrease the snow depth, and place the melt +! water in the 'runoff' variable. Keep track of the liquid water +! produced. + + if (Qm.gt.0.0) then + +! Compute the snow melt (m). + potmelt = dt * Qm / (ro_water * xLf) + +! Account for any snowmelt data assimilation. + if (icorr_factor_index.lt.0) then + potmelt_tmp = potmelt * corr_factor + swemelt = min(potmelt_tmp,swe_depth) +! Handle the case of no snowmelt data assimilation. + else + swemelt = min(potmelt,swe_depth) + endif + +! Compute any glacier or permanent snow-field melt (m water equiv.). + if (vegtype.eq.20.0) then + glacier_melt = potmelt - swemelt + else + glacier_melt = 0.0 + endif + +! Save a summing array of the glacier melt. + sum_glacmelt = sum_glacmelt + glacier_melt + +! Save the runoff contribution. + runoff = runoff + glacier_melt + +! Save a summing array of the snow melt. + sum_swemelt = sum_swemelt + swemelt + +! Compute the change in snow depth. + snow_d_melt = swemelt * ro_water / ro_snow_grid + snow_depth = snow_depth - snow_d_melt + snow_depth = max(0.0,snow_depth) + +! Clip snow depth values that are within machine precision of +! zero. Add the clipped moisture to the swe_melt value to +! satisfy the moisture budget. + if (snow_depth.lt.1.0e-6) then + swemelt = swemelt + snow_depth + snow_depth = 0.0 + endif + +! Compute the changes in snow density resulting from the melt. +! Assume that the melted snow is redistributed through the new +! snow depth up to a maximum density. Any additional melt water +! is added to the runoff. + if (snow_depth.eq.0.0) then + ro_snow_grid = ro_snowmax + runoff = runoff + swemelt + else + ro_snow_grid = swe_depth * ro_water / snow_depth + endif + + if (ro_snow_grid.gt.ro_snowmax) then + dz_water = snow_depth * & + & (ro_snow_grid - ro_snowmax) / ro_water + ro_snow_grid = ro_snowmax + swe_depth = snow_depth * ro_snow_grid / ro_water + runoff = runoff + dz_water + else + swe_depth = snow_depth * ro_snow_grid / ro_water + endif + + soft_snow_d = 0.0 + + else + +! These prevent values from the previous time step from being +! carried through to the next time step. + swemelt = 0.0 + glacier_melt = 0.0 + + endif + +! PRECIPITATION. + +! Precipitation falling as rain on snow contributes to a snow +! density increase, precipitation falling as snow adds to the +! snow depth, and rain falling on bare ground contributes to the +! runoff. This latest version of this section follows Justin +! Pflug's code updates. + +! We have precipitation. + if (prec.gt.0.0) then + rain = prec - sprec + +! If there is snow on the ground, all of the precipitation (rain +! and snowfall) is added to the snowpack. If there is no +! snowpack, then snowfall builds a new snowpack, and rain goes +! into runoff. + if (snow_depth.gt.0.0) then + swe_depth = swe_depth + rain + sprec_grnd + else + swe_depth = sprec_grnd + runoff = runoff + rain + endif + +! Update the new snow depth, the total snow depth, and the snow +! density. + snow_d_new = ro_water / ro_nsnow * sprec_grnd + snow_depth = snow_depth + snow_d_new + if (snow_depth.gt.0.0) then + ro_snow_grid = ro_water * swe_depth / snow_depth + endif + +! If the density threshold is exceeded, adjust that and place the +! excess moisture in the runoff array. + if (ro_snow_grid.gt.ro_snowmax) then + dz_water = snow_depth * (ro_snow_grid - ro_snowmax) / ro_water + ro_snow_grid = ro_snowmax + swe_depth = snow_depth * ro_snow_grid / ro_water + runoff = runoff + dz_water + endif + +! Here we handle the case where there is no precipitation, but +! there is snow falling from the canopy to the snowpack. + else + rain = 0.0 + if (sprec_grnd.gt.0.0) then + swe_depth = swe_depth + sprec_grnd + snow_d_new = ro_water / ro_snow * sprec_grnd + snow_depth = snow_depth + snow_d_new + ro_snow_grid = ro_water * swe_depth / snow_depth + endif + endif + +! The following are set up to be compatible with SnowTran-3D, and +! are in snow-depth units. The sum_sprec corrections are done +! in the SnowTran-3D code. + +! Assume any rain sets the soft snow depth to zero. + if (rain.eq.0.0) then + soft_snow_d = soft_snow_d + sprec_grnd * ro_water / ro_snow + else + soft_snow_d = 0.0 + endif + + snow_d = swe_depth * ro_water / ro_snow + sum_sprec = sum_sprec + sprec_grnd + +! The following are in swe-depth units. + sum_prec = sum_prec + prec + sum_runoff = sum_runoff + runoff + + return + end SUBROUTINE SNOWPACK + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE DDENSITY(ro_snow_grid,swe_depth,Tf,Tsfc,dt,A1,A2,& + & snow_depth,ro_water,ro_snowmax) + + implicit none + + real snow_depth,Tsg,Tf,Tsnow,Tsfc,ro_snow_grid,dt,A1,A2,& + & swe_depth_star,ro_snowmax,ro_water,swe_depth,ro_adjust + +! ro_adjust is a snow density rate adjustment factor that can be +! used to make the snow density increase faster (ro_adjust > 1.0) +! or slower (ro_adjust < 1.0). + ro_adjust = 5.0 + + if (snow_depth.gt.0.0) then + +! Assume that the snow-ground interface temperature is -1.0 C. + Tsg = Tf - 1.0 + Tsnow = 0.5 * (Tsg + Tsfc) + swe_depth_star= 0.5 * swe_depth + ro_snow_grid = ro_snow_grid + ro_adjust * dt * & + & (A1 * swe_depth_star * ro_snow_grid * & + & exp((- 0.08)*(Tf-Tsnow)) * exp((- A2)*ro_snow_grid)) + ro_snow_grid = min(ro_snowmax,ro_snow_grid) + snow_depth = ro_water * swe_depth / ro_snow_grid + + endif + + return + end SUBROUTINE DDENSITY + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SOLVEWB(xnew,Tf,Tair,rh,xLs,Cp,sfc_pressure) + + implicit none + + real A,B,C,ea,rh,Tair,Tf,tol,old,fprime,xLs,Cp,funct,xnew,& + & sfc_pressure + + integer maxiter,i + +! Coeffs for saturation vapor pressure over water (Buck 1981). +! Note: temperatures for Buck`s equations are in deg C, and +! vapor pressures are in mb. Do the adjustments so that the +! calculations are done with temperatures in K, and vapor +! pressures in Pa. + +! Over water. + A = 6.1121 * 100.0 + B = 17.502 + C = 240.97 +! Over ice. +! A = 6.1115 * 100.0 +! B = 22.452 +! C = 272.55 + +! Atmospheric vapor pressure from relative humidity data. + ea = rh / 100.0 * A * exp((B * (Tair - Tf))/(C + (Tair - Tf))) + +! Solve for the wet bulb temperature. + tol = 1.0e-2 + maxiter = 20 + old = Tair + + do i=1,maxiter + fprime = 1.0 + xLs/Cp * 0.622/sfc_pressure * log(10.0) * & + & 2353. * (10.0**(11.40 - 2353./old)) / old**2 + funct = old - Tair + xLs/Cp * 0.622/sfc_pressure * & + & (10.0**(11.40-2353./old) - ea) + xnew = old - funct/fprime + if (abs(xnew - old).lt.tol) return + old = xnew + end do + +! If the maximum iterations are exceeded, send a message and set +! the wet bulb temperature to the air temperature. + write (*,102) + 102 format('max iteration exceeded when solving for Twb') + xnew = Tair + + return + end SUBROUTINE SOLVEWB + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE NSNOWDEN(ro_nsnow,Twb,Tf,dt) + + implicit none + + real Twgmax,Tf,Twb,ro_nsnow,scalefact,dt,wt + + Twgmax = Tf + 1.0 + if (Twb.ge.258.15 .and. Twb.le.Twgmax) then + ro_nsnow = 50. + 1.7 * (Twb - 258.15)**1.5 + elseif (Twb.lt.258.15) then + ro_nsnow = 50.0 + else + ro_nsnow = 158.8 + endif + +! For one day time steps, this equation gives a new snow density at +! the end of the 24 hour period which is too low, by an approximate +! factor of X. Thus, for a daily time step, I scale the density by +! X before returning it to the main program. + + scalefact = 1.0 + if (dt.eq.86400.0) then + if (ro_nsnow.le.158.8) then + wt = 1.0 + (50.0 - ro_nsnow) / 108.8 + ro_nsnow = wt * scalefact * ro_nsnow + ro_nsnow + ro_nsnow = min(158.8,ro_nsnow) + endif + endif + + return + end SUBROUTINE NSNOWDEN + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE POSTPROC(ro_snow_grid,xro_snow,snow_depth,undef) + + implicit none + + real snow_depth,xro_snow,undef,ro_snow_grid + + if (snow_depth.eq.0.0) then + xro_snow = undef + else + xro_snow = ro_snow_grid + endif + + return + end SUBROUTINE POSTPROC + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE CONSTS_SNOWPACK(Cp,xLs,ro_ice,xLf,Tf,A1,A2,ro_water,& + & Cp_snow,ro_snowmax) + + implicit none + + real Cp,xLs,ro_ice,xLf,Tf,A1,A2,ro_water,Cp_snow,ro_snowmax + + Cp = 1004. + xLs = 2.500e6 + ro_ice = 917.0 + xLf = 3.34e5 + Tf = 273.15 + A1 = 0.0013 + A2 = 0.021 + ro_water = 1000.0 + Cp_snow = 2106. + ro_snowmax = 550.0 + + return + end SUBROUTINE CONSTS_SNOWPACK + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE MULTI_LAYER_SNOW(KK,ro_layer,Tf,dt,ro_water,& + & ro_ice,T_old,snod_layer,swed_layer,Qm,ro_snowmax,rain,& + & xLf,Cp_snow,melt_flag,runoff,tslsnowfall,ro_nsnow,& + & sprec,Tsfc,tsls_threshold,gamma,max_layers,change_layer,& + & dz_snow_min,snow_depth,swe_depth,undef,canopy_unload,& + & vegtype,glacier_melt,sum_glacmelt,sum_swemelt,snow_d,& + & Qe,sfc_sublim_flag,sum_sfcsublim,soft_snow_d,ro_snow,& + & sum_sprec,sprec_grnd_ml,sum_prec,prec,sum_runoff,& + & ro_snow_grid,xro_snow,swesublim,A1,A2,windspd_2m,& + & sfc_pressure,diam_layer,flux_layer,corr_factor,& + & icorr_factor_index) + + use snowmodel_inc + implicit none + + integer KK,max_layers,k + integer melt_flag(nz_max) + + real snod_layer(nz_max) + real swed_layer(nz_max) + real ro_layer(nz_max) + real T_old(nz_max) + real gamma(nz_max) + real diam_layer(nz_max) + real flux_layer(nz_max) + real frac_liq(nz_max) + + real Tf,dt,ro_water,ro_ice,Qm,ro_snowmax,rain,xLf,Cp_snow,& + & runoff,tslsnowfall,ro_nsnow,sprec,Tsfc,tsls_threshold,& + & dz_snow_min,snow_depth,swe_depth,undef,change_layer,& + & canopy_unload,vegtype,glacier_melt,sum_glacmelt,sum_swemelt,& + & soft_snow_d,Qe,sfc_sublim_flag,sum_sfcsublim,snow_d,& + & ro_snow,sum_sprec,sprec_grnd_ml,sum_prec,prec,sum_runoff,& + & ro_snow_grid,xro_snow,swesublim,A1,A2,windspd_2m,& + & sfc_pressure,corr_factor + + integer icorr_factor_index + +! THIS IS THE MULTI-LAYER SNOWPACK MODEL. + +! Note there is some confusion with the dy - dz notation used here. +! In the multi-layer code 'y' is the vertical coordinate. This is +! a hold-over from a time when my temperature solution code had +! y going up-down. + +! Compute the snow density change due to compaction and the impact +! of wind on the top snow layer. + CALL DDENSITY_ML(ro_layer,Tf,dt,ro_water,ro_snowmax,& + & T_old,KK,snod_layer,A1,A2,windspd_2m) + +! Calculate the rainfall from prec and sprec. + if (prec.gt.0.0) then + rain = prec - sprec + else + rain = 0.0 + endif + +! Distribute surface melt and rain precipitation through the snowpack. + CALL MELT_SNOW_ML(KK,swed_layer,ro_water,ro_layer,Qm,dt,& + & snod_layer,ro_snowmax,rain,xLf,Cp_snow,Tf,T_old,melt_flag,& + & runoff,canopy_unload,swe_depth,snow_depth,vegtype,& + & glacier_melt,sum_glacmelt,sum_swemelt,soft_snow_d,Qe,& + & sfc_sublim_flag,sum_sfcsublim,swesublim,ro_snow,& + & corr_factor,icorr_factor_index) + +! Account for the accumulation of snow precipitation on the snowpack. + CALL PRECIP_ML(KK,ro_layer,snod_layer,ro_water,tslsnowfall,& + & swed_layer,ro_nsnow,T_old,Tsfc,tsls_threshold,dt,& + & melt_flag,soft_snow_d,ro_snow,sum_sprec,sprec_grnd_ml,& + & sum_prec,prec,sum_runoff,runoff,snow_d,snow_depth,swe_depth,& + & diam_layer) + +! Merge layers if the number of layers exceeds some maximum number of +! layers or if a layer gets thinner than some minimum thickness. + CALL MERGE_LAYERS_ML(KK,ro_layer,snod_layer,swed_layer,& + & T_old,ro_water,max_layers,change_layer,dz_snow_min,melt_flag,& + & diam_layer) + +! The grain-growth model can account for the liquid fraction in the +! snow. The model deals with three different wetness conditions +! differently: +! frac_liq < 1.0e-4 is considered dry +! 1.0e-4 <= frac_liq < 0.09 is considered wet +! frac_liq >= 0.09 is considered very wet +! Note that there is also a different vapor diffusion threshold +! that is also used (0.02). +! I have not implemented these yet, and for now assume that the +! snow is dry. + do k=1,KK + frac_liq(k) = 0.0 + enddo + +! Update the grain size using the SNTHERM equations. + CALL GET_GRAIN_SIZE_SNTHERM(KK,dt,ro_layer,undef,& + & diam_layer,frac_liq,T_old,snod_layer,Tf,sfc_pressure,& + & flux_layer) + +! Calculate the temperature of each snow layer. + CALL SNOWTEMP_ML(gamma,T_old,Tsfc,KK,dt,ro_layer,Cp_snow,& + & Tf,snod_layer,melt_flag,diam_layer) + +! Postprocess the data. + CALL POST_PROC_ML(KK,snod_layer,snow_depth,swe_depth,undef,& + & swed_layer,gamma,ro_layer,melt_flag,T_old,Tf,ro_snow_grid,& + & ro_water,xro_snow,ro_snow) + + return + end SUBROUTINE MULTI_LAYER_SNOW + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GET_GRAIN_SIZE_SNTHERM(nlayers,dt,ro_layer,undef,& + & diam_layer,frac_liq,T_layer,dz,Tf,press,& + & flux_layer) + +! Someday I need to make the above terminology consistent with the +! rest of the code (like that below). +! SUBROUTINE GET_GRAIN_SIZE_SNTHERM(KK,dt,ro_layer,diam_layer, +! & frac_liq,T_old,snod_layer,Tf,sfc_pressure) + +! This code follows Jordan 1991 (Tech Doc for SNTHERM.89; this is +! referenced as "SNTH89" in the comments below). The equations +! that are solved are those in the original SNTHERM89 code. + +! De0 : Effective diffusion coefficient for water vapor in +! snow (m^2/s) at 100000 Pa and 273.15K +! press : Barometric pressure (Pa) +! dc(nlayers) : Vapor diffusion coefficient for = de*change in +! saturation vapor pressure with temperature +! vapor_flux(nlayers) : Average diffusive flux at nodal centroid +! [(upper+lower)/2] (kg/m^2 s) +! T_layer(nlayers) : Temperature in center (node) of layer (K) +! g1 : Grain growth constant for dry snow (5.0e-7) +! g2 : Grain growth constant for wet snow (4.0e-12) +! diam : Nodal effective grain diameter (m) +! frac_liq : Volume fraction of liquid water +! dt : Time step (s) +! e0 : Saturation vapor pressure at 0 degrees C (mb) +! Rw : Gas constant for water vapor (461.5) (j/kg-K) +! ro_ice : Ice density (917.0) (kg/m^3) +! ro_snow(nlayers) : Nodal bulk snow density (kg/m^3) + + use snowmodel_inc + implicit none + +! integer k,KK + integer nlayers,k,nzm + + real diam_layer(nz_max) + real flux_layer(nz_max) + real ro_layer(nz_max) + real T_layer(nz_max) + real frac_liq(nz_max) + real dz(nz_max) + real porosity(nz_max) + real diff_coef(nz_max) + real C_kT(nz_max) + real vapor_flux(nz_max) + +! These are the values at the control volume boundaries. + real T_layer_bndry(nz_max+1) + real dz_bndry(nz_max+1) + real diff_coef_bndry(nz_max+1) + + real g1,g2,ro_ice,De0,Des,dt,Tf,press,grain_scale,pi,& + & xLvi_o_Rw,c1i,xLvw_o_Rw,c1w,vaporvol,Uv_bot,Uv_top,& + & diam_mm,undef + +! real e0,Rw,xLvw,xLvi + + data g1 /5.0e-7/ + data g2 /4.0e-12/ + data ro_ice /917.0/ + data De0 /9.2e-5/ + +! Calculate the vapor diffusion constants for water(w) and ice(i). +! These are constants, so I just save the values as data values. +! data e0 /613.6/ +! data Rw /461.5/ +! data xLvw /2.505e6/ +! data xLvi /2.838e6/ +! xLvw_o_Rw = xLvw / Rw +! c1w = e0 * exp(xLvw_o_Rw / Tf) / Rw +! xLvi_o_Rw = xLvi / Rw +! c1i = e0 * exp(xLvi_o_Rw / Tf) / Rw +! print *,xLvw_o_Rw +! print *,c1w +! print *,xLvi_o_Rw +! print *,c1i + + data xLvw_o_Rw /5427.952/ + data c1w /5.6739e8/ + data xLvi_o_Rw /6149.513/ + data c1i /7.9639e9/ + + pi = 2.0 * acos(0.0) + +! This 'grain_scale' controls allows the user additional control +! on the grain-growth calculations. Values greater than 1.0 +! grows grains faster, and values less than 1.0 grows grains +! slower. +! data grain_scale /1.0/ +! data grain_scale /0.5/ + data grain_scale /2.5/ + +! Initialize the flux output variable so the no-layer outputs make +! sense. + do k=1,nz_max + flux_layer(k) = undef + enddo + +! Define the snow porosity. + do k=1,nlayers + porosity(k) = 1.0 - (ro_layer(k) / ro_ice) + +! The only place this value should have problems is if ro_layer is +! undef. It should be well-constrained before getting to this +! subroutine. + if (porosity(k) .lt. 0.0) porosity(k) = 0.0 + enddo + +! Diffusion coefficient for each snow layer. + do k=1,nlayers + +! Eqn. 20 of SNTH89. + if (frac_liq(k) .gt. 0.02) then + C_kT(k) = c1w * exp(- xLvw_o_Rw / T_layer(k)) * & + & (xLvw_o_Rw / T_layer(k) - 1.0) / T_layer(k)**2 + else + C_kT(k) = c1i * exp(- xLvi_o_Rw / T_layer(k)) * & + & (xLvi_o_Rw / T_layer(k) - 1.0) / T_layer(k)**2 + endif + +! SNTH89 assumed the porosity does not affect the fluxes. SNTH89 +! had a note that said "The diffusive vapor flux in snow is +! customarily taken as independent of porosity, which is +! generally a consequence of the 'hand-to-hand' process of +! vapor diffusion." Conceptually, it seems like if the porosity +! goes to zero the fluxes should stop. I do that here. If you +! don't like this idea, you can just comment out these 3 lines. +! Scale the flux by the available vapor. + vaporvol = porosity(k) - frac_liq(k) + vaporvol = max(0.0,vaporvol) + C_kT(k) = vaporvol * C_kT(k) + +! Left part of Eqn. 21 of SNTH89. + Des = De0 * (100000.0 / press) * (T_layer(k) / Tf)**6 + +! Eqn. 21 of SNTH89. The vapor diffusion coefficents. + diff_coef(k) = Des * C_kT(k) + + if (diff_coef(k).le.0.0) then + print *,'diff_coef(k) <= 0.0',k,diff_coef(k) + print *,porosity(k),ro_layer(k) + endif + + enddo + +! Include the boundary information in the required arrays. This +! information, and the flux calcuations below, follow Glen's 3D +! thermal sea ice growth model code (see /nice/heat/temp_3d.f, +! or SeaIce-3D). + +! Number of shifted layers. + nzm = nlayers + 1 + +! Control volume size. + dz_bndry(1) = 0.0 + do k=2,nzm + dz_bndry(k) = dz(k-1) + enddo + dz_bndry(nzm+1) = 0.0 + +! do k=1,nzm+1 +! print *, k,dz_bndry(k) +! enddo + +! Temperature. + T_layer_bndry(1) = T_layer(1) + do k=2,nzm + T_layer_bndry(k) = T_layer(k-1) + enddo + T_layer_bndry(nzm+1) = T_layer(nzm-1) + +! do k=1,nzm+1 +! print *, k,T_layer_bndry(k) +! enddo + +! Diffusion coefficients. + diff_coef_bndry(1) = diff_coef(1) + do k=2,nzm + diff_coef_bndry(k) = diff_coef(k-1) + enddo + diff_coef_bndry(nzm+1) = diff_coef(nzm-1) + +! do k=1,nzm+1 +! print *, k,diff_coef_bndry(k) +! enddo + +! Calculate the vapor flux across the control volume walls (Eqn. +! 21 of SNTH89). This is: flux = - diff_coef * dT/dz, where +! diff_coef = Des * C_kT. See page 45 of Patankar (1980) for +! a description of what is being done with the harmonic mean +! calculations. Here I am solving Patankar's Eqn. 4.8, with +! delx_e- = 0.5*dx_P, and delx_e+ = 0.5*dx_E. + do k=2,nzm + + if (dz_bndry(k-1).eq.0.0 .and. dz_bndry(k).eq.0.0) then + Uv_bot = 0.0 + elseif (dz_bndry(k).eq.0.0 .and. dz_bndry(k+1).eq.0.0) then + Uv_top = 0.0 + else + Uv_bot = - 2.0 * (T_layer_bndry(k) - T_layer_bndry(k-1)) / & + & (dz_bndry(k-1) / diff_coef_bndry(k-1) + & + & dz_bndry(k) / diff_coef_bndry(k)) + Uv_top = - 2.0 * (T_layer_bndry(k+1) - T_layer_bndry(k)) / & + & (dz_bndry(k) / diff_coef_bndry(k) + & + & dz_bndry(k+1) / diff_coef_bndry(k+1)) + endif + +! Assume the flux at the center of the control volume is the average +! of the fluxes at the control volume walls. Also note that we +! don't care about the direction of the fluxes; we are just +! assuming that the vapor transport is growing grains, regardless +! of the direction. This is used in the grain growth algorithm. + vapor_flux(k-1) = (abs(Uv_bot) + abs(Uv_top)) / 2.0 + +! Save a record of the layer fluxes, including the direction of the +! flow. Here I am saving the flux across the top of each layer. +! Under the assumption that the flux across the bottom of the +! bottom layer is zero, this should be enough information to +! calculate d_flux/d_z and get the mass loss and/or gain in each +! layer. + flux_layer(k-1) = Uv_top + + enddo + +! Because the zero temperature gradient assumed at the boundaries +! is not realistic, set the boundary fluxes equal to those just +! inside the boundaries. + vapor_flux(1) = vapor_flux(2) + vapor_flux(nlayers) = vapor_flux(nlayers-1) + +! Because below we don't allow the abs(fluxes) to be over 1.0e-6, +! do the same thing here. + do k=1,nlayers + + if (flux_layer(k).lt.-1.0e-6) then + flux_layer(k) = -1.0e-6 + elseif (flux_layer(k).gt.1.0e-6) then + flux_layer(k) = 1.0e-6 + endif + +! Convert these to fluxes per dt (instead of per sec). Without +! this the values are something like 10^-11. + flux_layer(k) = dt * flux_layer(k) + + enddo + +! Update the snow grain diameter. + do k=1,nlayers + + if (diam_layer(k) .le. 0.0) then + print *, 'execution halted because diam_layer <= 0.0' + print *, 'layer = ',k,' diam_layer(k) =',diam_layer(k) + stop + endif + +! Dry snow: The cut-off bewteen dry and wet snow is arbitrarily +! set at 0.0001. + if (frac_liq(k) .lt. 1.0e-4) then + +! The max vapor flux available for growth is arbitrarily set at +! 1.0e-6. This can be increased if you want to allow larger +! grains to grow, if the temperature gradients are available to +! drive greater fluxes. Here I have also included a scaling +! term that can be used to increase or decrease the growth rate +! of the grains to better match any observational datasets you +! might have. Eqn. 33 of SNTH89. + if (abs(vapor_flux(k)) .lt. 1.0e-6) then + diam_layer(k) = diam_layer(k) + grain_scale * dt * g1 * & + & abs(vapor_flux(k)) / diam_layer(k) + else + diam_layer(k) = diam_layer(k) + grain_scale * dt * g1 * & + & 1.0e-6 / diam_layer(k) + endif + +! Wet snow: Different equations for liquid volume fraction +! above and below 0.09. + else + if (frac_liq(k) .lt. 0.09) then +! Eqn. 34a of SNTH89. + diam_layer(k) = diam_layer(k) + grain_scale * dt * g2 * & + & (frac_liq(k)+0.05) / diam_layer(k) + else +! Eqn. 34b of SNTH89. + diam_layer(k) = diam_layer(k) + grain_scale * dt * g2 * & + & 0.14 / diam_layer(k) + endif + endif + +! Max grain size set at 5mm, based on Arctic Alaska depth hoar +! observations (larger sizes are possible but not common). + if (diam_layer(k) .gt. 5.0e-3) diam_layer(k) = 5.0e-3 + + enddo + + return + end SUBROUTINE GET_GRAIN_SIZE_SNTHERM + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GETGAMMA(KK,ro_layer,gamma) + + use snowmodel_inc + implicit none + + integer k,KK + real ro_layer(nz_max) + real gamma(nz_max) + +! Compute the snow thermal conductivity (gamma) from the snow density. + do k=1,KK + if (ro_layer(k).lt.156.0) then + gamma(k) = 0.023 + 0.234 * (ro_layer(k)/1000.0) + else + gamma(k) = 0.138 - 1.01 * (ro_layer(k)/1000.0) + 3.233 * & + & (ro_layer(k)/1000.0)**2 + endif + enddo + + return + end SUBROUTINE GETGAMMA + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GET_THERMAL_CONDUCTIVITY(KK,ro_layer,diam_layer,gamma) + +! This program calculates the thermal conductivity for a given +! grain size. + +! The grain size here is provided in mm, and is assumed to range +! from 0.5 mm (wind slab) to 5.0 mm (depth hoar). + + use snowmodel_inc + implicit none + + integer k,KK + real ro_layer(nz_max) + real gamma(nz_max) + real diam_layer(nz_max) + + real cond_slab,cond_hoar,wt,x1,x2,xx + +! Convert the diameter limits from mm to m. + x1 = 0.5 / 1000.0 + x2 = 5.0 / 1000.0 + + do k=1,KK + if (ro_layer(k).lt.180.0) then + cond_slab = 3.94e-2 + 2.00e-4*ro_layer(k) + else + cond_slab = 1.55e-1 - 1.02e-3*ro_layer(k) + & + & 3.21e-6*ro_layer(k)**2 + endif + + cond_hoar = 3.00e-2 + 2.00e-4*ro_layer(k) + +! Calculate the weighting factors. + xx = diam_layer(k) + wt = (xx - x1) / (x2 - x1) + +! Calculate the thermal conductivity. + gamma(k) = wt * cond_hoar + (1.0 - wt) * cond_slab + + enddo + + return + end SUBROUTINE GET_THERMAL_CONDUCTIVITY + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE POST_PROC_ML(KK,snod_layer,snow_depth,swe_depth,undef,& + & swed_layer,gamma,ro_layer,melt_flag,T_old,Tf,ro_snow_grid,& + & ro_water,xro_snow,ro_snow) + + use snowmodel_inc + implicit none + + integer k,KK + + real snod_layer(nz_max) + real swed_layer(nz_max) + real gamma(nz_max) + real ro_layer(nz_max) + real T_old(nz_max) + integer melt_flag(nz_max) + + real snow_depth,swe_depth,undef,Tf,ro_snow_grid,ro_water,& + & xro_snow,ro_snow + +! Calculate the total snow and swe depth, and the bulk snow density. + snow_depth = 0.0 + swe_depth = 0.0 + do k=1,KK + snow_depth = snow_depth + snod_layer(k) + swe_depth = swe_depth + swed_layer(k) + enddo + if (snow_depth.le.0.0) then + ro_snow_grid = ro_snow + else + ro_snow_grid = swe_depth * ro_water / snow_depth + endif + +! Set any areas outside the snowpack to undef. + do k=KK+1,nz_max + gamma(k) = undef + ro_layer(k) = undef + T_old(k) = undef + Tf + melt_flag(k) = nint(undef) + snod_layer(k) = undef + swed_layer(k) = undef + enddo + +! Clean up the snow density array so there are no values when +! there is no snow. + if (snow_depth.eq.0.0) then + xro_snow = undef + else + xro_snow = ro_snow_grid + endif + + return + end SUBROUTINE POST_PROC_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE MERGE_LAYERS_ML(KK,ro_layer,snod_layer,swed_layer,& + & T_old,ro_water,max_layers,change_layer,dz_snow_min,melt_flag,& + & diam_layer) + + use snowmodel_inc + implicit none + + integer k,KK,kkk,k_small,max_layers,icount,kkkk + + real swed_layer(nz_max) + real ro_layer(nz_max) + real snod_layer(nz_max) + real T_old(nz_max) + real diam_layer(nz_max) + integer melt_flag(nz_max) + + real snod_layer_small,ro_water,dz_snow_min,change_layer + +! Merge layers if the number of layers exceeds some maximum number of +! layers or if a layer gets thinner than some minimum thickness. +! Do this in snow_depth space because that is the grid the snow +! temperatures are being calculated on. + +! If any layer is thinner than the minimum layer thickness, merge it +! with the layer below. If that layer is layer 1, merge it with +! layer 2. If there is only one layer left, let it be smaller than +! the minimum thickness. Don't do any of this if a new layer is +! being built; only do it for layers below the top layer. + change_layer = 0.0 + +! Count how many layers are less than the minimum thickness, excluding +! the case where there is only one layer. + icount = 0 + if (KK.gt.1) then +! do k=1,KK + do k=1,KK-1 + if (snod_layer(k).lt.dz_snow_min) then + icount = icount + 1 + endif + enddo + endif + +! Note that if two thin layers are together, the merge may take +! out the other one. + do k=1,icount + change_layer = 1.0 + +! This gets and processes the last occurance. +! do kkkk=1,KK + do kkkk=1,KK-1 + if (snod_layer(kkkk).lt.dz_snow_min) then + k_small = kkkk + endif + enddo + + if (k_small.eq.1) then + snod_layer(1) = snod_layer(1) + snod_layer(2) + swed_layer(1) = swed_layer(1) + swed_layer(2) + ro_layer(1) = swed_layer(1) * ro_water / snod_layer(1) + T_old(1) = T_old(2) + diam_layer(1) = diam_layer(2) + melt_flag(1) = melt_flag(2) + KK = KK - 1 + do kkk=2,KK + snod_layer(kkk) = snod_layer(kkk+1) + swed_layer(kkk) = swed_layer(kkk+1) + ro_layer(kkk) = swed_layer(kkk) * ro_water / snod_layer(kkk) + T_old(kkk) = T_old(kkk+1) + diam_layer(kkk) = diam_layer(kkk+1) + melt_flag(kkk) = melt_flag(kkk+1) + enddo + else + snod_layer(k_small-1) = snod_layer(k_small-1) + & + & snod_layer(k_small) + swed_layer(k_small-1) = swed_layer(k_small-1) + & + & swed_layer(k_small) + ro_layer(k_small-1) = swed_layer(k_small-1) * ro_water / & + & snod_layer(k_small-1) + T_old(k_small-1) = T_old(k_small) + diam_layer(k_small-1) = diam_layer(k_small) + melt_flag(k_small-1) = melt_flag(k_small) + KK = KK - 1 + do kkk=k_small,KK + snod_layer(kkk) = snod_layer(kkk+1) + swed_layer(kkk) = swed_layer(kkk+1) + ro_layer(kkk) = swed_layer(kkk) * ro_water / snod_layer(kkk) + T_old(kkk) = T_old(kkk+1) + diam_layer(kkk) = diam_layer(kkk+1) + melt_flag(kkk) = melt_flag(kkk+1) + enddo + endif + enddo + +! Where the number of layers exceeds some maximum number of layers, +! find the thinnest layer and merge it with the one below. For the +! case where the thinnest layer is the bottom layer, merge it with +! layer 2. + if (KK.eq.max_layers+1) then + change_layer = 1.0 +! Find the thinnest layer. + snod_layer_small = 1000.0 + do k=1,KK + if (snod_layer(k).lt.snod_layer_small) then + snod_layer_small = snod_layer(k) + k_small = k + endif + enddo + +! Adjust accordingly. Note that layers below the thin layer do not +! change, unless the thin layer is layer 1. Also, since the layer +! is thin, assign the new layer the thick layer temperature. + if (k_small.eq.1) then + snod_layer(1) = snod_layer(1) + snod_layer(2) + swed_layer(1) = swed_layer(1) + swed_layer(2) + ro_layer(1) = swed_layer(1) * ro_water / snod_layer(1) + T_old(1) = T_old(2) + diam_layer(1) = diam_layer(2) + melt_flag(1) = melt_flag(2) + KK = KK - 1 + do kkk=2,KK + snod_layer(kkk) = snod_layer(kkk+1) + swed_layer(kkk) = swed_layer(kkk+1) + ro_layer(kkk) = swed_layer(kkk) * ro_water / snod_layer(kkk) + T_old(kkk) = T_old(kkk+1) + diam_layer(kkk) = diam_layer(kkk+1) + melt_flag(kkk) = melt_flag(kkk+1) + enddo + else + snod_layer(k_small-1) = snod_layer(k_small-1) + & + & snod_layer(k_small) + swed_layer(k_small-1) = swed_layer(k_small-1) + & + & swed_layer(k_small) + ro_layer(k_small-1) = swed_layer(k_small-1) * ro_water / & + & snod_layer(k_small-1) + T_old(k_small-1) = T_old(k_small) + diam_layer(k_small-1) = diam_layer(k_small) + melt_flag(k_small-1) = melt_flag(k_small) + KK = KK - 1 + do kkk=k_small,KK + snod_layer(kkk) = snod_layer(kkk+1) + swed_layer(kkk) = swed_layer(kkk+1) + ro_layer(kkk) = swed_layer(kkk) * ro_water / snod_layer(kkk) + T_old(kkk) = T_old(kkk+1) + diam_layer(kkk) = diam_layer(kkk+1) + melt_flag(kkk) = melt_flag(kkk+1) + enddo + endif + endif + +! Now that we are done with change_layer, set it equal to k_small, +! the position of the change. + if (change_layer.eq.1.0) change_layer = real(k_small) + + return + end SUBROUTINE MERGE_LAYERS_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE MELT_SNOW_ML(KK,swed_layer,ro_water,ro_layer,Qm,dt,& + & snod_layer,ro_snowmax,rain,xLf,Cp_snow,Tf,T_old,melt_flag,& + & runoff,canopy_unload,swe_depth,snow_depth,vegtype,& + & glacier_melt,sum_glacmelt,sum_swemelt,soft_snow_d,Qe,& + & sfc_sublim_flag,sum_sfcsublim,swesublim,ro_snow,& + & corr_factor,icorr_factor_index) + + use snowmodel_inc + implicit none + + integer k,KK + + real swed_layer(nz_max) + real ro_layer(nz_max) + real snod_layer(nz_max) + real T_old(nz_max) + real swemelt,extra,ro_water,swe_space,add,runoff,ro_snowmax,& + & rain,delta_T,xLf,Cp_snow,extra_delta_T,Tf,dt,Qm,canopy_unload,& + & potmelt,swe_depth,snow_depth,vegtype,glacier_melt,& + & sum_glacmelt,sum_swemelt,soft_snow_d,Qe,sfc_sublim_flag,& + & xLsublim,potsublim,swesublim,sum_sfcsublim,ro_snow,& + & potmelt_tmp,corr_factor + + integer icorr_factor_index + + integer melt_flag(nz_max) + +! Initialize the runoff array. + runoff = 0.0 + +! SURFACE SUBLIMATION. + +! Whether static-surface (non-blowing snow) sublimation is included +! in the model calculations is controlled by the sfc_sublim_flag. +! I am waiting for the flux-tower data Matthew and I are collecting +! in Alaska, to compare with the model simulations, before +! including this part of the model in all simulations. + +! If the sfc_sublim_flag is turned on, the latent heat flux (Qe) +! calculated in ENBAL is used to add/remove snow from the snowpack. +! xLsublim = xLf + xLv = 2.5104x10^6 J/kg + 3.334x10^5 J/kg, and +! potsublim is in m swe. + + if (swe_depth.gt.0.0 .and. sfc_sublim_flag.eq.1.0) then + if (Qe.lt.0.0) then +! Compute the snow-surface sublimation (m, swe). + xLsublim = 2.844e6 + potsublim = (- dt) * Qe / (ro_water * xLsublim) + swesublim = min(potsublim,swe_depth) +! Save a summing array of the static surface snow sublimation. + sum_sfcsublim = sum_sfcsublim + swesublim + else + swesublim = 0.0 + endif + else + swesublim = 0.0 + endif + +! Modify the swe layer thicknesses, and reduce the number of layers +! if needed. + if (swesublim.gt.0.0) then +! Check to see whether this sublimation requires a layer reduction. + CALL REDUCE_LAYERS(swesublim,swed_layer,KK) + +! Build the new snow layer thicknesses, and recalculate the total +! snow and swe depths. Assume this sublimated snow does not +! change the snow density and does not change the soft snow depth. +! It only reduces the snow depth and the associated swe depth. + snow_depth = 0.0 + swe_depth = 0.0 + do k=1,KK + snod_layer(k) = swed_layer(k) * ro_water / ro_layer(k) + snow_depth = snow_depth + snod_layer(k) + swe_depth = swe_depth + swed_layer(k) + enddo + endif + +! MELTING. + + if (Qm.gt.0.0) then + +! Convert the melt energy to water equivalent melt depth (m). + potmelt = dt * Qm / (ro_water * xLf) + +! Account for any snowmelt data assimilation. + if (icorr_factor_index.lt.0) then + potmelt_tmp = potmelt * corr_factor + swemelt = min(potmelt_tmp,swe_depth) +! Handle the case of no snowmelt data assimilation. + else + swemelt = min(potmelt,swe_depth) + endif + +! Compute any glacier or permanent snow-field melt (m water equiv.). + if (vegtype.eq.20.0) then + glacier_melt = potmelt - swemelt + else + glacier_melt = 0.0 + endif + +! Save a summing array of the glacier melt. + sum_glacmelt = sum_glacmelt + glacier_melt + +! Save the runoff contribution. + runoff = runoff + glacier_melt + +! Save a summing array of the snow melt. + sum_swemelt = sum_swemelt + swemelt + +! In the presence of melt, zero out the soft snow layer. + soft_snow_d = 0.0 + + else + +! These prevent values from the previous time step from being +! carried through to the next time step. + swemelt = 0.0 + glacier_melt = 0.0 + + endif + +! Handle the case where rain and canopy_unload fall on snow-free +! ground (this is not included in the code below, nor in the +! PRECIP_ML subroutine, so I include it here). + if (swe_depth.eq.0.0) then + runoff = runoff + rain + canopy_unload + endif + +! Deal with melting snow. + + if (swemelt.gt.0.0) then +! Check to see whether this melt leads to a reduction in layers. + CALL REDUCE_LAYERS(swemelt,swed_layer,KK) + +! Build the new snow layer thicknesses, and initiate the melt_flag. + do k=1,KK + snod_layer(k) = swed_layer(k) * ro_water / ro_layer(k) + melt_flag(k) = 0 + enddo + endif + +! Add the melt, rain, and canopy unloading (assumed to be wet as rain) +! to the remaining snow layer thicknesses, up to the maximum snow +! density, and let the rest of the melt drain out the snowpack bottom +! as runoff. + extra = swemelt + rain + canopy_unload + if (extra.gt.0.0) then + do k=KK,1,-1 + if (extra.gt.0.0) then + swe_space = snod_layer(k) * (ro_snowmax - ro_layer(k)) / & + & ro_water + add = min(swe_space,extra) + swed_layer(k) = swed_layer(k) + add + extra = extra - add + endif + if (snod_layer(k).le.0.0) then + ro_layer(k) = ro_snow + else + ro_layer(k) = swed_layer(k) * ro_water / snod_layer(k) + endif + enddo + runoff = extra + endif + +! Also take into account the refreezing of this liquid in a cold +! snowpack. Assume that the liquid will fully warm each layer before +! moving on to the next layer. + extra = swemelt + rain + canopy_unload + if (extra.gt.0.0) then + do k=KK,1,-1 + if (extra.gt.0.0) then + +! Compute the change in temperature that would result if this liquid +! was used to freeze and raise the snow temperature. + if (snod_layer(k).le.0.0) then + delta_T = 0.0 + else + delta_T = (extra * xLf) / (Cp_snow * snod_layer(k)) + endif + +! Use this potential temperature change to adjust the snow +! temperature in the presence of the liquid. + T_old(k) = T_old(k) + delta_T + extra_delta_T = max(0.0,T_old(k)-Tf) + T_old(k) = min(T_old(k),Tf) + +! Keep track of which layers have been pushed to Tf. This will be +! used in the temperature solution subroutine to fix the snow +! temperature at Tf (if melt_flag = 1). + if (T_old(k).eq.Tf) then + melt_flag(k) = 1 + else + melt_flag(k) = 0 + endif + +! Define the amount of liquid this remaining temperature change +! represents, so it can be used in the layer below (that may be +! a different size). + extra = Cp_snow * snod_layer(k) * extra_delta_T / xLf + + endif + enddo + endif + + return + end SUBROUTINE MELT_SNOW_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE REDUCE_LAYERS(swemelt,swed_layer,KK) + + use snowmodel_inc + implicit none + + integer k,KK + real swed_layer(nz_max) + real eps,swemelt_tmp,swemelt,excess + + eps = 1e-6 + swemelt_tmp = swemelt + +! The use of eps here does not allow the vertical grid increment to +! be less that eps. + + do k=KK,1,-1 + excess = swed_layer(k) - swemelt_tmp + +! if (excess.gt.0.0) then + if (excess.gt.eps) then + swed_layer(k) = excess + KK = k + return +! elseif (excess.eq.0.0) then + elseif (excess.ge.0.0 .and. excess.le.eps) then + KK = k - 1 + return + else + swemelt_tmp = - excess + endif + enddo + +! If there is no snow left. + KK = 0 + + return + end SUBROUTINE REDUCE_LAYERS + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE PRECIP_ML(KK,ro_layer,snod_layer,ro_water,tslsnowfall,& + & swed_layer,ro_nsnow,T_old,Tsfc,tsls_threshold,dt,& + & melt_flag,soft_snow_d,ro_snow,sum_sprec,sprec_grnd_ml,& + & sum_prec,prec,sum_runoff,runoff,snow_d,snow_depth,swe_depth,& + & diam_layer) + + use snowmodel_inc + implicit none + + integer k,KK + + real snod_layer(nz_max) + real ro_layer(nz_max) + real swed_layer(nz_max) + real T_old(nz_max) + real diam_layer(nz_max) + real ro_nsnow,ro_water,z_nsnow,tsls_threshold,& + & z_snowtopl,sweq_topl,Tsfc,tslsnowfall,dt,soft_snow_d,ro_snow,& + & sum_sprec,sprec_grnd_ml,sum_prec,prec,sum_runoff,runoff,snow_d,& + & snow_depth,swe_depth + + integer melt_flag(nz_max) + +! If the melt from the previous subroutine reduced the snowpack +! to no snow, reset the time since last snowfall to the threshold, +! otherwise you will not build a new layer on the bare ground. + if (KK.eq.0) tslsnowfall = tsls_threshold + +! Create and/or modify the snow c.v.'s to account for new snowfall. + if (sprec_grnd_ml.gt.0.0) then + if (tslsnowfall.ge.tsls_threshold) then +! Create a new layer if snowfall has stopped for a period of time +! greater or equal to the defined threshold. + KK = KK + 1 + z_nsnow = ro_water / ro_nsnow * sprec_grnd_ml + snod_layer(KK) = z_nsnow + ro_layer(KK) = ro_nsnow + swed_layer(KK) = ro_layer(KK) * snod_layer(KK) / ro_water +! Define this new snow layer to have the surface temperature. + T_old(KK) = Tsfc +! Define this new layer to have the initial grain size (0.5 mm). + diam_layer(KK) = 0.5 / 1000.0 + + melt_flag(KK) = 0 + else +! Add to the existing top layer. + z_nsnow = ro_water / ro_nsnow * sprec_grnd_ml + z_snowtopl = snod_layer(KK) + z_nsnow + sweq_topl = sprec_grnd_ml + snod_layer(KK) * ro_layer(KK) / & + & ro_water + snod_layer(KK) = snod_layer(KK) + z_nsnow + ro_layer(KK) = ro_water * sweq_topl / z_snowtopl + swed_layer(KK) = ro_layer(KK) * snod_layer(KK) / ro_water + endif + +! Update the total swe and snow depths. + snow_depth = 0.0 + swe_depth = 0.0 + do k=1,KK + snow_depth = snow_depth + snod_layer(k) + swe_depth = swe_depth + swed_layer(k) + enddo + endif + +! Define the time since last snowfall, in hours. Handle the case +! where there is no snow on the ground. + if (sprec_grnd_ml.gt.0.0) then + tslsnowfall = 0.0 + else + tslsnowfall = tslsnowfall + dt / 3600.0 + endif + if (KK.eq.0) tslsnowfall = tsls_threshold + +! The following are set up to be compatible with SnowTran-3D, and +! are in snow-depth units. The sum_sprec corrections are done +! in the SnowTran-3D code. + soft_snow_d = soft_snow_d + sprec_grnd_ml * ro_water / ro_snow + snow_d = swe_depth * ro_water / ro_snow +! sum_sprec = sum_sprec + sprec_grnd_ml * ro_water / ro_snow + sum_sprec = sum_sprec + sprec_grnd_ml + +! The following are in swe-depth units. + sum_prec = sum_prec + prec + sum_runoff = sum_runoff + runoff + + return + end SUBROUTINE PRECIP_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE DDENSITY_ML(ro_layer,Tf,dt,ro_water,ro_snowmax,& + & T_old,KK,snod_layer,A1,A2,windspd_2m) + + use snowmodel_inc + implicit none + + integer k,KK,kkk + + real snod_layer(nz_max) + real ro_layer(nz_max) + real T_old(nz_max) + real sweqstar(nz_max) + real sweql(nz_max) + + real A1,A2,ro_water,ro_snowmax,dt,Tf,ro_adjust,C,U,alfa,& + & windspd_2m + +! Define the density rate coefficients. +! C = 1.00 + C = 0.50 +! C = 0.10 + +! Define alfa. + alfa = 0.2 + +! ro_adjust is a snow density rate adjustment factor that can be +! used to make the snow density increase faster (ro_adjust > 1.0) +! or slower (ro_adjust < 1.0). + ro_adjust = 5.0 + + if (KK.gt.0) then + + do k=1,KK + sweql(k) = ro_layer(k) / ro_water * snod_layer(k) + enddo + + do kkk=1,KK + sweqstar(kkk) = sweql(kkk) / 2.0 + do k=kkk+1,KK + sweqstar(kkk) = sweqstar(kkk) + sweql(k) + enddo + enddo + +! Pre-wind-adjustment code. +! do k=1,KK +! ro_layer(k) = ro_layer(k) + ro_adjust * dt * +! & (A1 * sweqstar(k) * ro_layer(k) * +! & exp(-0.08*(Tf-T_old(k))) * exp(-A2*ro_layer(k))) +! ro_layer(k) = min(ro_snowmax,ro_layer(k)) +! snod_layer(k) = sweql(k) * ro_water / ro_layer(k) +! enddo + +! Update the density of all the layers except the top layer. + do k=1,KK-1 + ro_layer(k) = ro_layer(k) + ro_adjust * dt * & + & (A1 * sweqstar(k) * ro_layer(k) * & + & exp(-0.08*(Tf-T_old(k))) * exp(-A2*ro_layer(k))) + ro_layer(k) = min(ro_snowmax,ro_layer(k)) + snod_layer(k) = sweql(k) * ro_water / ro_layer(k) + enddo + +! Update the density of the top layer while including the influence +! of wind in this layer only. This is Equation (18) for U in +! Liston et al. (2007). C here has just been an assigned an +! arbitrary value; it controls the impact of U on the density +! evolution. + k=KK + + if (windspd_2m.ge.5.0) then + U = C * & + & (5.0 + 15.0 * (1.0 - exp(-(alfa*(windspd_2m - 5.0))))) + else + U = 1.0 + endif +! If you want to turn this off, you can uncomment the following +! line. +! U = 1.0 + +! The equation below is the same as that for the below-surface +! layers, except for the addition of the U term. + ro_layer(k) = ro_layer(k) + ro_adjust * dt * & + & (U * A1 * sweqstar(k) * ro_layer(k) * & + & exp(-0.08*(Tf-T_old(k))) * exp(-A2*ro_layer(k))) + ro_layer(k) = min(ro_snowmax,ro_layer(k)) + snod_layer(k) = sweql(k) * ro_water / ro_layer(k) + + endif + + return + end SUBROUTINE DDENSITY_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SNOWTEMP_ML(gamma,T_old,Tsfc,KK,dt,ro_layer,Cp_snow,& + & Tf,snod_layer,melt_flag,diam_layer) + + use snowmodel_inc + implicit none + + real gamma(nz_max) + real diam_layer(nz_max) + real ro_layer(nz_max) + real snod_layer(nz_max) + real g_b_ns(nz_max+1) + real f_n(nz_max+1) + real aN(nz_max) + real aP0(nz_max) + real aS(nz_max) + real dely_p(nz_max+1) + real dy_p(nz_max) + real y_crds(nz_max+2) + real y_wall(nz_max+1) + real A_sub(nz_max) + real A_super(nz_max) + real A_main(nz_max) + real b_vector(nz_max) + real T_old(nz_max) + real Sc(nz_max) + real Sp(nz_max) + + integer melt_flag(nz_max) + + integer k,KK + real Tsfc,T_N,bc_N,bc_S,Cp_snow,Tf,dt,Tsg + +! Define the snow thermal conductivity (gamma) for each layer. +! CALL GETGAMMA(KK,ro_layer,gamma) + +! This is the thermal conductivity that depends on grain size. + CALL GET_THERMAL_CONDUCTIVITY(KK,ro_layer,diam_layer,gamma) + + if (KK.gt.1) then + +! Update the control volume information. + CALL GETCV(KK,dy_p,snod_layer) + CALL CV_INFO(dely_p,f_n,y_crds,y_wall,dy_p,KK) + +! Compute the general equation coefficients. + CALL GAMMA1(g_b_ns,gamma,f_n,KK) + CALL GE_COEF(aN,aS,aP0,dy_p,dely_p,g_b_ns,dt,KK,& + & ro_layer,Cp_snow) + +!--------------------------------------------------------------------- +!--------------------------------------------------------------------- +! Account for the boundary conditions. +! South boundary condition: +! For T_S = known, define +! bc_S = aS(1) * T_S; where T_S = known +! For dT_S/dn = 0, define +! bc_S = 0.0 +! aS(1) = 0.0 +! North boundary condition: +! For T_N = known, define +! bc_N = aN(KK) * T_N; where T_N = known +! For dT_N/dn = 0, define +! bc_N = 0.0 +! aN(KK) = 0.0 +!--------------------------------------------------------------------- +!--------------------------------------------------------------------- + +! Define the upper and lower boundary conditions. + T_N = Tsfc + bc_N = aN(KK) * T_N + bc_S = 0.0 + aS(1) = 0.0 + +! Provide the source terms. + +! Force the source terms to produce Tf at the positions where melting +! occurred during this time step. + do k=1,KK + if (melt_flag(k).eq.1) then + Sc(k) = 10e30 * Tf + Sp(k) = -10e30 + else + Sc(k) = 0.0 + Sp(k) = 0.0 + endif + enddo + +! Configure the information for the matrix solver. + CALL PREPSOLVE(A_sub,A_super,A_main,b_vector,T_old,& + & dy_p,bc_S,bc_N,Sc,Sp,aN,aS,aP0,KK) + +! Solve the system of equations. + CALL TRISOLVE(T_old,A_sub,A_main,A_super,b_vector,KK) + + elseif (KK.eq.1) then +! Assume that the snow-ground interface temperature is -1.0 C. + Tsg = Tf - 1.0 + T_old(1) = 0.5 * (Tsg + Tsfc) + endif + + return + end SUBROUTINE SNOWTEMP_ML + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GETCV(KK,dy_p,snod_layer) + + use snowmodel_inc + implicit none + + real dy_p(nz_max) + real snod_layer(nz_max) + + integer k,KK + +! Provide values of Control Volume size in the y direction. + do k=1,KK + dy_p(k) = snod_layer(k) + enddo + + return + end SUBROUTINE GETCV + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE PREPSOLVE(A_sub,A_super,A_main,b_vector,T_old,& + & dy_p,bc_S,bc_N,Sc,Sp,aN,aS,aP0,KK) + + use snowmodel_inc + implicit none + + real aP(nz_max) + real aN(nz_max) + real aS(nz_max) + real Sp(nz_max) + real Sc(nz_max) + real aP0(nz_max) + real dy_p(nz_max) + real T_old(nz_max) + real b_vector(nz_max) + real A_sub(nz_max) + real A_super(nz_max) + real A_main(nz_max) + + integer k,KK + real bc_S,bc_N + +! Compute matrix diagonal and b coeffs. + do k=1,KK + aP(k) = aN(k) + aS(k) + aP0(k) - Sp(k) * dy_p(k) + b_vector(k) = Sc(k) * dy_p(k) + aP0(k) * T_old(k) + enddo + +! Modify b to account for dirichlet boundary conditions. + b_vector(1) = b_vector(1) + bc_S + b_vector(KK) = b_vector(KK) + bc_N + +! Prepare to call the tridiagonal solver. + do k=1,KK-1 + A_sub(k) = - aS(k+1) + A_super(k) = - aN(k) + enddo + + do k=1,KK + A_main(k) = aP(k) + enddo + + return + end SUBROUTINE PREPSOLVE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE CV_INFO(dely_p,f_n,y_crds,y_wall,dy_p,KK) + + use snowmodel_inc + implicit none + + real dy_pbc(nz_max+2) + real dely_p(nz_max+1) + real f_n(nz_max+1) + real dy_p(nz_max) + real y_crds(nz_max+2) + real y_wall(nz_max+1) + + integer k,KK + real temp + +! PRESSURE CONTROL VOLUME SIZE AND POSITION INFORMATION + +! Include exterior boundary pressure grid points. + dy_pbc(1) = 0.0 + do k=2,KK+1 + dy_pbc(k) = dy_p(k-1) + enddo + dy_pbc(KK+2) = 0.0 + +! Compute the distance between pressure grid points. + do k=1,KK+1 + dely_p(k) = .5 * (dy_pbc(k) + dy_pbc(k+1)) + enddo + +! Compute the distance between the pressure grid points and the control +! volume wall. (The following is true because the grid points do +! pressure are defined to be in the center of the control volume.) +! And then compute f_e and f_n. These two steps are combined below. + do k=1,KK+1 + f_n(k) = .5 * dy_pbc(k+1) / dely_p(k) + enddo + +! Compute the x and y coordinates of the pressure c.v. grid points, +! including boundaries. + temp = 0.0 + do k=1,KK+2 + y_crds(k) = temp + .5 * dy_pbc(k) + temp = temp + dy_pbc(k) + enddo + +! Compute the x and y coordinates of the pressure c.v. walls. + y_wall(1) = 0.0 + do k=2,KK+1 + y_wall(k) = y_wall(k-1) + dy_p(k-1) + enddo + + return + end SUBROUTINE CV_INFO + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GAMMA1(g_b_ns,gamma,f_n,KK) + + use snowmodel_inc + implicit none + + real g_b_ns(nz_max+1) + real gamma(nz_max) + real g_ns(nz_max+2) + real f_n(nz_max+1) + + integer k,KK + +! This provides gamma information on c.v. walls. + +! Include gamma just outside of n, s boundaries. + g_ns(1) = gamma(1) + do k=2,KK+1 + g_ns(k) = gamma(k-1) + enddo + g_ns(KK+2) = gamma(KK) + +! Compute gamma (diffusion coefficient) at the n, s control +! volume boundaries using equation 4.9, p. 45. + do k=1,KK+1 + g_b_ns(k) = 1.0/((1.0 - f_n(k))/g_ns(k) + f_n(k)/g_ns(k+1)) + enddo + + return + end SUBROUTINE GAMMA1 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE GE_COEF(aN,aS,aP0,dy_p,dely_p,g_b_ns,dt,KK,& + & ro_layer,Cp_snow) + + use snowmodel_inc + implicit none + + real aN(nz_max) + real aS(nz_max) + real aP0(nz_max) + real dely_p(nz_max+1) + real g_b_ns(nz_max+1) + real dy_p(nz_max) + real ro_layer(nz_max) + + integer k,KK + real Cp_snow,dt + +! CALCULATE THE COEFFICIENTS aP, for the general phi equation. + do k=2,KK+1 + aN(k-1) = g_b_ns(k) / dely_p(k) + aS(k-1) = g_b_ns(k-1) / dely_p(k-1) + enddo + + do k=1,KK + aP0(k) = ro_layer(k) * Cp_snow * dy_p(k) / dt + enddo + + return + end SUBROUTINE GE_COEF + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE TRISOLVE(x,asub,amain,asuper,b,KK) + + use snowmodel_inc + implicit none + + real asub(nz_max) + real asuper(nz_max) + real amain(nz_max) + real b(nz_max) + real x(nz_max) + real z(nz_max) + real lmain(nz_max) + real lsub(nz_max) + real usuper(nz_max) + + integer k,KK + + lmain(1) = amain(1) + usuper(1) = asuper(1)/lmain(1) + + do k=2,KK-1 + lsub(k-1) = asub(k-1) + lmain(k) = amain(k) - lsub(k-1) * usuper(k-1) + usuper(k) = asuper(k) / lmain(k) + enddo + + lsub(KK-1) = asub(KK-1) + lmain(KK) = amain(KK) - lsub(KK-1) * usuper(KK-1) + z(1) = b(1) / lmain(1) + + do k=2,KK + z(k) = 1.0 / lmain(k) * (b(k) - lsub(k-1) * z(k-1)) + enddo + + x(KK) = z(KK) + + do k=KK-1,1,-1 + x(k) = z(k) - usuper(k) * x(k+1) + enddo + + return + end SUBROUTINE TRISOLVE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ZERO_SNOW(nx,ny,snow_depth,ro_snow_grid,ro_snow,& + & swe_depth,swe_depth_old,canopy_int_old,KK,sum_swemelt,& + & tslsnowfall,snod_layer,swed_layer,ro_layer,T_old,& + & sum_sprec,multilayer_snowpack,tsls_threshold,& + & sum_trans) + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,k + + integer multilayer_snowpack + integer KK(nx,ny) + + real tsls_threshold,ro_snow + real tslsnowfall(nx,ny) + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real swe_depth(nx,ny) + real snow_depth(nx,ny) + real ro_snow_grid(nx,ny) + real sum_sprec(nx,ny) + real sum_swemelt(nx,ny) + real sum_trans(nx,ny) + + print *,'ZEROING OUT THE SNOW ARRAYS' + print *,'ZEROING OUT THE SNOW ARRAYS' + print *,'ZEROING OUT THE SNOW ARRAYS' + + do j=1,ny + do i=1,nx + canopy_int_old(i,j) = 0.0 + swe_depth_old(i,j) = 0.0 + snow_depth(i,j) = 0.0 + ro_snow_grid(i,j) = ro_snow + swe_depth(i,j) = 0.0 + sum_sprec(i,j) = 0.0 + sum_swemelt(i,j) = 0.0 + sum_trans(i,j) = 0.0 + enddo + enddo + + if (multilayer_snowpack.eq.1) then + do j=1,ny + do i=1,nx + tslsnowfall(i,j) = tsls_threshold + do k=1,KK(i,j) + snod_layer(i,j,k) = 0.0 + swed_layer(i,j,k) = 0.0 + ro_layer(i,j,k) = ro_snow + T_old(i,j,k) = 273.15 + enddo + KK(i,j) = 0 + enddo + enddo + endif + + return + end SUBROUTINE ZERO_SNOW + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ZERO_SNOW_SEAICE_4(nx,ny,snow_depth,ro_snow_grid,& + & ro_snow,swe_depth,swe_depth_old,canopy_int_old,KK,& + & sum_swemelt,tslsnowfall,snod_layer,swed_layer,& + & ro_layer,T_old,sum_sprec,multilayer_snowpack,& + & tsls_threshold,iyear,diam_layer,output_path_wo_assim) + +! NOTE: This program is VERY specific to the original Lagrangian +! simulations. If you are doing something else, you will have to +! make numerous changes to this code and the subroutines that are +! called from it. + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,k,iyear,icount + + parameter (icount=70000) + + integer multilayer_snowpack + integer KK(nx,ny) + + real tsls_threshold,ro_snow + real tslsnowfall(nx,ny) + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real swe_depth(nx,ny) + real snow_depth(nx,ny) + real ro_snow_grid(nx,ny) + real sum_sprec(nx,ny) + real sum_swemelt(nx,ny) + real diam_layer(nx,ny,nz_max) + + real snod_init(icount) + real swed_init(icount) + real sden_init(icount) + + character*80 output_path_wo_assim + + print *,'TRANSFERRING THE SNOW DATA TO THE NEXT YEAR' + print *,'TRANSFERRING THE SNOW DATA TO THE NEXT YEAR' + print *,'TRANSFERRING THE SNOW DATA TO THE NEXT YEAR' + +! Calculate the snow data initial conditions that will be used +! in the next year. + CALL SUPERIMPOSED_ICE(iyear,output_path_wo_assim,& + & snod_init,swed_init,sden_init,ro_snow) + + do j=1,ny + do i=1,nx + + canopy_int_old(i,j) = 0.0 + swe_depth_old(i,j) = 0.0 + snow_depth(i,j) = 0.0 + ro_snow_grid(i,j) = ro_snow + swe_depth(i,j) = 0.0 + sum_sprec(i,j) = 0.0 + sum_swemelt(i,j) = 0.0 + + if (snod_init(i).ge.0.0) then + swe_depth_old(i,j) = swed_init(i) + snow_depth(i,j) = snod_init(i) + ro_snow_grid(i,j) = sden_init(i) + swe_depth(i,j) = swed_init(i) + endif + + enddo + enddo + + if (multilayer_snowpack.eq.1) then + do j=1,ny + do i=1,nx + tslsnowfall(i,j) = tsls_threshold + do k=1,KK(i,j) + snod_layer(i,j,k) = 0.0 + swed_layer(i,j,k) = 0.0 + ro_layer(i,j,k) = ro_snow + T_old(i,j,k) = 273.15 + diam_layer(i,j,k) = 0.5 / 1000.0 + enddo + + if (snod_init(i).ge.0.0) then + KK(i,j) = 1 + snod_layer(i,j,1) = snod_init(i) + swed_layer(i,j,1) = swed_init(i) + ro_layer(i,j,1) = sden_init(i) + T_old(i,j,1) = 273.15 + diam_layer(i,j,1) = 0.5 / 1000.0 + else + KK(i,j) = 0 + endif + + enddo + enddo + endif + + return + end SUBROUTINE ZERO_SNOW_SEAICE_4 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE ZERO_SEAICE_SNOW(nx,ny,snow_depth,ro_snow_grid,& + & ro_snow,swe_depth,swe_depth_old,canopy_int_old,KK,& + & tslsnowfall,snod_layer,swed_layer,ro_layer,T_old,& + & multilayer_snowpack,tsls_threshold,seaice_conc,& + & sum_sprec,sum_trans) + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,k + + integer multilayer_snowpack + integer KK(nx,ny) + + real tsls_threshold,ro_snow + real tslsnowfall(nx,ny) + real snod_layer(nx,ny,nz_max) + real swed_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real swe_depth_old(nx,ny) + real canopy_int_old(nx,ny) + real swe_depth(nx,ny) + real snow_depth(nx,ny) + real ro_snow_grid(nx,ny) + real seaice_conc(nx,ny) + real sum_sprec(nx,ny) + real sum_trans(nx,ny) + + do j=1,ny + do i=1,nx + if (seaice_conc(i,j).eq.0.0) then + canopy_int_old(i,j) = 0.0 + swe_depth_old(i,j) = 0.0 + snow_depth(i,j) = 0.0 + ro_snow_grid(i,j) = ro_snow + swe_depth(i,j) = 0.0 + sum_sprec(i,j) = 0.0 + sum_trans(i,j) = 0.0 + endif + enddo + enddo + + if (multilayer_snowpack.eq.1) then + do j=1,ny + do i=1,nx + if (seaice_conc(i,j).eq.0.0) then + tslsnowfall(i,j) = tsls_threshold + do k=1,KK(i,j) + snod_layer(i,j,k) = 0.0 + swed_layer(i,j,k) = 0.0 + ro_layer(i,j,k) = ro_snow + T_old(i,j,k) = 273.15 + enddo + KK(i,j) = 0 + endif + enddo + enddo + endif + + return + end SUBROUTINE ZERO_SEAICE_SNOW + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE NSNOW_DENSITY_FROM_BLOWING_SNOW(windspd_2m,sprec,dt,& + & ro_nsnow_wind) + + implicit none + + real alfa,windspd_2m,ro_nsnow_wind,sprec,dt_24hours,dt + +! Required constants. + alfa = 0.2 + dt_24hours = 86400.0 + +! This new snow density increase due to wind, is only for the single- +! layer snowpack. + if (sprec.gt.0.0) then + +! To define the offset I assumed under cold conditions (ro_nsnow = +! 50.0 kg/m3): +! 1) 24-hour ave wind speed >= 20 m/s gives ro_nsnow = 350 kg/m3. +! 2) 24-hour ave wind speed = 5 m/s gives ro_nsnow = 150 kg/m3, +! (actually what really matters here is the density difference +! of 200 kg/m3 for the wind speed difference from 5 to 20 m/s). +! 3) 24-hour ave wind speed < 5 m/s gives ro_nsnow = ro_nsnow. +! 4) It is appropriate to use an exponential decay function +! between the 5 and 20 m/s values. + if (windspd_2m.lt.5.0) then + ro_nsnow_wind = 0.0 + else + ro_nsnow_wind = 25.0 + & + & 250.0 * (1.0 - exp(-(alfa*(windspd_2m - 5.0)))) + +! Now scale this 24-hour value by dt. I checked, and this is the +! perfect way to do this. It makes the 3-hour and 24-hour dt +! cases identical! +! In the end I decided to not do this scaling because the resulting +! snow depth is scaled at this time step by the precipitation +! inputs, and because I think the wind speed is the main +! controlling factor, not the duration of the wind at this speed. +! ro_nsnow_wind = dt / dt_24hours * ro_nsnow_wind + endif + + else + + ro_nsnow_wind = 0.0 + + endif + +! If you want to turn this off, you can uncomment the following +! line. +! ro_nsnow_wind = 0.0 + + return + end SUBROUTINE NSNOW_DENSITY_FROM_BLOWING_SNOW + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE WINDSPEED_2M(windspd,ht_windobs,windspd_2m) + + implicit none + + real ht_windobs,snow_z0,windspd,windspd_2m + +! Required constants. + snow_z0 = 0.001 + +! Calculate the 2-m wind speed. + windspd_2m = windspd * & + & log(2.0/snow_z0)/log(ht_windobs/snow_z0) + + return + end SUBROUTINE WINDSPEED_2M + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + SUBROUTINE SUPERIMPOSED_ICE(iyear,output_path_wo_assim,& + & snod_col_init2,swed_col_init2,sden_col_init1,ro_snow) + +! Here I am going to sweep through June and July and determine +! whether the snowpack ever became isothermal during this +! period. + + implicit none + + integer k,iend_year,iyear,i,j,ii,jj + +! Number of tracked parcels. + integer, parameter :: icount = 70000 + + integer, parameter :: nnx=361,nny=361 + + character*80 output_path_wo_assim + +! Parcels. + real roff_col(icount) + real snod_col(icount) + real swed_col(icount) + real conc_col(icount) + real simp_col(icount) + real snod_col_init1(icount) + real snod_col_init2(icount) + real swed_col_init1(icount) + real swed_col_init2(icount) + real sden_col_init1(icount) + + real zi(icount) + real zj(icount) + real conc(icount) + +! EASE grid. + real snod1(nnx,nny) + real snod2(nnx,nny) + real swed1(nnx,nny) + + integer iyr_start,imo_start,idy_start,imo_end,idy_end,iiyear,& + & ioptn,julian_end,julian_start,irec,imo_beg,idy_beg,irec1,& + & irec2,irec3,julian_beg,i_len_wo,trailing_blanks,istart_year + + real undef,ro_snow + +! Parcel tracks and concentration from NSIDC. + character path3*(*) + parameter (path3= & + & '../../parcel_tracks/3_mk_daily/') + +! SnowModel run outputs on original parcels. +! character path1*(*) +! parameter (path1 = '/data4/lagrangian/sm_38yrs/merra/outputs/') + i_len_wo = 80 - trailing_blanks(output_path_wo_assim) + + undef = -9999.0 + + iend_year = 2018 + istart_year = 1981 + + iiyear = iyear - istart_year + 1 + +! Open the parcel track data. + if (iyear.eq.istart_year) then + open (7021,file=path3//'ij_parcels_1980-2018.gdat', & + & form='unformatted',access='direct',recl=4*2*icount) + + open (7022,file=path3//'conc_parcels_1980-2018.gdat',& + & form='unformatted',access='direct',recl=4*1*icount) + endif + +! Input files. +! open (7031,file=output_path_wo_assim(1:i_len_wo)//'roff.gdat', +! & form='unformatted',access='direct',recl=4*icount) + +! open (7032,file=output_path_wo_assim(1:i_len_wo)//'snod.gdat', +! & form='unformatted',access='direct',recl=4*icount) + +! open (7033,file=output_path_wo_assim(1:i_len_wo)//'swed.gdat', +! & form='unformatted',access='direct',recl=4*icount) + +! These have to be closed and reopened so the data are completely +! available for the following read statements. + close (234) + close (236) + close (238) + + open (234,file=output_path_wo_assim(1:i_len_wo)//'roff.gdat',& + & form='unformatted',access='direct',recl=4*icount) + + open (236,file=output_path_wo_assim(1:i_len_wo)//'snod.gdat',& + & form='unformatted',access='direct',recl=4*icount) + + open (238,file=output_path_wo_assim(1:i_len_wo)//'swed.gdat',& + & form='unformatted',access='direct',recl=4*icount) + +! Output files. + if (iyear.eq.istart_year) then + open (7051,file='seaice/superimposed_ice_flag_parcel.gdat',& + & form='unformatted',access='direct',recl=4*3*icount,& + & status='replace') + + open (7061,file='seaice/superimposed_ice_flag_ease.gdat',& + & form='unformatted',access='direct',recl=4*2*nnx*nny,& + & status='replace') + + open (7071,file='seaice/snod_init.gdat',& + & form='unformatted',access='direct',recl=4*3*icount,& + & status='replace') + endif + +! Find the irecs between 1 June and 31 July of each year. + +! This is the begining of the simulation. + iyr_start = 1980 + imo_start = 8 + idy_start = 1 + +! Julian start. + ioptn = 3 + call calndr (ioptn,idy_start,imo_start,iyr_start,julian_start) + +! This is the begining of the summer period. + imo_beg = 6 + idy_beg = 1 + +! This is the end of the simulation year. + imo_end = 7 + idy_end = 31 + +! Extracting the last day of the simulation year. + +! Initialize the array. + do k=1,icount + simp_col(k) = undef + enddo + +! Find the irecs for 1 June and 31 July. + call calndr (ioptn,idy_beg,imo_beg,iyear,julian_beg) + irec1 = julian_beg - julian_start + 1 + call calndr (ioptn,idy_end,imo_end,iyear,julian_end) + irec2 = julian_end - julian_start + 1 + + print *,iiyear,iyear,irec1,irec2 + print *,iiyear,iyear,irec1,irec2 + print *,iiyear,iyear,irec1,irec2 + + do irec=irec1,irec2 + +! Read in the parcel data. +! read (7031,rec=irec) (roff_col(k),k=1,icount) + read (234,rec=irec) (roff_col(k),k=1,icount) + read (7022,rec=irec) (conc_col(k),k=1,icount) + +! Perform some cleanup duties. This should be done in the +! SnowModel code before roff is written out. But right now +! it is not. + do k=1,icount + if (conc_col(k).eq.0.0) roff_col(k) = undef + enddo + +! These runoff data = 0.0 for parcels with snow (or no snow) and +! zero runoff at this time step, and = undef if there is no +! parcel (i.e., if conc = 0.0). + +! If there is any runoff out the base of the snowpack during +! June or July, then the snowpack is isothermal and we assume +! that any remaining snow on this parcel on 31 July is so wet +! that if and when it eventually re-freezes it will create +! superimposed ice. + do k=1,icount + if (roff_col(k).gt.0.0) then + simp_col(k) = 1.0 + endif + enddo + + enddo + +! Apply the 'ZERO THE SNOW DEPTH' requirement to the 31 July +! snow depth. +! read (7032,rec=irec2) (snod_col(k),k=1,icount) +! read (7033,rec=irec2) (swed_col(k),k=1,icount) + read (236,rec=irec2) (snod_col(k),k=1,icount) + read (238,rec=irec2) (swed_col(k),k=1,icount) + + do k=1,icount + snod_col_init1(k) = snod_col(k) + swed_col_init1(k) = swed_col(k) + if (simp_col(k).eq.1.0) then + snod_col_init1(k) = 0.0 + swed_col_init1(k) = 0.0 + endif + enddo + + write (7051,rec=iiyear) & + & (snod_col_init1(k),k=1,icount),& + & (snod_col(k),k=1,icount),& + & (simp_col(k),k=1,icount) + +! Grid these data to the EASE grid. + call parcel_to_ease(nnx,nny,icount,irec2,snod_col_init1,snod1,& + & undef) + call parcel_to_ease(nnx,nny,icount,irec2,snod_col,snod2,& + & undef) + call parcel_to_ease(nnx,nny,icount,irec2,swed_col_init1,swed1,& + & undef) + +! Save the EASE grid data. + write (7061,rec=iiyear)& + & ((snod1(i,j),i=1,nnx),j=1,nny),& + & ((snod2(i,j),i=1,nnx),j=1,nny) + +! Prepare the initial condition snow depth array for 1 Aug. +! snod1 is my initial condition on the EASE grid. Use this to +! define an initial condition on the 1 Aug parcels. Do this +! by finding the EASE grid (i,j) position that corresponds to +! each 1 Aug parcel location. And then assigning this initial +! snow depth (and the other corresponding variables) to that +! parcel. + +! NOTE: this is going to crash on the last year! I need to fix +! that! +! The +1 here is what is converting the end of year data to a +! begining of the year IC on the new parcels. +! This is a stupid way to fix that problem. + if (iyear.ne.iend_year) then + irec3 = irec2 + 1 + else + irec3 = irec2 + endif + + read (7021,rec=irec3) (zi(k),k=1,icount),(zj(k),k=1,icount) + read (7022,rec=irec3) (conc(k),k=1,icount) + + do k=1,icount + snod_col_init2(k) = 0.0 + swed_col_init2(k) = 0.0 + if (conc(k).ne.0.0) then + ii = nint(zi(k)) + jj = nint(zj(k)) + if (snod1(ii,jj).ne.undef) then + snod_col_init2(k) = snod1(ii,jj) + swed_col_init2(k) = swed1(ii,jj) + else + snod_col_init2(k) = 0.0 + swed_col_init2(k) = 0.0 + endif + endif + + if (snod_col_init2(k).eq.undef) then + print *,'snod_col_init2(k)=undef',k,conc(k) + endif + if (swed_col_init2(k).eq.undef) then + print *,'swed_col_init2(k)=undef',k,conc(k) + endif + + enddo + +! Calculate the snow density IC by using the swed and snod values. +! This cleans up the problem of having undef sden when the +! depths are 0.0. + do k=1,icount + if (snod_col_init2(k).ne.0.0 .and. & + & snod_col_init2(k).ne.undef) then + sden_col_init1(k) = 1000.0 * swed_col_init2(k) / & + & snod_col_init2(k) + else + sden_col_init1(k) = ro_snow + endif + enddo + +! Save the snow depth initial condition data. + write (7071,rec=iiyear) (snod_col_init2(k),k=1,icount),& + & (swed_col_init2(k),k=1,icount),& + & (sden_col_init1(k),k=1,icount) + +! close (7021) +! close (7022) +! close (7031) +! close (7032) +! close (7033) +! close (7051) +! close (7061) +! close (7071) + + return + end SUBROUTINE SUPERIMPOSED_ICE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine parcel_to_ease(nnx,nny,icount,iter,snow_col,snow,& + & undef) + + implicit none + + integer ii,jj,nnx,nny,i,j,k,iter,icount + + real zi(icount),zj(icount),conc(icount) + + real snow_col(icount) + real snow(nnx,nny) + + real cnt(nnx,nny) + real conc_area_sum(nnx,nny) + + real undef,zii,zjj + real center_x1,center_y1,center_x2,center_y2,area + +! Read in the parcel track data. + read (7021,rec=iter) (zi(k),k=1,icount),(zj(k),k=1,icount) + read (7022,rec=iter) (conc(k),k=1,icount) + +! Make any 0.0 concentrations undefined, and convert them +! from 0-100 to 0-1. + do k=1,icount + conc(k) = conc(k) / 100.0 + if (conc(k).eq.0.0) conc(k) = undef + enddo + +! Initialize the working arrays. + do j=1,nny + do i=1,nnx + +! Snow depth. + snow(i,j) = 0.0 + +! Counting array. + cnt(i,j) = 0.0 + +! Concentration-area product summing array. + conc_area_sum(i,j) = 0.0 + + enddo + enddo + + do k=1,icount + if (conc(k).ne.undef) then + +! Decimal coordinate of the center of the parcel. + center_x2 = zi(k) + center_y2 = zj(k) + +! Coordinate of the EASE grid cell center that this parcel +! center sits in, integer and real versions. + ii = nint(zi(k)) + jj = nint(zj(k)) + +! This eliminates any problems at the boundaries, if you have +! a situation where there is non-zero conc on the boundary +! grid cells. + if (ii.eq.1) ii = 2 + if (ii.eq.nnx) ii = nnx-1 + if (jj.eq.1) jj = 2 + if (jj.eq.nny) jj = nny-1 + + zii = real(ii) + zjj = real(jj) + +! Loop through the 3x3 grid cells surrounding the EASE grid cell. + do j=jj-1,jj+1 + do i=ii-1,ii+1 + +! Define the center coords of the surrounding EASE grid cells. + center_x1 = real(i) + center_y1 = real(j) + +! Find the overlap in fractional area of each EASE grid cell. So, +! the "area" coming out of this is: 0-1 = the fraction of the +! 25-km by 25-km EASE grid cell that this parcel covers. + call overlap_area (center_x1,center_y1,center_x2,& + & center_y2,area) + +! Use the concentration to weight the snow depth under the +! assumption that the concentration is proportional to the +! contributing area. + area = area * conc(k) + +! Count how many parcels contribute to each EASE grid cell. + if (area.gt.0.0) then + cnt(i,j) = cnt(i,j) + 1.0 + endif + +! Keep track of the concentrations that sum to over 1.0. They +! will be used to scale the result at the end of the averaging +! calculations. + conc_area_sum(i,j) = conc_area_sum(i,j) + area + +! Sum the snow depth contributions from each parcel in each EASE +! grid cell, by scaling the depth values by the area and conc. + snow(i,j) = snow(i,j) + area * snow_col(k) + + enddo + enddo + + endif + enddo + +! Take care of the problem where the area-concentrations summed +! to over 1.0. + do j=1,nny + do i=1,nnx + +! Clip the values below 1.0 so when you do the divide, only +! concentration sums above 1.0 scale the result (values below +! 1.0 are already grid-averaged values). + conc_area_sum(i,j) = max(1.0,conc_area_sum(i,j)) + +! Scale the snow depth averages for cases where the concentration +! summed to greater than 1.0. + snow(i,j) = snow(i,j) / conc_area_sum(i,j) + + enddo + enddo + +! Clean up any grid cells that never had any ice in them. + do j=1,nny + do i=1,nnx + if (cnt(i,j).eq.0.0) then + snow(i,j) = undef + endif + enddo + enddo + + return + end SUBROUTINE parcel_to_ease + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine overlap_area (center_x1,center_y1,center_x2,& + & center_y2,area) + +! Here center_x1,y1 is the EASE grid cell, and center_x2,y2 is +! the parcel cell. + + implicit none + + real center_x1,center_y1 + real center_x2,center_y2 + real x1_min,x1_max,y1_min,y1_max + real x2_min,x2_max,y2_min,y2_max + real x_overlap,y_overlap,area + +! These are the boundary coords of the EASE grid cell. + x1_min = center_x1 - 0.5 + x1_max = center_x1 + 0.5 + y1_min = center_y1 - 0.5 + y1_max = center_y1 + 0.5 + +! These are the boundary coords of the parcel. + x2_min = center_x2 - 0.5 + x2_max = center_x2 + 0.5 + y2_min = center_y2 - 0.5 + y2_max = center_y2 + 0.5 + +! Define the overlap in x and y. + x_overlap = max(0.0,min(x1_max,x2_max) - max(x1_min,x2_min)) + y_overlap = max(0.0,min(y1_max,y2_max) - max(y1_min,y2_min)) + +! Calculate the area overlap. + area = x_overlap * y_overlap + +! print 98, x_overlap,y_overlap,area +! 98 format (3f10.3) + + return + end subroutine overlap_area + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! diff --git a/lis/surfacemodels/land/subLSM/snowmodel/physics/snowtran_code.f90 b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowtran_code.f90 new file mode 100755 index 000000000..a55884d64 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/physics/snowtran_code.f90 @@ -0,0 +1,4059 @@ +! snowtran_code.f + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! Snow-Transport Modeling System - 3D (SnowTran-3D) !!!!!! +!!!!! Copyright (C) 1998 !!!!!! +!!!!! by Glen E. Liston, InterWorks Consulting !!!!!! +!!!!! All Rights Reserved !!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! This FORTRAN code receives inputs of wind speed, wind direction, +! air temperature, relative humidity, vegetation type, topography, +! and precipitation, and it outputs snow depth, saltation flux, +! suspended flux, sublimation of blowing snow, and the snow depth +! changes resulting from these processes. +! +! All units are in m, kg, s, K. +! +! This model is described in the paper: +! A Snow-Transport Model for Complex Terrain, by Glen E. Liston +! and Matthew Sturm, Journal of Glaciology, 1998, Vol. 44, +! No. 148, pages 498-516. +! +! The author of this code is: +! Dr. Glen E. Liston +! InterWorks Consulting +! 15621 SnowMan Road +! Loveland, Colorado 80538 +! +! To run in 2-D mode, set nx = 3 and look at the data at i = 2. +! This is required because of the boundary conditions imposed +! along i = 1 and 3. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine SNOWTRAN_CODE(bc_flag,bs_flag,C_z,& + & conc_salt,deltax,deltay,dh_salt,dh_salt_u,dh_salt_v,& + & dh_susp,dh_susp_u,dh_susp_v,dt,dz_susp,fall_vel,fetch,& + & gravity,h_const,h_star,ht_rhobs,ht_windobs,index_ue,& + & index_uw,index_vn,index_vs,iter,nx,ny,pi,Qsalt,Qsalt_max,& + & Qsalt_maxu,Qsalt_maxv,Qsalt_u,Qsalt_v,Qsubl,Qsusp,& + & Qsusp_u,Qsusp_v,rh_grid,ro_air,ro_snow,ro_water,snow_d,& + & snow_d_init,snow_z0,soft_snow_d,sprec,sum_glacmelt,& + & subgrid_flag,wbal_salt,wbal_susp,wbal_qsubl,sum_sprec,& + & tabler_ee,tabler_ne,tabler_nn,tabler_nw,tabler_se,& + & tabler_ss,tabler_sw,tabler_ww,tair_grid,topo,topo_land,& + & topoflag,twolayer_flag,Up_const,Ur_const,Utau,& + & Utau_t,uwind_grid,veg_z0,vegsnowd_xy,vegtype,vonKarman,& + & vwind_grid,wind_min,winddir_flag,winddir_grid,& + & windspd_flag,windspd_grid,xmu,z_0,ztop_susp,max_iter,& + & run_enbal,run_snowpack,wbal_subgrid,sum_qsubl,sum_trans,& + & swe_depth,snow_depth,ro_snow_grid,sum_prec,sum_runoff,& + & sum_Qcs,canopy_int,w_balance,sum_sfcsublim,tabler_dir,& + & slope_adjust,Utau_t_const,Utau_t_flag,ro_soft_snow_old,& + & ro_soft_snow,ro_nsnow,prec,Qcs,runoff,d_canopy_int,& + & glacier_melt,swe_depth_old,swesublim,canopy_unload,& + & canopy_int_old,iter_start,multilayer_snowpack,swed_layer,& + & KK,snod_layer,ro_layer,curve_lg_scale_flag,curve_wt_lg,& + & seaice_run,seaice_conc,tslsnowfall,T_old,tsls_threshold,& + & curve_len_scale,Tabler_1_flag,Tabler_2_flag,undef,& + & tabler_sfc_path_name,output_path_wo_assim,& + & output_path_wi_assim,icorr_factor_loop,windspd_2m_grid,& + & Qsubl_depth) + + use snowmodel_inc + implicit none + + integer iter,nx,ny,i,j,iter_start,max_iter + + real ro_snow,ro_water,ro_air,gravity,vonKarman,snow_z0 + real deltax,deltay,dt,undef + real fetch,xmu,C_z,h_const,wind_min,windspd_flag + real Up_const,dz_susp,ztop_susp,fall_vel,Ur_const + real Utau_t_const,pi,bc_flag,topoflag,Utau_t_flag + real ht_windobs,ht_rhobs,bs_flag,twolayer_flag + real subgrid_flag,winddir_flag,curve_len_scale + real run_enbal,run_snowpack,tabler_dir,slope_adjust + + real topo_land(nx,ny) + real tabler_nn(nx,ny) + real tabler_ss(nx,ny) + real tabler_ee(nx,ny) + real tabler_ww(nx,ny) + real tabler_ne(nx,ny) + real tabler_se(nx,ny) + real tabler_sw(nx,ny) + real tabler_nw(nx,ny) + real topo(nx,ny) + real vegtype(nx,ny) + + real tabler_nn_orig(nx,ny) + real tabler_ss_orig(nx,ny) + real tabler_ee_orig(nx,ny) + real tabler_ww_orig(nx,ny) + real tabler_ne_orig(nx,ny) + real tabler_se_orig(nx,ny) + real tabler_sw_orig(nx,ny) + real tabler_nw_orig(nx,ny) + real snow_d_tabler(nx,ny) + real topo_tmp(nx,ny) + + real uwind_grid(nx,ny),vwind_grid(nx,ny) + real windspd_grid(nx,ny),winddir_grid(nx,ny) + real tair_grid(nx,ny),sprec(nx,ny) + real rh_grid(nx,ny),windspd_2m_grid(nx,ny) + + integer index_ue(ny_max,2*nx_max+1),index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1),index_vs(nx_max,2*ny_max+1) + + real snow_d(nx,ny) + real snow_depth(nx,ny) + real swe_depth(nx,ny) + real ro_snow_grid(nx,ny) + real ro_soft_snow(nx,ny) + real ro_soft_snow_old(nx,ny) + real ro_nsnow(nx,ny) + real snow_d_init(nx,ny) + real Utau(nx,ny) + real Utau_t(nx,ny) + real z_0(nx,ny) + real h_star(nx,ny) + real conc_salt(nx,ny) + + real Qsalt_max(nx,ny) + real Qsalt_maxu(nx,ny),Qsalt_maxv(nx,ny) + real Qsalt(nx,ny) + real Qsalt_u(nx,ny),Qsalt_v(nx,ny) + real dh_salt(nx,ny) + real dh_salt_u(nx,ny),dh_salt_v(nx,ny) + + real Qsusp(nx,ny) + real Qsusp_u(nx,ny),Qsusp_v(nx,ny) + real dh_susp(nx,ny) + real dh_susp_u(nx,ny),dh_susp_v(nx,ny) + + real dh_subgrid(nx,ny) + real Qsubl(nx,ny) + real Qsubl_depth(nx,ny) + + real sum_sprec(nx,ny) + real wbal_qsubl(nx,ny) + real wbal_salt(nx,ny) + real wbal_susp(nx,ny) + real wbal_subgrid(nx,ny) + real sum_qsubl(nx,ny) + real sum_trans(nx,ny) + real soft_snow_d(nx,ny) + + real prec(nx,ny) + real Qcs(nx,ny) + real runoff(nx,ny) + real d_canopy_int(nx,ny) + real glacier_melt(nx,ny) + real swe_depth_old(nx,ny) + real swesublim(nx,ny) + real canopy_unload(nx,ny) + real canopy_int_old(nx,ny) + + real vegsnowd_xy(nx,ny) + real veg_z0(nx,ny) + + real sum_glacmelt(nx,ny),w_balance(nx,ny),& + & sum_prec(nx,ny),sum_runoff(nx,ny),& + & sum_Qcs(nx,ny),canopy_int(nx,ny),& + & sum_sfcsublim(nx,ny) + + integer multilayer_snowpack,k + integer KK(nx,ny) + real swe_change_tmp,swe_change,tsls_threshold + real swed_layer_z(nz_max) + real swed_layer(nx,ny,nz_max) + real snod_layer(nx,ny,nz_max) + real ro_layer(nx,ny,nz_max) + real T_old(nx,ny,nz_max) + real tslsnowfall(nx,ny) + + real curve_lg_scale_flag + real curve_wt_lg(nx_max,ny_max) + + real seaice_run + real seaice_conc(nx,ny) + + real Tabler_1_flag,Tabler_2_flag + character*80 output_path_wo_assim,output_path_wi_assim,& + & tabler_sfc_path_name + integer i_len_tabler,trailing_blanks,icorr_factor_loop,& + & i_len_wo,i_len_wi + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Perform some intialization steps that are unique to SnowTran-3D. + if (iter.eq.iter_start) then + +! This is now done in preprocess_code.f +! print *, +! & 'cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' +! print *, +! & 'c Snow-Transport Modeling System - 3D (SnowTran-3D) c' +! print *, +! & 'c Copyright (C) 1998 c' +! print *, +! & 'c by Glen E. Liston, InterWorks Consulting c' +! print *, +! & 'c All Rights Reserved c' +! print *, +! & 'cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' + +! SnowTran-3D can only be run with SnowPack and EnBal turned on. + if (run_enbal.ne.1.0 .and. run_snowpack.ne.1.0) then + print *,'You cannot run SnowTran-3D without' + print *,'SnowPack and EnBal anymore.' + stop + endif + + if (subgrid_flag.eq.1.0) then + +! Check to make sure topoflag = 1.0. + if (subgrid_flag.eq.1.0 .and. topoflag.eq.0.0) then + print *,'If subgrid_flag=1.0, then topoflag must = 1.0' + print *,' Correct this in snowmodel.par to continue.' + stop + endif + +! The Tabler surfaces were originally developed assuming the grid +! increment would never be less than 1.0 m. You probably should +! not run it with deltax and deltay less than 1.0 without some +! further testing. + if (deltax.lt.1.0 .or. deltay.lt.1.0) then + print *,'The Tabler subgrid algorithm has not been' + print *,'tested for deltax and/or deltay less than' + print *,'1.0 m. You should probably do some testing' + print *,'before running the model at less than 1.0-m' + print *,'resolution. Acually I am pretty sure it will' + print *,'run, but it will not generate the correct' + print *,'snow-depth profiles.' + stop + endif + +! If this is the first time through, generate the Tabler snow +! accumulation surfaces for the land topography. + call tabler_3d(nx,ny,topo_land,deltax,deltay,& + & tabler_ww_orig,tabler_ee_orig,tabler_ss_orig,& + & tabler_nn_orig,tabler_ne_orig,tabler_se_orig,& + & tabler_sw_orig,tabler_nw_orig,slope_adjust) + +! Include the vegetation snow-holding depths in the Tabler +! surfaces. + do i=1,nx + do j=1,ny + tabler_nn_orig(i,j) = & + & max(tabler_nn_orig(i,j),vegsnowd_xy(i,j)) + tabler_ne_orig(i,j) = & + & max(tabler_ne_orig(i,j),vegsnowd_xy(i,j)) + tabler_ee_orig(i,j) = & + & max(tabler_ee_orig(i,j),vegsnowd_xy(i,j)) + tabler_se_orig(i,j) = & + & max(tabler_se_orig(i,j),vegsnowd_xy(i,j)) + tabler_ss_orig(i,j) = & + & max(tabler_ss_orig(i,j),vegsnowd_xy(i,j)) + tabler_sw_orig(i,j) = & + & max(tabler_sw_orig(i,j),vegsnowd_xy(i,j)) + tabler_ww_orig(i,j) = & + & max(tabler_ww_orig(i,j),vegsnowd_xy(i,j)) + tabler_nw_orig(i,j) = & + & max(tabler_nw_orig(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler equilibrium surfaces for each of the 8 main wind +! directions. Also save the land DEM distribution. + if (Tabler_1_flag.eq.1.0) then + i_len_tabler = 80 - trailing_blanks(tabler_sfc_path_name) + open(51,& + & file=tabler_sfc_path_name(1:i_len_tabler)//'tabler_sfcs.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + write(51,rec=1) ((tabler_nn_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=2) ((tabler_ne_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=3) ((tabler_ee_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=4) ((tabler_se_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=5) ((tabler_ss_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=6) ((tabler_sw_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=7) ((tabler_ww_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=8) ((tabler_nw_orig(i,j),i=1,nx),j=1,ny) + write(51,rec=9) ((topo_land(i,j),i=1,nx),j=1,ny) + close (51) + endif + +! This available if you want to save the Tabler surface that was +! used at each time step. + if (Tabler_2_flag.eq.1.0) then + if (icorr_factor_loop.eq.1) then + i_len_wo = 80 - trailing_blanks(output_path_wo_assim) + open(52,& + & file=output_path_wo_assim(1:i_len_wo)//'tabler_sfcs_iter.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + endif + if (icorr_factor_loop.eq.2) then + i_len_wi = 80 - trailing_blanks(output_path_wi_assim) + open(52,& + & file=output_path_wi_assim(1:i_len_wi)//'tabler_sfcs_iter.gdat',& + & form='unformatted',access='direct',recl=4*nx*ny) + endif + endif + endif + + endif + +! Print out some basic run information to the screen. +! print 102, windspd_flag,winddir_flag +! 102 format(25x,' wind spd = ',f5.2,' wind dir = ',f4.0) + +! In SnowTran-3D, the summed snow precipitation must be in units +! of snow-depth. The rest of the routines assume that it is in +! swe units. + do j=1,ny + do i=1,nx + sum_sprec(i,j) = sum_sprec(i,j) * ro_water / ro_snow + enddo + enddo + +! Update the threshold friction velocity. + if (Utau_t_flag.eq.0.0) then + if (curve_lg_scale_flag.eq.1.0) then + do j=1,ny + do i=1,nx + Utau_t(i,j) = curve_wt_lg(i,j) * Utau_t_const + enddo + enddo + else + do j=1,ny + do i=1,nx + Utau_t(i,j) = Utau_t_const + enddo + enddo + endif + elseif (Utau_t_flag.eq.1.0) then + do j=1,ny + do i=1,nx + call surface_snow_1(tair_grid(i,j),windspd_2m_grid(i,j),& + & sprec(i,j),ro_soft_snow(i,j),Utau_t(i,j),& + & ro_soft_snow_old(i,j),dt,ro_nsnow(i,j)) + enddo + enddo + if (curve_lg_scale_flag.eq.1.0) then + do j=1,ny + do i=1,nx + Utau_t(i,j) = curve_wt_lg(i,j) * Utau_t(i,j) + enddo + enddo + endif + endif + +! Set the blowing snow flag to zero until it is clear that we will +! have blowing snow. + bs_flag = 0.0 + +! If the wind speed is lower that some threshold, then don't +! need to do any of the snow transport computations. + if (windspd_flag.ge.4.0) then + +! Get the wind direction indexing arrays for this particular +! wind event (time step). + call getdirection(nx,ny,uwind_grid,vwind_grid,index_ue,& + & index_uw,index_vn,index_vs) + +! Solve for Utau and z_0 if snow is saltating, else solve assuming +! z_0 is known from snow depth and/or veg type, and solve for +! Utau. + call solveUtau(Utau,ht_windobs,windspd_grid,C_z,vonKarman,& + & gravity,z_0,h_star,h_const,vegsnowd_xy,snow_d,& + & snow_z0,veg_z0,bs_flag,nx,ny,Utau_t,soft_snow_d) + +! If the blowing snow flag indicates wind transported snow +! somewhere within the domain (bs_flag = 1.0), run the saltation +! and suspension models. + if (bs_flag.eq.1.0) then + +! Solve for the saltation flux. +! print *,' Saltation' + call saltation(Qsalt,deltax,fetch,Utau,Utau_t,nx,ny,& + & ro_air,gravity,vegsnowd_xy,snow_d,& + & Qsalt_max,Qsalt_maxu,Qsalt_maxv,deltay,Qsalt_u,Qsalt_v,& + & index_ue,index_uw,index_vn,index_vs,uwind_grid,& + & vwind_grid,xmu,soft_snow_d,bc_flag) + +! Solve for the suspension flux. +! print *,' Suspension' + call suspension(Utau,vonKarman,nx,ny,conc_salt,& + & Qsalt,Qsusp,z_0,h_star,dz_susp,ztop_susp,pi,& + & fall_vel,Ur_const,Up_const,Utau_t,Qsubl,ht_rhobs,& + & tair_grid,rh_grid,Qsusp_u,Qsusp_v,uwind_grid,& + & vwind_grid) + + elseif (bs_flag.eq.0.0) then + + call noblowsnow(nx,ny,Qsalt_max,Qsalt_maxu,& + & Qsalt_maxv,Qsalt,Qsalt_u,Qsalt_v,dh_salt,dh_salt_u,& + & dh_salt_v,conc_salt,Qsusp,Qsusp_u,Qsusp_v,dh_susp,& + & dh_susp_u,dh_susp_v,Qsubl,dh_subgrid) + + endif + + else + +! This 'noblowsnow' call zeros out data from a previous time step +! that had blowing snow. + call noblowsnow(nx,ny,Qsalt_max,Qsalt_maxu,& + & Qsalt_maxv,Qsalt,Qsalt_u,Qsalt_v,dh_salt,dh_salt_u,& + & dh_salt_v,conc_salt,Qsusp,Qsusp_u,Qsusp_v,dh_susp,& + & dh_susp_u,dh_susp_v,Qsubl,dh_subgrid) + + endif + +! If this is a normal SnowTran-3D run, adjust the accumulations +! and erosions in reponse to varying transport fluxes across +! the simulation domain. If it is a sea ice run with 25-km +! grid cells, just adjust the snow depth in response to the +! blowing snow sublimation fluxes only. + + if (seaice_run.eq.1.0 .and. deltax.eq.25000.0) then + +! Here Qsubl goes in as a flux, and comes out in snow depth units. +! And Qsubl_depth comes out in swe depth units. + call bs_sublimation_only(nx,ny,dt,bs_flag,ro_water,& + & snow_depth,swe_depth,ro_snow_grid,soft_snow_d,Qsubl,& + & vegsnowd_xy,Qsubl_depth) + + elseif (seaice_run.eq.4.0 .and. deltax.eq.25000.0) then + +! Here Qsubl goes in as a flux, and comes out in snow depth units. +! And Qsubl_depth comes out in swe depth units. + call bs_sublimation_only(nx,ny,dt,bs_flag,ro_water,& + & snow_depth,swe_depth,ro_snow_grid,soft_snow_d,Qsubl,& + & vegsnowd_xy,Qsubl_depth) + + else + +! Compute the new snow depth due to accumulation from precipitation, +! saltation, and suspension, and the mass loss due to +! sublimation. + call accum(snow_d,nx,ny,ro_snow,dt,ro_water,& + & deltax,deltay,vegsnowd_xy,Tabler_2_flag,& + & index_ue,index_uw,index_vn,index_vs,undef,& + & Qsalt_u,Qsalt_v,Qsusp_u,Qsusp_v,Qsubl,dh_salt,& + & dh_salt_u,dh_salt_v,dh_susp,dh_susp_u,dh_susp_v,& + & wbal_qsubl,wbal_salt,wbal_susp,bs_flag,& + & soft_snow_d,topo,topo_land,topoflag,subgrid_flag,& + & tabler_nn,tabler_ss,tabler_ee,tabler_ww,& + & tabler_ne,tabler_se,tabler_sw,tabler_nw,& + & uwind_grid,vwind_grid,wbal_subgrid,sum_qsubl,& + & sum_trans,swe_depth,snow_depth,ro_snow_grid,& + & dh_subgrid,tabler_dir,iter,slope_adjust,& + & curve_len_scale) + + endif + +! Use the changes in swe due to saltation, suspension, and +! blowing snow sublimation to adjust the multilayer snowpack +! layers. + if (multilayer_snowpack.eq.1) then + + if (seaice_run.ne.0.0) then + do j=1,ny + do i=1,nx +! This is the sublimation in terms of swe depth. + wbal_qsubl(i,j) = Qsubl(i,j) * ro_snow_grid(i,j) / & + & ro_water +! Because these simulations are done over grid cells that are +! around 25-km by 25-km, subgrid blowing snow processes are not +! simulated. + wbal_salt(i,j) = 0.0 + wbal_susp(i,j) = 0.0 + wbal_subgrid(i,j) = 0.0 + enddo + enddo + endif + + do j=1,ny + do i=1,nx + swe_change = wbal_qsubl(i,j) + wbal_salt(i,j) + & + & wbal_susp(i,j) + wbal_subgrid(i,j) + +! Net mass loss for this grid cell at this time step. + if (swe_change.lt.0.0) then + swe_change_tmp = -swe_change + +! Extract the vertical column for this i,j point, and send it +! to the subroutine. *** Note that I should use f95, then I would +! not have to do this (I could pass in subsections of the arrays). + do k=1,nz_max + swed_layer_z(k) = swed_layer(i,j,k) + enddo + +! Check to see whether a layer reduction is required. + CALL REDUCE_LAYERS(swe_change_tmp,swed_layer_z,KK(i,j)) + +! Re-build the 3-D array. See note above about using f95 to avoid this. + do k=1,nz_max + swed_layer(i,j,k) = swed_layer_z(k) + enddo + +! Update the snow layer thicknesses, and recalculate the total +! snow and swe depths. Assume this swe change does not change +! the snow density and does not change the soft snow depth. It +! only reduces the snow depth and the associated swe depth. + snow_depth(i,j) = 0.0 + swe_depth(i,j) = 0.0 + do k=1,KK(i,j) + snod_layer(i,j,k) = swed_layer(i,j,k) * ro_water / & + & ro_layer(i,j,k) +! ro_layer(i,j,k) = ro_layer(i,j,k) + snow_depth(i,j) = snow_depth(i,j) + snod_layer(i,j,k) + swe_depth(i,j) = swe_depth(i,j) + swed_layer(i,j,k) + enddo + +! Net mass gain for this grid cell at this time step. + elseif (swe_change.gt.0.0) then + +! Add to the existing top layer. + swed_layer(i,j,KK(i,j)) = swed_layer(i,j,KK(i,j)) + & + & swe_change +! ro_layer(i,j,k) = ro_layer(i,j,k) + snod_layer(i,j,KK(i,j)) = swed_layer(i,j,KK(i,j)) * & + & ro_water / ro_layer(i,j,KK(i,j)) + +! Update the snow layer thicknesses, and recalculate the total +! snow and swe depths. Assume this swe change does not change +! the snow density and does not change the soft snow depth. It +! only reduces the snow depth and the associated swe depth. + snow_depth(i,j) = 0.0 + swe_depth(i,j) = 0.0 + do k=1,KK(i,j) + snow_depth(i,j) = snow_depth(i,j) + snod_layer(i,j,k) + swe_depth(i,j) = swe_depth(i,j) + swed_layer(i,j,k) + enddo + + else + + snow_depth(i,j) = 0.0 + swe_depth(i,j) = 0.0 + do k=1,KK(i,j) + snow_depth(i,j) = snow_depth(i,j) + snod_layer(i,j,k) + swe_depth(i,j) = swe_depth(i,j) + swed_layer(i,j,k) + enddo + + endif + + enddo + enddo + endif + +! Perform a water balance check (see notes in this subroutine). + if (seaice_run.eq.0.0) then + +! Don't do this calculation for subgrid_flag = 1.0. This can be +! turned back on and the required adjustments made to the code, +! if needed. +! if (subgrid_flag.eq.0.0) then +! call waterbal_snowtran(w_balance,prec,Qcs, +! & runoff,d_canopy_int,swe_depth,glacier_melt,iter, +! & wbal_qsubl,wbal_salt,wbal_susp,wbal_subgrid,nx,ny, +! & swe_depth_old,swesublim,canopy_unload,canopy_int, +! & canopy_int_old) +! endif + endif + +! If this is a sea ice run, zero out the ocean grid cells that +! have no sea ice in them. + if (seaice_run.ne.0.0) then + CALL ZERO_SEAICE_SNOW(nx,ny,snow_depth,ro_snow_grid,& + & ro_snow,swe_depth,swe_depth_old,canopy_int_old,KK,& + & tslsnowfall,snod_layer,swed_layer,ro_layer,T_old,& + & multilayer_snowpack,tsls_threshold,seaice_conc,& + & sum_sprec,sum_trans) + endif + +! Save the mass balance variables from this time step. + do j=1,ny + do i=1,nx + swe_depth_old(i,j) = swe_depth(i,j) + canopy_int_old(i,j) = canopy_int(i,j) + enddo + enddo + +! In SnowTran-3D, the summed snow precipitation were in units +! of snow-depth. The rest of the routines assume that it is in +! swe units. + do j=1,ny + do i=1,nx + sum_sprec(i,j) = sum_sprec(i,j) * ro_snow / ro_water + enddo + enddo + +! Close the Tabler surface output file if this is the end of this +! assimulation loop. + if (iter.eq.max_iter) close(52) + + return + end subroutine SNOWTRAN_CODE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine waterbal_snowtran(w_balance,prec,Qcs,& + & runoff,d_canopy_int,swe_depth,glacier_melt,iter,& + & wbal_qsubl,wbal_salt,wbal_susp,wbal_subgrid,nx,ny,& + & swe_depth_old,swesublim,canopy_unload,canopy_int,& + & canopy_int_old) + + use snowmodel_inc + implicit none + + integer iter,nx,ny,i,j + + real w_balance(nx,ny),prec(nx,ny),& + & Qcs(nx,ny),runoff(nx,ny),& + & d_canopy_int(nx,ny),swe_depth(nx,ny),& + & glacier_melt(nx,ny),wbal_qsubl(nx,ny),& + & wbal_salt(nx,ny),swe_depth_old(nx,ny),& + & swesublim(nx,ny),wbal_susp(nx,ny),& + & wbal_subgrid(nx,ny),canopy_unload(nx,ny),& + & canopy_int_old(nx,ny),canopy_int(nx,ny) + +! Note that the following balances should hold. These aren't quite +! right, but it is a place to start. +! Canopy Balance (forest): +! canopy = sprec - unload + Qcs ==> unload = sprec - canopy + Qcs +! +! Snowpack Balance (forest): +! swe_d = unload + rain - runoff ==> +! canopy + swe_d = sprec + rain + Qcs - runoff +! prec = sprec + rain +! sum_rain = sum_sprec - sum_prec +! +! Snowpack Balance (non-forest): +! swe_d = sprec + rain - runoff + subl + salt + susp + subgrid + +! glaciermelt +! +! Everywhere: +! w_balance = sum_prec + sum_Qcs - sum_runoff + sum_subl + +! sum_trans - canopy_int - swe_depth + sum_glacmelt +! +! The related variables that would need to be brought in are: +! d_canopy_int,sum_d_canopy_int,sum_unload + +! The subroutine WATERBAL_SNOWTRAN is used if the model simulation +! includes SnowTran-3D. + do j=1,ny + do i=1,nx + w_balance(i,j) = swe_depth_old(i,j) - swe_depth(i,j) + & + & prec(i,j) - runoff(i,j) + glacier_melt(i,j) +& + & wbal_qsubl(i,j) + wbal_salt(i,j) + wbal_susp(i,j) +& + & wbal_subgrid(i,j) - swesublim(i,j) + canopy_int_old(i,j) -& + & canopy_int(i,j) + Qcs(i,j) + + if (abs(w_balance(i,j)).gt.1.0e-5) & + & print*,'water imbalance at iter =',iter,' ',w_balance(i,j) + + enddo + enddo + + return + end subroutine waterbal_snowtran + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine noblowsnow(nx,ny,Qsalt_max,Qsalt_maxu,& + & Qsalt_maxv,Qsalt,Qsalt_u,Qsalt_v,dh_salt,dh_salt_u,& + & dh_salt_v,conc_salt,Qsusp,Qsusp_u,Qsusp_v,dh_susp,& + & dh_susp_u,dh_susp_v,Qsubl,dh_subgrid) + + use snowmodel_inc + implicit none + + integer nx,ny,i,j + real Qsalt_max(nx,ny) + real Qsalt_maxu(nx,ny),Qsalt_maxv(nx,ny) + real Qsalt(nx,ny) + real Qsalt_u(nx,ny),Qsalt_v(nx,ny) + real dh_salt(nx,ny) + real dh_salt_u(nx,ny),dh_salt_v(nx,ny) + + real conc_salt(nx,ny) + + real Qsusp(nx,ny) + real Qsusp_u(nx,ny),Qsusp_v(nx,ny) + real dh_susp(nx,ny) + real dh_susp_u(nx,ny),dh_susp_v(nx,ny) + real dh_subgrid(nx,ny) + + real Qsubl(nx,ny) + + do i=1,nx + do j=1,ny + Qsalt_max(i,j) = 0.0 + Qsalt_maxu(i,j) = 0.0 + Qsalt_maxv(i,j) = 0.0 + Qsalt(i,j) = 0.0 + Qsalt_u(i,j) = 0.0 + Qsalt_v(i,j) = 0.0 + dh_salt(i,j) = 0.0 + dh_salt_u(i,j) = 0.0 + dh_salt_v(i,j) = 0.0 + conc_salt(i,j) = 0.0 + Qsusp(i,j) = 0.0 + Qsusp_u(i,j) = 0.0 + Qsusp_v(i,j) = 0.0 + dh_susp(i,j) = 0.0 + dh_susp_u(i,j) = 0.0 + dh_susp_v(i,j) = 0.0 + Qsubl(i,j) = 0.0 + dh_subgrid(i,j) = 0.0 + enddo + enddo + + return + end + + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine bs_sublimation_only(nx,ny,dt,bs_flag,ro_water,& + & snow_depth,swe_depth,ro_snow_grid,soft_snow_d,Qsubl,& + & vegsnowd_xy,Qsubl_depth) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny + + real dt,bs_flag,ro_water,snowdmin,hard_snow_d + + real snow_depth(nx,ny) + real swe_depth(nx,ny) + real ro_snow_grid(nx,ny) + + real soft_snow_d(nx,ny) + real Qsubl(nx,ny) + real Qsubl_depth(nx,ny) + + real vegsnowd_xy(nx,ny) + +! Adjust the snow and swe depths to account for blowing-snow +! sublimation. + + if (bs_flag.eq.1.0) then + +! SUBLIMATION +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. Since Qsubl is blowing snow sublimation, don't let +! this sublimation reach down into the hard snow layer or into +! the vegsnowd, because that snow is not available to be blown +! around. + do i=1,nx + do j=1,ny + hard_snow_d = snow_depth(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + +! Convert Qsubl from sublimation flux to sublimated snow depth. +! Qsubl is negative here. + Qsubl(i,j) = Qsubl(i,j) * dt / ro_snow_grid(i,j) + + if (snow_depth(i,j).gt.snowdmin) then + if (snow_depth(i,j)+Qsubl(i,j).le.snowdmin) then + Qsubl(i,j) = snowdmin - snow_depth(i,j) + endif + else + Qsubl(i,j) = 0.0 + endif + enddo + enddo + +! Account for decreases in snow depth due to sublimation. + do i=1,nx + do j=1,ny + snow_depth(i,j) = snow_depth(i,j) + Qsubl(i,j) + soft_snow_d(i,j) = soft_snow_d(i,j) + Qsubl(i,j) + enddo + enddo + + else + + do i=1,nx + do j=1,ny + Qsubl(i,j) = 0.0 + enddo + enddo + + endif + +! Convert any snow-depth adjustments that occurred above to +! swe using the spatially-distributed snow density from the +! snowpack model. Also convert the Qsubl_depth values from +! snow depth to swe depth units. + do i=1,nx + do j=1,ny + swe_depth(i,j) = snow_depth(i,j) * ro_snow_grid(i,j) / & + & ro_water + Qsubl_depth(i,j) = Qsubl(i,j) * ro_snow_grid(i,j) / & + & ro_water + enddo + enddo + + return + end subroutine bs_sublimation_only + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine accum(snow_d,nx,ny,ro_snow,dt,ro_water,& + & deltax,deltay,vegsnowd_xy,Tabler_2_flag,& + & index_ue,index_uw,index_vn,index_vs,undef,& + & Qsalt_u,Qsalt_v,Qsusp_u,Qsusp_v,Qsubl,dh_salt,& + & dh_salt_u,dh_salt_v,dh_susp,dh_susp_u,dh_susp_v,& + & wbal_qsubl,wbal_salt,wbal_susp,bs_flag,& + & soft_snow_d,topo,topo_land,topoflag,subgrid_flag,& + & tabler_nn,tabler_ss,tabler_ee,tabler_ww,& + & tabler_ne,tabler_se,tabler_sw,tabler_nw,& + & uwind_grid,vwind_grid,wbal_subgrid,sum_qsubl,& + & sum_trans,swe_depth,snow_depth,ro_snow_grid,& + & dh_subgrid,tabler_dir,iter,slope_adjust,& + & curve_len_scale) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,iter,k,loops_snowd_smoother,II,JJ,nnx,nny,& + & irotate_flag + + real ro_snow,dt,deltax,deltay,bs_flag,topoflag,ro_water + real snowdmin,hard_snow_d,subgrid_flag,tabler_dir + real slope_adjust,xmult,curve_len_scale,Tabler_2_flag + + real snow_d(nx,ny) + real snow_d_tmp(nx,ny) + real snow_depth(nx,ny) + real swe_depth(nx,ny) + real ro_snow_grid(nx,ny) + real snow_d_tabler(nx,ny) + real snow_d_dep(nx,ny) + real soft_snow_d_dep(nx,ny) + + real tabler_nn(nx,ny) + real tabler_ss(nx,ny) + real tabler_ee(nx,ny) + real tabler_ww(nx,ny) + real tabler_ne(nx,ny) + real tabler_se(nx,ny) + real tabler_sw(nx,ny) + real tabler_nw(nx,ny) + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + + real soft_snow_d(nx,ny) + real Qsubl(nx,ny) + real topo(nx,ny) + real topo_land(nx,ny) + real topo_tmp(nx,ny) + + real dh_salt(nx,ny) + real dh_salt_u(nx,ny) + real dh_salt_v(nx,ny) + + real dh_susp(nx,ny) + real dh_susp_u(nx,ny) + real dh_susp_v(nx,ny) + + real dh_subgrid(nx,ny) + real dh_dep(nx,ny) + + real Qsalt_u(nx,ny) + real Qsalt_v(nx,ny) + + real Qsusp_u(nx,ny) + real Qsusp_v(nx,ny) + + real wbal_qsubl(nx,ny) + real wbal_salt(nx,ny) + real wbal_susp(nx,ny) + real wbal_subgrid(nx,ny) + real sum_qsubl(nx,ny) + real sum_trans(nx,ny) + + real vegsnowd_xy(nx,ny) + + integer index_ue(ny_max,2*nx_max+1) + integer index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1) + integer index_vs(nx_max,2*ny_max+1) + + real extra,space,fill,undef + real pi,rad2deg,bsflux_dir,bs_flux_u,bs_flux_v,subgrid_dir + +! Define the required constants. + pi = 2.0 * acos(0.0) + rad2deg = 180.0 / pi + +! COMPUTE THE NEW SNOW DEPTH. + +! PRECIPITATION +! Account for the addition due to snow precipitation. +! This is now updated at the beginning of the program (day). + +! Sum the precipitation in terms of snow depth. + if (bs_flag.eq.1.0) then + +! SALTATION + + call getnewdepth(nx,ny,deltax,deltay,Qsalt_u,& + & Qsalt_v,dh_salt_u,dh_salt_v,index_ue,index_uw,& + & index_vn,index_vs,ro_snow,dt,vegsnowd_xy,snow_d,& + & soft_snow_d,snow_d_dep,soft_snow_d_dep,subgrid_flag) + +! This saves the deposition part of the snow-depth change. + if (subgrid_flag.eq.1.0) then + do i=1,nx + do j=1,ny + dh_dep(i,j) = snow_d_dep(i,j) + enddo + enddo + endif + + do i=1,nx + do j=1,ny + dh_salt(i,j) = dh_salt_u(i,j) + dh_salt_v(i,j) + enddo + enddo + +! SUSPENSION + + call getnewdepth(nx,ny,deltax,deltay,Qsusp_u,& + & Qsusp_v,dh_susp_u,dh_susp_v,index_ue,index_uw,& + & index_vn,index_vs,ro_snow,dt,vegsnowd_xy,snow_d,& + & soft_snow_d,snow_d_dep,soft_snow_d_dep,subgrid_flag) + +! This adds the suspension part the deposition to the +! saltation part of the snow-depth change. + if (subgrid_flag.eq.1.0) then + do i=1,nx + do j=1,ny + dh_dep(i,j) = dh_dep(i,j) + snow_d_dep(i,j) + enddo + enddo + endif + + do i=1,nx + do j=1,ny + dh_susp(i,j) = dh_susp_u(i,j) + dh_susp_v(i,j) + enddo + enddo + +! Save a copy of the snow distribution to be used to calculate the +! snow distribution changes resulting from the subgrid +! redistribution. + do i=1,nx + do j=1,ny + snow_d_tmp(i,j) = snow_d(i,j) + enddo + enddo + +! Run the subgrid parameterization to account for unrealistic +! snow accumulation spikes. + if (subgrid_flag.eq.1.0) then + +! Do the Tabler corrections while assuming the constant snow density +! defined in snowmodel.par (ro_snow). This is done to avoid all +! of the messy tracking of different density snows that is being +! blown around by the wind. This simplification could be relaxed +! at some point, but it is not an easy accounting, and I don't +! think it is justified at this point, given everything else that +! we don't know. snow_d is coming in from SnowPack where the +! ro_snow adjustment has already been made. When all of the Tabler +! calculations are finished, then we will convert back from the +! SnowTran constant density convention to the SnowPack ro_snow_grid +! spatially distributed snow density. Note that here, that coming +! from SnowPack, if the snow depth equals zero, the snow density +! is undefined. This can cause problems for the case where Tabler +! has moved snow into a previously snow-free grid cell; that grid +! cell will also need a snow density assigned to it. Right now I +! am assigning that value to be ro_snow from snowmodel.par. + do i=1,nx + do j=1,ny + snow_d_tabler(i,j) = snow_d(i,j) + enddo + enddo + +! The following subgrid_1 subroutine was saved because it provides +! an example of how to relax the assumption of a single wind +! direction over the entire domain at a given time step. This +! is the old subgrid routine that is no longer used or supported. +! if (subgrid_flag.eq.1.0) then +! call subgrid_1(nx,ny,snow_d_tabler, +! & index_ue,index_uw,index_vn,index_vs, +! & tabler_nn,tabler_ss,tabler_ee,tabler_ww, +! & tabler_ne,tabler_se,tabler_sw,tabler_nw,uwind_grid, +! & vwind_grid,tabler_dir) +! endif + +! Calculate the integrated snow-transport direction. + +! Initialize the summing arrays. + bs_flux_u = 0.0 + bs_flux_v = 0.0 + +! Sum the fluxes in the u-v directions. Add the u-v sign to the +! fluxes so there is a direction associated with them. + do i=1,nx + do j=1,ny + bs_flux_u = bs_flux_u + & + & sign(Qsalt_u(i,j),uwind_grid(i,j)) + & + & sign(Qsusp_u(i,j),uwind_grid(i,j)) + bs_flux_v = bs_flux_v + & + & sign(Qsalt_v(i,j),vwind_grid(i,j)) + & + & sign(Qsusp_v(i,j),vwind_grid(i,j)) + enddo + enddo + +! Calculate the resulting direction. Some compilers do not +! allow both u and v to be 0.0 in the atan2 computation. + if (abs(bs_flux_u).lt.1e-10) bs_flux_u = 1e-10 + bsflux_dir = rad2deg * atan2(bs_flux_u,bs_flux_v) + if (bsflux_dir.ge.180.0) then + bsflux_dir = bsflux_dir - 180.0 + else + bsflux_dir = bsflux_dir + 180.0 + endif + +! print *,bsflux_dir,bs_flux_u,bs_flux_v +! print *,bsflux_dir,bs_flux_u,bs_flux_v +! print *,bsflux_dir,bs_flux_u,bs_flux_v +! print *,bsflux_dir,bs_flux_u,bs_flux_v + +! Decide whether tabler_dir or bsflux_dir is going to be used to do +! the Tabler-surface snow redistributions. + if (tabler_dir.lt.0.0) then + subgrid_dir = bsflux_dir +! print *, 'using bsflux_dir' + else + subgrid_dir = tabler_dir +! print *, 'using tabler_dir' + endif + +! Smooth the snow distribution to eliminate any sharp wind speed +! variations computed at the next time step. Define the number +! of times this is done to be a function of the curvature length +! scale and the grid increment. Unwanted peaks in the snow +! distributions can be further eliminated by adjusting the +! multiplication factor, xmult. Also see "loops_windwt_smoother" +! in micromet_code.f. +! xmult = 0.15 + xmult = 0.25 +! xmult = 0.5 + loops_snowd_smoother = nint(xmult * curve_len_scale / & + & (0.5 * (deltax + deltay))) + +! print * +! print *, 'loops_snowd_smoother ',loops_snowd_smoother +! print * + +! Don't do this smoothing if the domain is arbitrarily small. + if (nx.gt.100 .and. ny.gt.100) then + do k=1,loops_snowd_smoother + call smoother9(nx,ny,snow_d_tabler) + enddo + endif + +! Create Tabler surfaces from the snow on the ground at this +! time step, with just erosion taken into account (that's +! where we are at this point). Add that current snow depth +! to topo_land. Then use this to create the Tabler surface that +! will be used for this time step. Also define this depth to be +! dependent on the SnowPack spatially distributed snow density, +! not the constant density used in SnowTran. + do i=1,nx + do j=1,ny + topo_tmp(i,j) = snow_d_tabler(i,j) + topo_land(i,j) + enddo + enddo + +! The following loop does four things: + +! (1) Extract the Tabler surface for the direction of interest at +! this time step. + +! (2) The Tabler surfaces that were just generated have had topo_tmp +! subtracted off of them, giving just the drift profiles with +! things like zero drift depth on ridges and windwards slopes. +! So, add the snow depth, prior to any wind redistribution, to +! these Tabler surfaces. This will be the maximum snow depth +! allowed as part of the wind redistribution. + +! (3) Set the snow-free areas equal to the snow-holding depth. + +! (4) Save the calculated Tabler surface at this time step. You can +! comment this out if you don't want to write them out. + +! nn. +! Consider N winds. + if (subgrid_dir.gt.337.5 .and. subgrid_dir.le.360.0 .or. & + & subgrid_dir.ge.0.0 .and. subgrid_dir.le.22.5) then +! print *,'in nn' + +! Extract the Tabler surface. + irotate_flag = 1 + call tabler_n(nx,ny,topo_tmp,tabler_nn,deltay, & + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_nn(i,j) = snow_d_tabler(i,j) + tabler_nn(i,j) + tabler_nn(i,j) = max(tabler_nn(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0) & + & write(52,rec=iter) ((tabler_nn(i,j),i=1,nx),j=1,ny) + +! ne. +! Consider NE winds. + elseif (subgrid_dir.gt.22.5 .and. subgrid_dir.le.67.5) then +! print *,'in ne' + +! Extract the Tabler surface. + irotate_flag = 2 + call tabler_e(nx,ny,topo_tmp,tabler_ne,1.41*deltax, & + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_ne(i,j) = snow_d_tabler(i,j) + tabler_ne(i,j) + tabler_ne(i,j) = max(tabler_ne(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0) & + & write(52,rec=iter) ((tabler_ne(i,j),i=1,nx),j=1,ny) + +! ee. +! Consider E winds. + elseif (subgrid_dir.gt.67.5 .and. subgrid_dir.le.112.5) then +! print *,'in ee' + +! Extract the Tabler surface. + irotate_flag = 1 + call tabler_e(nx,ny,topo_tmp,tabler_ee,deltax, & + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_ee(i,j) = snow_d_tabler(i,j) + tabler_ee(i,j) + tabler_ee(i,j) = max(tabler_ee(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0) & + & write(52,rec=iter) ((tabler_ee(i,j),i=1,nx),j=1,ny) + +! se. +! Consider SE winds. + elseif(subgrid_dir.gt.112.5 .and. subgrid_dir.le.157.5)then +! print *,'in se' + +! Extract the Tabler surface. + irotate_flag = 2 + call tabler_s(nx,ny,topo_tmp,tabler_se,1.41*deltay,& + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_se(i,j) = snow_d_tabler(i,j) + tabler_se(i,j) + tabler_se(i,j) = max(tabler_se(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((tabler_se(i,j),i=1,nx),j=1,ny) + +! ss. +! Consider S winds. + elseif(subgrid_dir.gt.157.5 .and. subgrid_dir.le.202.5)then +! print *,'in ss' + +! Extract the Tabler surface. + irotate_flag = 1 + call tabler_s(nx,ny,topo_tmp,tabler_ss,deltay,& + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_ss(i,j) = snow_d_tabler(i,j) + tabler_ss(i,j) + tabler_ss(i,j) = max(tabler_ss(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((tabler_ss(i,j),i=1,nx),j=1,ny) + +! sw. +! Consider SW winds. + elseif(subgrid_dir.gt.202.5 .and. subgrid_dir.le.247.5)then +! print *,'in sw' + +! Extract the Tabler surface. + irotate_flag = 2 + call tabler_w(nx,ny,topo_tmp,tabler_sw,1.41*deltax,& + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_sw(i,j) = snow_d_tabler(i,j) + tabler_sw(i,j) + tabler_sw(i,j) = max(tabler_sw(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((tabler_sw(i,j),i=1,nx),j=1,ny) + +! ww. +! Consider W winds. + elseif(subgrid_dir.gt.247.5 .and. subgrid_dir.le.292.5)then +! print *,'in ww' + +! Extract the Tabler surface. + irotate_flag = 1 + call tabler_w(nx,ny,topo_tmp,tabler_ww,deltax,& + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_ww(i,j) = snow_d_tabler(i,j) + tabler_ww(i,j) + tabler_ww(i,j) = max(tabler_ww(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((tabler_ww(i,j),i=1,nx),j=1,ny) + +! nw. +! Consider NW winds. + elseif(subgrid_dir.gt.292.5 .and. subgrid_dir.le.337.5)then +! print *,'in nw' + +! Extract the Tabler surface. + irotate_flag = 2 + call tabler_n(nx,ny,topo_tmp,tabler_nw,1.41*deltay,& + & irotate_flag,slope_adjust) + +! Add the snow depth back on, and clip to the snow-holding depth. + do i=1,nx + do j=1,ny + tabler_nw(i,j) = snow_d_tabler(i,j) + tabler_nw(i,j) + tabler_nw(i,j) = max(tabler_nw(i,j),vegsnowd_xy(i,j)) + enddo + enddo + +! Save the Tabler surface. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((tabler_nw(i,j),i=1,nx),j=1,ny) + + else + print *,'subgrid_dir not found' + stop + + endif + +! Now add the +dh snow back on, and do the sweep that does not +! allow any snow to exist above the Tabler surface. + do i=1,nx + do j=1,ny + snow_d_tabler(i,j) = snow_d_tabler(i,j) + dh_dep(i,j) + enddo + enddo + +! Sweep across the domain in the direction defined by tabler_dir +! or bsflux_dir (see above; now defined by subgrid_dir). This is +! done in the same direction across the entire domain. If using +! tabler_dir, then it is the same direction for all time steps. +! If using bsflux_dir, then it varies for each time step depending +! on the dominant transport direction. If you ever want to relax +! this "same direction over the entire domain" assumption, see +! the subgrid_1 subroutine (search subgrid_1 in this document; it +! is all commented out). + +! nn. +! Consider N winds. + if (subgrid_dir.gt.337.5 .and. subgrid_dir.le.360.0 .or. & + & subgrid_dir.ge.0.0 .and. subgrid_dir.le.22.5) then +! print *,'in nn' + +! Do the sweep in the direction of interest. + do i=1,nx + extra = 0.0 + do j=ny,1,-1 + if (snow_d_tabler(i,j).ge.tabler_nn(i,j)) then + extra = extra + snow_d_tabler(i,j) - tabler_nn(i,j) + snow_d_tabler(i,j) = tabler_nn(i,j) + else + space = tabler_nn(i,j) - snow_d_tabler(i,j) + fill = min(extra,space) + snow_d_tabler(i,j) = snow_d_tabler(i,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + enddo + enddo + +! ne. +! Consider NE winds. + elseif (subgrid_dir.gt.22.5 .and. subgrid_dir.le.67.5) then +! print *,'in ne' + +! Do the sweep in the direction of interest. + nny = nx + ny - 1 + do j=1,nny + extra = 0.0 + do i=nx,1,-1 + JJ = j + i - nx + if (JJ.ge.1 .and. JJ.le.ny) then + if (snow_d_tabler(i,JJ).ge.tabler_ne(i,JJ)) then + extra = extra+snow_d_tabler(i,JJ)-tabler_ne(i,JJ) + snow_d_tabler(i,JJ) = tabler_ne(i,JJ) + else + space = tabler_ne(i,JJ) - snow_d_tabler(i,JJ) + fill = min(extra,space) + snow_d_tabler(i,JJ) = snow_d_tabler(i,JJ) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + endif + enddo + enddo + +! ee. +! Consider E winds. + elseif (subgrid_dir.gt.67.5 .and. subgrid_dir.le.112.5) then +! print *,'in ee' + +! Do the sweep in the direction of interest. + do j=1,ny + extra = 0.0 + do i=nx,1,-1 + if (snow_d_tabler(i,j).ge.tabler_ee(i,j)) then + extra = extra + snow_d_tabler(i,j) - tabler_ee(i,j) + snow_d_tabler(i,j) = tabler_ee(i,j) + else + space = tabler_ee(i,j) - snow_d_tabler(i,j) + fill = min(extra,space) + snow_d_tabler(i,j) = snow_d_tabler(i,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + enddo + enddo + +! se. +! Consider SE winds. + elseif(subgrid_dir.gt.112.5 .and. subgrid_dir.le.157.5)then +! print *,'in se' + +! Do the sweep in the direction of interest. + nnx = nx + ny - 1 + do i=1,nnx + extra = 0.0 + do j=1,ny + II = i - j + 1 + if (II.ge.1 .and. II.le.nx) then + if (snow_d_tabler(II,j).ge.tabler_se(II,j)) then + extra = extra+snow_d_tabler(II,j)-tabler_se(II,j) + snow_d_tabler(II,j) = tabler_se(II,j) + else + space = tabler_se(II,j) - snow_d_tabler(II,j) + fill = min(extra,space) + snow_d_tabler(II,j) = snow_d_tabler(II,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + endif + enddo + enddo + +! ss. +! Consider S winds. + elseif(subgrid_dir.gt.157.5 .and. subgrid_dir.le.202.5)then +! print *,'in ss' + +! Do the sweep in the direction of interest. + do i=1,nx + extra = 0.0 + do j=1,ny + if (snow_d_tabler(i,j).ge.tabler_ss(i,j)) then + extra = extra + snow_d_tabler(i,j) - tabler_ss(i,j) + snow_d_tabler(i,j) = tabler_ss(i,j) + else + space = tabler_ss(i,j) - snow_d_tabler(i,j) + fill = min(extra,space) + snow_d_tabler(i,j) = snow_d_tabler(i,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + enddo + enddo + +! sw. +! Consider SW winds. + elseif(subgrid_dir.gt.202.5 .and. subgrid_dir.le.247.5)then +! print *,'in sw' + +! Do the sweep in the direction of interest. + nny = nx + ny - 1 + do j=1,nny + extra = 0.0 + do i=1,nx + JJ = j + i - nx + if (JJ.ge.1 .and. JJ.le.ny) then + if (snow_d_tabler(i,JJ).ge.tabler_sw(i,JJ)) then + extra = extra+snow_d_tabler(i,JJ)-tabler_sw(i,JJ) + snow_d_tabler(i,JJ) = tabler_sw(i,JJ) + else + space = tabler_sw(i,JJ) - snow_d_tabler(i,JJ) + fill = min(extra,space) + snow_d_tabler(i,JJ) = snow_d_tabler(i,JJ) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + endif + enddo + enddo + +! ww. +! Consider W winds. + elseif(subgrid_dir.gt.247.5 .and. subgrid_dir.le.292.5)then +! print *,'in ww' + +! Do the sweep in the direction of interest. + do j=1,ny + extra = 0.0 + do i=1,nx + if (snow_d_tabler(i,j).ge.tabler_ww(i,j)) then + extra = extra + snow_d_tabler(i,j) - tabler_ww(i,j) + snow_d_tabler(i,j) = tabler_ww(i,j) + else + space = tabler_ww(i,j) - snow_d_tabler(i,j) + fill = min(extra,space) + snow_d_tabler(i,j) = snow_d_tabler(i,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + enddo + enddo + +! nw. +! Consider NW winds. + elseif(subgrid_dir.gt.292.5 .and. subgrid_dir.le.337.5)then +! print *,'in nw' + +! Do the sweep in the direction of interest. + nnx = nx + ny - 1 + do i=1,nnx + extra = 0.0 + do j=ny,1,-1 + II = i - j + 1 + if (II.ge.1 .and. II.le.nx) then + if (snow_d_tabler(II,j).ge.tabler_nw(II,j)) then + extra = extra+snow_d_tabler(II,j)-tabler_nw(II,j) + snow_d_tabler(II,j) = tabler_nw(II,j) + else + space = tabler_nw(II,j) - snow_d_tabler(II,j) + fill = min(extra,space) + snow_d_tabler(II,j) = snow_d_tabler(II,j) + fill + extra = extra - fill + if (extra.lt.0.0) print *,'extra < 0.0',extra + endif + endif + enddo + enddo + + else + print *,'subgrid_dir not found' + stop + + endif + +! Update the snow depths using the Tabler adjustments. + do i=1,nx + do j=1,ny + snow_d(i,j) = snow_d_tabler(i,j) + enddo + enddo + + endif +! End subgrid_flag = 1.0. + +! Calculate the snow depth resulting from the subgrid +! redistribution. + do i=1,nx + do j=1,ny + dh_subgrid(i,j) = snow_d(i,j) - snow_d_tmp(i,j) + enddo + enddo + +! SUBLIMATION +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. Since Qsubl is blowing snow sublimation, don't let +! this sublimation reach down into the hard snow layer or into +! the vegsnowd, because that snow is not available to be blown +! around. I don't think it matters much whether this is done +! before or after the Tabler subgrid redistribution. + do i=1,nx + do j=1,ny + hard_snow_d = snow_d(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + +! Convert Qsubl flux to sublimated snow depth. + Qsubl(i,j) = Qsubl(i,j) * dt / ro_snow + + if (snow_d(i,j).gt.snowdmin) then + if (snow_d(i,j)+Qsubl(i,j).le.snowdmin) then + Qsubl(i,j) = snowdmin - snow_d(i,j) + endif + else + Qsubl(i,j) = 0.0 + endif + enddo + enddo + +! Account for decreases in snow depth due to sublimation. Note +! that the subgrid_flag = 1.0 routines have not modified the +! soft snow depth in any way. Changes must be made if this is +! not an appropriate assumption. + do i=1,nx + do j=1,ny + snow_d(i,j) = snow_d(i,j) + Qsubl(i,j) + soft_snow_d(i,j) = soft_snow_d(i,j) + Qsubl(i,j) + enddo + enddo + +! Find any undefined ro_snow_grid(i,j) values, that correspond to +! non-zero snow_d(i,j) values, and fill them in with ro_snow. +! This no longer seems to be required. Any zero snow_d(i,j) +! values should have ro_snow in the ro_snow_grid(i,j) positions +! from the initial conditions that were provided. +! do i=1,nx +! do j=1,ny +! the checking code would go here. +! enddo +! enddo + +! Update the surface topography resulting from the snow setting +! on the land. + if (topoflag.eq.1.0) then + do i=1,nx + do j=1,ny +! This gives the constant density version. +! topo(i,j) = topo_land(i,j) + snow_d(i,j) +! This gives the spatially distributed density version. + topo(i,j) = topo_land(i,j) + snow_d(i,j) * & + & ro_snow_grid(i,j) / ro_snow + enddo + enddo + elseif (topoflag.eq.0.0) then + do i=1,nx + do j=1,ny + topo(i,j) = topo_land(i,j) + enddo + enddo + endif + + else +! Because a Tabler surface was not generated or used (because there +! was no blowing snow), save this time step as undef values. + if (Tabler_2_flag.eq.1.0)& + & write(52,rec=iter) ((undef,i=1,nx),j=1,ny) + +! This ends the "if blowing snow flag = 1" case. + endif + +! MOISTURE BALANCE +! Save enough information to do a moisture balance. + do i=1,nx + do j=1,ny + +! Save the sublimation in terms of swe depth. + wbal_qsubl(i,j) = Qsubl(i,j) * ro_snow / ro_water + +! Save the saltation in terms of swe depth. + wbal_salt(i,j) = dh_salt(i,j) * ro_snow / ro_water + +! Save the suspension in terms of swe depth. + wbal_susp(i,j) = dh_susp(i,j) * ro_snow / ro_water + +! Save the subgrid redistribution in terms of swe depth. + wbal_subgrid(i,j) = dh_subgrid(i,j) * ro_snow / ro_water + +! Fill summing arrays of the sublimation and transport quantities. + sum_qsubl(i,j) = sum_qsubl(i,j) + wbal_qsubl(i,j) + sum_trans(i,j) = sum_trans(i,j) + wbal_salt(i,j) + & + & wbal_susp(i,j) + wbal_subgrid(i,j) + + enddo + enddo + + do i=1,nx + do j=1,ny + +! Convert any snow-depth adjustments that occurred in SnowTran-3D +! to swe (using the SnowTran-3D constant snow density) so +! that it can be used in SNOWPACK that accounts for the +! time-evolution of snow density. + swe_depth(i,j) = snow_d(i,j) * ro_snow / ro_water + +! Calculate the snow depth using the spatially-distributed snow density +! from the snowpack model. + snow_depth(i,j) = swe_depth(i,j) * & + ro_water / ro_snow_grid(i,j) + + enddo + enddo + + return + end subroutine accum + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine smoother9(nx,ny,snow) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny + real snow(nx,ny) + real snow_tmp(nx,ny) + +! Performs a 9-point smoothing operation. + +! The result at each grid point is a weighted average of the grid +! point and the surrounding 8 points. The center point receives +! a weight of 1.0, the points at each side and above and below +! receive a weight of 0.5, and corner points receive a weight of +! 0.3. All points are multiplied by their weights and summed, +! then divided by the total weight. + +! Do the interior. + do i=2,nx-1 + do j=2,ny-1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + & + & snow(i,j+1) + snow(i-1,j) + snow(i+1,j)) + 0.3 *& + & (snow(i-1,j-1) + snow(i+1,j+1) + snow(i-1,j+1) +& + & snow(i+1,j-1))) / 4.2 + enddo + enddo + +! Do the sides. + j = 1 + do i=2,nx-1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j+1) + snow(i-1,j) +& + & snow(i+1,j)) + 0.3 * (snow(i+1,j+1) + snow(i-1,j+1))) / 3.1 + enddo + + j = ny + do i=2,nx-1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + snow(i-1,j) +& + & snow(i+1,j)) + 0.3 * (snow(i+1,j-1) + snow(i-1,j-1))) / 3.1 + enddo + + i = 1 + do j=2,ny-1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + snow(i,j+1) +& + & snow(i+1,j)) + 0.3 * (snow(i+1,j-1) + snow(i+1,j+1))) / 3.1 + enddo + + i = nx + do j=2,ny-1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + snow(i,j+1) +& + & snow(i-1,j)) + 0.3 * (snow(i-1,j-1) + snow(i-1,j+1))) / 3.1 + enddo + +! Do the corners. + i = 1 + j = 1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j+1) + snow(i+1,j)) +& + & 0.3 * snow(i+1,j+1)) / 2.3 + + i = nx + j = 1 + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j+1) + snow(i-1,j)) +& + & 0.3 * snow(i-1,j+1)) / 2.3 + + i = 1 + j = ny + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + snow(i+1,j)) +& + & 0.3 * snow(i+1,j-1)) / 2.3 + + i = nx + j = ny + snow_tmp(i,j) = (snow(i,j) + 0.5 * (snow(i,j-1) + snow(i-1,j)) +& + & 0.3 * snow(i-1,j-1)) / 2.3 + +! Return the smoothed array. + do i=1,nx + do j=1,ny + snow(i,j) = snow_tmp(i,j) + enddo + enddo + + return + end subroutine smoother9 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine suspension(Utau,vonKarman,nx,ny,conc_salt,& + & Qsalt,Qsusp,z_0,h_star,dz,ztop,pi,& + & fall_vel,Ur_const,Up_const,Utau_t,Qsubl,ht_rhobs,& + & tair_grid,rh_grid,Qsusp_u,Qsusp_v,uwind_grid,& + & vwind_grid) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,nzsteps,iz + + real vonKarman,dz,ztop,fall_vel,Ur_const,Up_const + real ht_rhobs,V_susp,V_salt,pi + real U_p,Utau_fallvel,U_r,phistar_Cr,product,conc,z + + real Utau(nx,ny) + real Utau_t(nx,ny) + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + real z_0(nx,ny) + real h_star(nx,ny) + real conc_salt(nx,ny) + real Qsalt(nx,ny) + real Qsusp(nx,ny) + real Qsusp_u(nx,ny) + real Qsusp_v(nx,ny) + real Qsubl(nx,ny) + + real tair_grid(nx,ny) + real rh_grid(nx,ny) + +! Compute the mass concentration of suspended snow according to +! Kind (1992). + + do i=1,nx + do j=1,ny + if (Qsalt(i,j).gt.0.0) then + Utau_fallvel = Utau(i,j) / fall_vel + if (h_star(i,j).eq.z_0(i,j)) h_star(i,j) = 2.0 * z_0(i,j) + U_r = Utau(i,j)/vonKarman * log(h_star(i,j)/z_0(i,j)) + phistar_Cr = Utau(i,j)/U_r * Ur_const + product = phistar_Cr * Utau_fallvel + U_p = Up_const * Utau_t(i,j) + +! Compute the concentration in the saltation layer (kg/m**3). + conc_salt(i,j) = Qsalt(i,j) / (h_star(i,j) * U_p) + + nzsteps = int((ztop - h_star(i,j)) / dz) + + Qsusp(i,j) = 0.0 + Qsubl(i,j) = 0.0 + + do iz=1,nzsteps + z = h_star(i,j) + 0.5 * dz + real(iz - 1) * dz + +! Compute the concentration of the suspended snow at height z. + conc = conc_salt(i,j) * ((product + 1.0) * & + & (z/h_star(i,j))**((-fall_vel)/(vonKarman*Utau(i,j))) - & + & product) + conc = max(conc,0.0) + +! Only do The integration if the concentration is non-zero. + if (conc.gt.0.0) then + +! Compute the sublimation due to suspension. + call getsublim(z,rh_grid(i,j),tair_grid(i,j),Utau(i,j),& + & z_0(i,j),V_susp,V_salt,Utau_t(i,j),ht_rhobs,1.0,pi) + +! Perform the quadrature (summation), without the constants. + if (z.eq.z_0(i,j)) z = 1.2 * z_0(i,j) + Qsusp(i,j) = Qsusp(i,j) + conc * log(z/z_0(i,j)) * dz + Qsubl(i,j) = Qsubl(i,j) + conc * V_susp * dz + + endif + + enddo + +! Finish the quadratures. +! Include the constants for Qsusp. + Qsusp(i,j) = Utau(i,j) / vonKarman * Qsusp(i,j) + +! Include the sublimation contribution due to saltation. + z = h_star(i,j) / 2.0 + call getsublim(z,rh_grid(i,j),tair_grid(i,j),Utau(i,j),& + & z_0(i,j),V_susp,V_salt,Utau_t(i,j),ht_rhobs,0.0,pi) + + Qsubl(i,j) = Qsubl(i,j) +& + & V_salt * conc_salt(i,j) * h_star(i,j) + + else + conc_salt(i,j) = 0.0 + Qsusp(i,j) = 0.0 + Qsubl(i,j) = 0.0 + endif + + enddo + enddo + +! Separate the east-west and the north-south suspended transport +! components; the vector sum should equal Qsusp. + do i=1,nx + do j=1,ny + Qsusp_u(i,j) = Qsusp(i,j) * abs(uwind_grid(i,j)) /& + & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + Qsusp_v(i,j) = Qsusp(i,j) * abs(vwind_grid(i,j)) /& + & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + enddo + enddo + + return + end subroutine suspension + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine saltation(Qsalt,deltax,fetch,Utau,Utau_t,nx,ny,& + & ro_air,gravity,vegsnowd_xy,snow_d,& + & Qsalt_max,Qsalt_maxu,Qsalt_maxv,deltay,Qsalt_u,Qsalt_v,& + & index_ue,index_uw,index_vn,index_vs,uwind_grid,& + & vwind_grid,xmu,soft_snow_d,bc_flag) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny + integer k,istart,iend,jstart,jend + + real deltax,deltay,fetch,ro_air,gravity,dUtau,xmu,& + & blowby,bc_flag + + real Qsalt_max(nx,ny) + real Qsalt_maxu(nx,ny) + real Qsalt_maxv(nx,ny) + real Qsalt(nx,ny) + real Qsalt_u(nx,ny) + real Qsalt_v(nx,ny) + real Utau(nx,ny) + real Utau_t(nx,ny) + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + real snow_d(nx,ny) + real soft_snow_d(nx,ny) + real vegsnowd_xy(nx,ny) + + integer index_ue(ny_max,2*nx_max+1) + integer index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1) + integer index_vs(nx_max,2*ny_max+1) + + real scale_EW,scale_NS + +! The blowby parameter is implemented to account for the erosion +! of the tops of deep snow accumulations. It corrects a +! deficiency in the du*/dx* < 0 formulation. It is a number that +! should range from 0 to 1.0, and represents the fraction of the +! upwind saltation flux that is transfered farther downwind into +! the next grid cell. So, the bigger the number, the less +! peaked the drift accumulation profile is. blowby = 0.0 is the +! original model. I am now using the Tabler surfaces to do the +! same kind of thing, so here I hard-code the parameter as in the +! original model. + blowby = 0.0 + +! Compute the maximum possible saltation flux, assuming that +! an abundance of snow is available at the surface. + do i=1,nx + do j=1,ny + +! For a given wind speed, find Qsalt_max. + Qsalt_max(i,j) = 0.68 * ro_air / gravity * & + & Utau_t(i,j) / Utau(i,j) * (Utau(i,j)**2 - Utau_t(i,j)**2) + Qsalt_max(i,j) = max(Qsalt_max(i,j),0.0) + +! Now weight the max saltation flux for the u and v wind +! components, where the vector sum should equal Qsalt_max. + Qsalt_maxu(i,j) = Qsalt_max(i,j) * abs(uwind_grid(i,j)) / & + & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + Qsalt_maxv(i,j) = Qsalt_max(i,j) * abs(vwind_grid(i,j)) / & + & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) + enddo + enddo + +! Define an upwind boundary condition. If bc_flag = 1.0 then it is +! assumed that the inflow saltation flux has reached steady state. +! If bc_flag = 0.0 then the saltation flux is assumed to be zero. +! The boundary condition is implemented by initializing the arrays +! to Qsalt_max, and since upwind boundaries are not called in +! the Qsalt computation, they stay in effect for the future +! accumulation/erosion computation. + if (bc_flag.eq.0.0) then + do i=1,nx + do j=1,ny +! Zero incoming flux at the boundaries. + Qsalt_u(i,j) = 0.0 + Qsalt_v(i,j) = 0.0 + enddo + enddo + elseif (bc_flag.eq.1.0) then + do i=1,nx + do j=1,ny +! Steady-state (maximum) incoming flux at the boundaries. + Qsalt_u(i,j) = Qsalt_maxu(i,j) + Qsalt_v(i,j) = Qsalt_maxv(i,j) + enddo + enddo + endif + +! Define the scaling coefficients for Eqn. 9 in L&S 1998. Don't +! let them be greater than 1.0 or you will make more snow than +! there was before. + scale_EW = xmu * deltax / fetch + scale_EW = min(1.0,scale_EW) + scale_NS = xmu * deltay / fetch + scale_NS = min(1.0,scale_NS) + +! Consider WESTERLY winds. + do j=1,ny + do k=1,index_uw(j,1) + istart = index_uw(j,k*2)+1 + iend = index_uw(j,k*2+1) + do i=istart,iend + dUtau = Utau(i,j) - Utau(i-1,j) + if (dUtau.ge.0.0) then + Qsalt_u(i,j) = Qsalt_u(i-1,j) + scale_EW * & + & (Qsalt_maxu(i,j) - Qsalt_u(i-1,j)) + else +! Qsalt_u(i,j) = min(Qsalt_u(i-1,j),Qsalt_maxu(i,j)) + + if (Qsalt_u(i-1,j).lt.Qsalt_maxu(i,j)) then + Qsalt_u(i,j) = Qsalt_u(i-1,j) + else + Qsalt_u(i,j) = & + & max(blowby*Qsalt_u(i-1,j),Qsalt_maxu(i,j)) + endif + + endif + enddo + enddo + enddo + +! Consider EASTERLY winds. + do j=1,ny + do k=1,index_ue(j,1) + iend = index_ue(j,k*2) + istart = index_ue(j,k*2+1)-1 + do i=istart,iend,-1 + dUtau = Utau(i,j) - Utau(i+1,j) + if (dUtau.ge.0.0) then + Qsalt_u(i,j) = Qsalt_u(i+1,j) + scale_EW * & + & (Qsalt_maxu(i,j) - Qsalt_u(i+1,j)) + else +! Qsalt_u(i,j) = min(Qsalt_u(i+1,j),Qsalt_maxu(i,j)) + + if (Qsalt_u(i+1,j).lt.Qsalt_maxu(i,j)) then + Qsalt_u(i,j) = Qsalt_u(i+1,j) + else + Qsalt_u(i,j) = & + & max(blowby*Qsalt_u(i+1,j),Qsalt_maxu(i,j)) + endif + + endif + enddo + enddo + enddo + +! Consider SOUTHERLY winds. + do i=1,nx + do k=1,index_vs(i,1) + jstart = index_vs(i,k*2)+1 + jend = index_vs(i,k*2+1) + do j=jstart,jend + dUtau = Utau(i,j) - Utau(i,j-1) + if (dUtau.ge.0.0) then + Qsalt_v(i,j) = Qsalt_v(i,j-1) + scale_NS * & + & (Qsalt_maxv(i,j) - Qsalt_v(i,j-1)) + else +! Qsalt_v(i,j) = min(Qsalt_v(i,j-1),Qsalt_maxv(i,j)) + + if (Qsalt_v(i,j-1).lt.Qsalt_maxv(i,j)) then + Qsalt_v(i,j) = Qsalt_v(i,j-1) + else + Qsalt_v(i,j) = & + & max(blowby*Qsalt_v(i,j-1),Qsalt_maxv(i,j)) + endif + + endif + enddo + enddo + enddo + +! Consider NORTHERLY winds. + do i=1,nx + do k=1,index_vn(i,1) + jend = index_vn(i,k*2) + jstart = index_vn(i,k*2+1)-1 + do j=jstart,jend,-1 + dUtau = Utau(i,j) - Utau(i,j+1) + if (dUtau.ge.0.0) then + Qsalt_v(i,j) = Qsalt_v(i,j+1) + scale_NS * & + & (Qsalt_maxv(i,j) - Qsalt_v(i,j+1)) + else +! Qsalt_v(i,j) = min(Qsalt_v(i,j+1),Qsalt_maxv(i,j)) + + if (Qsalt_v(i,j+1).lt.Qsalt_maxv(i,j)) then + Qsalt_v(i,j) = Qsalt_v(i,j+1) + else + Qsalt_v(i,j) = & + & max(blowby*Qsalt_v(i,j+1),Qsalt_maxv(i,j)) + endif + + endif + enddo + enddo + enddo + +! Combine the u and v components to yield the total saltation flux +! at each grid cell. + do i=1,nx + do j=1,ny + Qsalt(i,j) = Qsalt_u(i,j) + Qsalt_v(i,j) + enddo + enddo + +! Adjust Qsalt to account for the availablity of snow for transport; +! taking into consideration whether there is snow on the ground, +! the holding depth of the vegetation, etc.. + do i=1,nx + do j=1,ny + if (snow_d(i,j).le.vegsnowd_xy(i,j)) Qsalt(i,j) = 0.0 + if (soft_snow_d(i,j).le.0.0) Qsalt(i,j) = 0.0 + enddo + enddo + + return + end subroutine saltation + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine solveUtau(Utau,ht_windobs,windspd_grid,C_z,vonKarman,& + & gravity,z_0,h_star,h_const,vegsnowd_xy,snow_d,& + & snow_z0,veg_z0,bs_flag,nx,ny,Utau_t,soft_snow_d) + + use snowmodel_inc + !KRA + use LIS_coreMod + use LIS_mpiMod + use snowmodel_lsmMod, only : snowmodel_struc + !KRA + + implicit none + + integer :: ierr ! KRA + + integer i,j,nx,ny + + real bs_flag,guess,sfrac,vonKarman,ht_windobs,C_z,gravity + real h_const,snow_z0,Utautmp,windtmp,wind_max + real threshold,threshold_flag,z_0_tmp + + real Utau(nx,ny) + real Utau_t(nx,ny) + real windspd_grid(nx,ny) + real z_0(nx,ny) + real h_star(nx,ny) + real snow_d(nx,ny) + real soft_snow_d(nx,ny) + real veg_z0(nx,ny) + real vegsnowd_xy(nx,ny) + +! Initially set the blowing snow flag to no blowing snow +! (bs_flag = 0.0). Then, if snow is found to blow in any +! domain grid cell, set the flag to on (bs_flag = 1.0). + bs_flag = 0.0 + +! Build the Utau array. + guess = 0.1 + do i=1,nx + do j=1,ny + +! Determine whether snow is saltating (this influences how Utau +! and z_0 are computed). + if (snow_d(i,j).le.vegsnowd_xy(i,j)) then + +! Saltation will not occur. + sfrac = snow_d(i,j) / max(vegsnowd_xy(i,j),veg_z0(i,j)) + z_0(i,j) = sfrac * snow_z0 + (1.0 - sfrac) * veg_z0(i,j) + z_0_tmp = min(0.25*ht_windobs,z_0(i,j)) + Utau(i,j) = windspd_grid(i,j) * & + & vonKarman / log(ht_windobs/z_0_tmp) + h_star(i,j) = z_0(i,j) * h_const / C_z + elseif (soft_snow_d(i,j).le.0.0) then +! Saltation will not occur. + z_0(i,j) = snow_z0 + Utau(i,j) = windspd_grid(i,j) * & + & vonKarman / log(ht_windobs/z_0(i,j)) + h_star(i,j) = z_0(i,j) + else +! Saltation may occur. Test for that possibility by assuming that +! saltation is present, solving for Utau and z_0, and comparing +! whether Utau exceeds Utau_t. If it does not, set z_0 to that +! of snow and recompute Utau. + +! To help insure that the iteration converges, set the minimum +! wind speed to be 1.0 m/s, and the maximum wind speed to be +! 30 m/s at 10-m height. + windtmp = max(1.0,windspd_grid(i,j)) + wind_max = 30.0 * log(ht_windobs/snow_z0)/log(10.0/snow_z0) + windtmp = min(windtmp,wind_max) + +! For u* over 0.6, use the relation z0 = 0.00734 u* - 0.0022, +! instead of Equation (5) in Liston and Sturm (1998). Note that +! for windspeeds greater than about 35 m/s this will have to be +! modified for the solution algorithm to converge (because the +! roughness length will start to be higher than the obs height!). + threshold = 0.6/vonKarman * log(ht_windobs/0.0022) + if (windtmp.le.threshold) then + threshold_flag = 1.0 + else + threshold_flag = 2.0 + endif + + call solve1(Utautmp,guess,ht_windobs,windtmp,C_z,vonKarman,& + & gravity,threshold_flag) + + if (Utautmp.gt.Utau_t(i,j)) then + +! We have saltation. + Utau(i,j) = Utautmp + z_0(i,j) = C_z * Utau(i,j)**2 / (2.0 * gravity) + h_star(i,j) = h_const * Utau(i,j)**2 / (2.0 * gravity) + bs_flag = 1.0 + else + +! We do not have saltation, but the vegetation is covered by snow. +! Because we have determined that we do not have saltation, make +! sure Utau does not exceed Utau_t. + z_0(i,j) = snow_z0 + Utau(i,j) = windspd_grid(i,j) * & + & vonKarman / log(ht_windobs/z_0(i,j)) + Utau(i,j) = min(Utau(i,j),Utau_t(i,j)) + h_star(i,j) = z_0(i,j) * h_const / C_z + + endif + endif + + enddo + enddo + +! KRA +#if (defined SPMD) +! call co_max(bs_flag) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(bs_flag, snowmodel_struc(1)%bsflag_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + bs_flag = snowmodel_struc(1)%bsflag_glb + ! print *, "final bs_flag: ", bs_flag +#endif +! KRA + + return + end subroutine solveUtau + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine solve1(xnew,guess,z,windtmp,C_z,vonKarman,& + & gravity,threshold_flag) + + implicit none + + integer i,maxiter + + real xnew,guess,z,windtmp,C_z,vonKarman,tol,old,gravity + real fprime,funct,threshold_flag + + tol = 1.0e-3 + maxiter = 20 + old = guess + + if (threshold_flag.eq.1.0) then + + do i=1,maxiter + fprime = - 1.0 + 2.0 / old * windtmp * vonKarman * & + & (log(z) - log(C_z/(2.0*gravity)) - 2.0*log(old))**(-2) + funct = - old + windtmp * vonKarman * & + & (log(z) - log(C_z/(2.0*gravity)) - 2.0*log(old))**(-1) + xnew = old - funct/fprime + if (abs(xnew - old).lt.tol) return + old = xnew + end do + + elseif (threshold_flag.eq.2.0) then + + old = 0.6 + do i=1,maxiter + fprime = - 1.0 + windtmp * vonKarman * & + & 0.00734 / (0.00734 * old - 0.0022) * & + & (log(z) - log(0.00734 * old - 0.0022))**(-2) + funct = - old + windtmp * vonKarman * & + & (log(z) - log(0.00734 * old - 0.0022))**(-1) + xnew = old - funct/fprime + if (abs(xnew - old).lt.tol) return + old = xnew + end do + + endif + + print *,'max iteration exceeded when solving for Utau, Utau=',old + + return + end subroutine solve1 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine getsublim(z,rh,tair,Utau,& + & z_0,V_susp,V_salt,Utau_t,ht_rhobs,flag,pi) + + implicit none + + real pi,ro_ice,xM,R,R_dryair,vonKarman,visc_air,h_s + real xlamdaT,D,ro_sat,rh_offset,sigma + real alfa,rbar_r,xmbar,rbar,u_z,x_r,wbar,flag + real z,rh,tair,Utau,z_0,V_susp,V_salt,Utau_t,ht_rhobs + real V_r,xN_r,xNu,xSh,tmp1,tmp2,top,bottom,V_rsalt + + ro_ice = 917.0 + xM = 18.01 + R = 8313. + R_dryair = 287. + vonKarman = 0.4 + visc_air = 13.e-6 + h_s = 2.838e6 + +! xlamdaT = 0.00063 * tair + 0.0673 + xlamdaT = 0.024 + D = 2.06e-5 * (tair/273.0)**(1.75) +! ro_sat = 0.622 * 10.0**(11.40 - 2353./tair) / (R_dryair * tair) + ro_sat = 0.622 / (R_dryair * tair) * & + & 610.78 * exp(21.875 * (tair - 273.15) / (tair - 7.66)) + +! Assume that the rh varies according to a modification to +! Pomeroy's humidity variation with height equation. + rh_offset = 1.0 - 0.027 * log(ht_rhobs) + sigma = (0.01 * rh - 1.0) * (rh_offset + 0.027 * log(z)) + sigma = min(0.0,sigma) + sigma = max(-1.0,sigma) + + alfa = 4.08 + 12.6 * z + rbar_r = 4.6e-5 * z**(-0.258) + xmbar = 4.0/3.0 * pi * ro_ice * rbar_r**3 * & + & (1.0 + 3.0/alfa + 2.0/alfa**2) + rbar = ((3.0 * xmbar) / (4.0 * pi * ro_ice))**(0.33) + u_z = Utau/vonKarman * log(z/z_0) + x_r = 0.005 * u_z**(1.36) + wbar = 1.1e7 * rbar**(1.8) + + if (flag.eq.1.0) then + +! Compute the sublimation loss rate coefficient for the suspension +! layer. + V_r = wbar + 3.0 * x_r * cos(pi/4.0) + xN_r = 2.0 * rbar * V_r / visc_air + xNu = 1.79 + 0.606 * xN_r**(0.5) + xSh = xNu + tmp1 = (h_s * xM)/(R * tair) - 1.0 + tmp2 = xlamdaT * tair * xNu + top = 2.0 * pi * rbar * sigma + bottom = h_s/tmp2 * tmp1 + 1.0/(D * ro_sat * xSh) + V_susp = (top/bottom)/xmbar + V_salt = 0.0 + + elseif (flag.eq.0.0) then + +! Compute the sublimation loss rate coefficient for the saltation +! layer. + V_rsalt = 0.68 * Utau + 2.3 * Utau_t + xN_r = 2.0 * rbar * V_rsalt / visc_air + xNu = 1.79 + 0.606 * xN_r**(0.5) + xSh = xNu + tmp1 = (h_s * xM)/(R * tair) - 1.0 + tmp2 = xlamdaT * tair * xNu + top = 2.0 * pi * rbar * sigma + bottom = h_s/tmp2 * tmp1 + 1.0/(D * ro_sat * xSh) + V_salt = (top/bottom)/xmbar + V_susp = 0.0 + + endif + + return + end subroutine getsublim + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine getdirection(nx,ny,uwind_grid,vwind_grid,index_ue,& + & index_uw,index_vn,index_vs) + + use snowmodel_inc + implicit none + + integer i,j,nx,ny,npairs + + real sign1,sign2 + + integer index_ue(ny_max,2*nx_max+1) + integer index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1) + integer index_vs(nx_max,2*ny_max+1) + + real uwind_grid(nx,ny) + real vwind_grid(nx,ny) + +! Index whether the winds are blowing east or west. The first +! column of the index array is the number of pairs of begining +! and ending array index of blocks of wind running in the same +! direction. + +! Sweep looking for WESTERLY winds, looking for positive numbers. + do j=1,ny + + if (uwind_grid(1,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.gt.0.0) then + npairs = 1 + index_uw(j,2) = 1 + else + npairs = 0 + endif + do i=2,nx + + if (uwind_grid(i-1,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + if (uwind_grid(i,j).le.0.0) then + sign2 = -1.0 + else + sign2 = 1.0 + endif + + if (sign2.ne.sign1) then +! We have a sign change. + if (sign2.gt.0.0) then +! We have gone from negative to positive, indicating the start +! of a new positive group. + npairs = npairs + 1 + index_uw(j,npairs*2) = i + else +! We have gone from positive to negative, indicating the end of +! the group. + index_uw(j,npairs*2+1) = i - 1 + endif + endif + enddo + + if (uwind_grid(nx,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.gt.0.0) then + index_uw(j,npairs*2+1) = nx + endif + index_uw(j,1) = npairs + enddo + +! do j=1,ny +! print 30, (index_uw(j,k),k=1,index_uw(j,1)*2+1) +! enddo +! print * +! print * + +! Sweep looking for EASTERLY winds, looking for negative numbers. + do j=1,ny + + if (uwind_grid(1,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.lt.0.0) then + npairs = 1 + index_ue(j,2) = 1 + else + npairs = 0 + endif + do i=2,nx + + if (uwind_grid(i-1,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + if (uwind_grid(i,j).le.0.0) then + sign2 = -1.0 + else + sign2 = 1.0 + endif + + if (sign2.ne.sign1) then +! We have a sign change. + if (sign2.lt.0.0) then +! We have gone from positive to negative, indicating the start +! of a new negative group. + npairs = npairs + 1 + index_ue(j,npairs*2) = i + else +! We have gone from negative to positive, indicating the end of +! the group. + index_ue(j,npairs*2+1) = i - 1 + endif + endif + enddo + + if (uwind_grid(nx,j).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.lt.0.0) then + index_ue(j,npairs*2+1) = nx + endif + index_ue(j,1) = npairs + enddo + +! do j=1,ny +! print 30, (index_ue(j,k),k=1,index_ue(j,1)*2+1) +! enddo +! print * +! print * + +! Sweep looking for SOUTHERLY winds, looking for positive numbers. + do i=1,nx + + if (vwind_grid(i,1).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.gt.0.0) then + npairs = 1 + index_vs(i,2) = 1 + else + npairs = 0 + endif + do j=2,ny + + if (vwind_grid(i,j-1).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + if (vwind_grid(i,j).le.0.0) then + sign2 = -1.0 + else + sign2 = 1.0 + endif + + if (sign2.ne.sign1) then +! We have a sign change. + if (sign2.gt.0.0) then +! We have gone from negative to positive, indicating the start +! of a new positive group. + npairs = npairs + 1 + index_vs(i,npairs*2) = j + else +! We have gone from positive to negative, indicating the end of +! the group. + index_vs(i,npairs*2+1) = j - 1 + endif + endif + enddo + + if (vwind_grid(i,ny).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.gt.0.0) then + index_vs(i,npairs*2+1) = ny + endif + index_vs(i,1) = npairs + enddo + +! do i=1,nx +! print 30, (index_vs(i,k),k=1,index_vs(i,1)*2+1) +! enddo +! print * +! print * + +! Sweep looking for NORTHERLY winds, looking for negative numbers. + do i=1,nx + + if (vwind_grid(i,1).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.lt.0.0) then + npairs = 1 + index_vn(i,2) = 1 + else + npairs = 0 + endif + do j=2,ny + + if (vwind_grid(i,j-1).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + if (vwind_grid(i,j).le.0.0) then + sign2 = -1.0 + else + sign2 = 1.0 + endif + + if (sign2.ne.sign1) then +! We have a sign change. + if (sign2.lt.0.0) then +! We have gone from positive to negative, indicating the start +! of a new negative group. + npairs = npairs + 1 + index_vn(i,npairs*2) = j + else +! We have gone from negative to positive, indicating the end of +! the group. + index_vn(i,npairs*2+1) = j - 1 + endif + endif + enddo + + if (vwind_grid(i,ny).le.0.0) then + sign1 = -1.0 + else + sign1 = 1.0 + endif + + if (sign1.lt.0.0) then + index_vn(i,npairs*2+1) = ny + endif + index_vn(i,1) = npairs + enddo + +! do i=1,nx +! print 30, (index_vn(i,k),k=1,index_vn(i,1)*2+1) +! enddo +! print * +! print * +! 30 format(20i4) + + return + end subroutine getdirection + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine getnewdepth(nx,ny,deltax,deltay,Qsalt_u,& + & Qsalt_v,dh_salt_u,dh_salt_v,index_ue,index_uw,& + & index_vn,index_vs,ro_snow,dt,vegsnowd_xy,snow_d,& + & soft_snow_d,snow_d_dep,soft_snow_d_dep,subgrid_flag) + +! If subgrid_flag = 1.0, this routine separates the snow +! accumulation and erosion contributions to the snowpack +! evolution so they can be dealt with separately in the +! subgrid_flag = 1.0 approach and routines. + + use snowmodel_inc + implicit none + + integer i,j,nx,ny + integer k,istart,iend,jstart,jend + + real deltax,deltay,ro_snow,dt,dQsalt,snowdmin + real hard_snow_d,weight_u,weight_v,eps + + integer index_ue(ny_max,2*nx_max+1) + integer index_uw(ny_max,2*nx_max+1) + integer index_vn(nx_max,2*ny_max+1) + integer index_vs(nx_max,2*ny_max+1) + + real Qsalt_u(nx,ny) + real Qsalt_v(nx,ny) + + real snow_d(nx,ny) + real soft_snow_d(nx,ny) + real dh_salt_u(nx,ny) + real dh_salt_v(nx,ny) + real vegsnowd_xy(nx,ny) + real snow_d_dep(nx,ny) + real soft_snow_d_dep(nx,ny) + + real subgrid_flag + +! Define an upwind boundary condition for saltation (here I have +! assumed that the transport is in equilibrium). + do i=1,nx + do j=1,ny + dh_salt_u(i,j) = 0.0 + dh_salt_v(i,j) = 0.0 + enddo + enddo + +! Consider WESTERLY winds. + do j=1,ny + do k=1,index_uw(j,1) + istart = index_uw(j,k*2)+1 + iend = index_uw(j,k*2+1) + do i=istart,iend + dQsalt = Qsalt_u(i,j) - Qsalt_u(i-1,j) + dh_salt_u(i,j) = (- dt) / ro_snow * dQsalt / deltax + +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. + hard_snow_d = snow_d(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + if (snow_d(i,j).gt.snowdmin) then + if (snow_d(i,j)+dh_salt_u(i,j).le.snowdmin) then + dh_salt_u(i,j) = snowdmin - snow_d(i,j) + Qsalt_u(i,j) = Qsalt_u(i-1,j) - dh_salt_u(i,j) * & + & ro_snow * deltax / dt + endif + else + Qsalt_u(i,j) = 0.0 + dh_salt_u(i,j) = 0.0 + endif + enddo + enddo + enddo + +! Consider EASTERLY winds. + do j=1,ny + do k=1,index_ue(j,1) + iend = index_ue(j,k*2) + istart = index_ue(j,k*2+1)-1 + do i=istart,iend,-1 + dQsalt = Qsalt_u(i,j) - Qsalt_u(i+1,j) + dh_salt_u(i,j) = (- dt) / ro_snow * dQsalt / deltax + +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. + hard_snow_d = snow_d(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + if (snow_d(i,j).gt.snowdmin) then + if (snow_d(i,j)+dh_salt_u(i,j).le.snowdmin) then + dh_salt_u(i,j) = snowdmin - snow_d(i,j) + Qsalt_u(i,j) = Qsalt_u(i+1,j) - dh_salt_u(i,j) * & + & ro_snow * deltax / dt + endif + else + Qsalt_u(i,j) = 0.0 + dh_salt_u(i,j) = 0.0 + endif + enddo + enddo + enddo + +! Consider SOUTHERLY winds. + do i=1,nx + do k=1,index_vs(i,1) + jstart = index_vs(i,k*2)+1 + jend = index_vs(i,k*2+1) + do j=jstart,jend + dQsalt = Qsalt_v(i,j) - Qsalt_v(i,j-1) + dh_salt_v(i,j) = (- dt) / ro_snow * dQsalt / deltay + +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. + hard_snow_d = snow_d(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + if (snow_d(i,j).gt.snowdmin) then + if (snow_d(i,j)+dh_salt_v(i,j).le.snowdmin) then + dh_salt_v(i,j) = snowdmin - snow_d(i,j) + Qsalt_v(i,j) = Qsalt_v(i,j-1) - dh_salt_v(i,j) * & + & ro_snow * deltay / dt + endif + else + Qsalt_v(i,j) = 0.0 + dh_salt_v(i,j) = 0.0 + endif + enddo + enddo + enddo + +! Consider NORTHERLY winds. + do i=1,nx + do k=1,index_vn(i,1) + jend = index_vn(i,k*2) + jstart = index_vn(i,k*2+1)-1 + do j=jstart,jend,-1 + dQsalt = Qsalt_v(i,j) - Qsalt_v(i,j+1) + dh_salt_v(i,j) = (- dt) / ro_snow * dQsalt / deltay + +! Make adjustments for the case where there is no snow available +! on the ground (or captured within the vegetation) to be +! eroded. + hard_snow_d = snow_d(i,j) - soft_snow_d(i,j) + snowdmin = max(vegsnowd_xy(i,j),hard_snow_d) + if (snow_d(i,j).gt.snowdmin) then + if (snow_d(i,j)+dh_salt_v(i,j).le.snowdmin) then + dh_salt_v(i,j) = snowdmin - snow_d(i,j) + Qsalt_v(i,j) = Qsalt_v(i,j+1) - dh_salt_v(i,j) *& + & ro_snow * deltay / dt + endif + else + Qsalt_v(i,j) = 0.0 + dh_salt_v(i,j) = 0.0 + endif + enddo + enddo + enddo + +! Update the snow depth changes due to saltation transport from the +! the east and west, and north and south. Also correct dh_salt_u +! and dh_salt_v to account for the minimum snow depth. + eps = 1e-6 + do i=1,nx + do j=1,ny + weight_u = abs(dh_salt_u(i,j)) / & + & (abs(dh_salt_u(i,j)) + abs(dh_salt_v(i,j)) + eps) + + weight_v = abs(dh_salt_v(i,j)) / & + & (abs(dh_salt_u(i,j)) + abs(dh_salt_v(i,j)) + eps) + + dh_salt_u(i,j) = weight_u * dh_salt_u(i,j) + dh_salt_v(i,j) = weight_v * dh_salt_v(i,j) + + if (subgrid_flag.eq.0.0) then + snow_d(i,j) = snow_d(i,j) + dh_salt_u(i,j) + dh_salt_v(i,j) + + soft_snow_d(i,j) = soft_snow_d(i,j) + dh_salt_u(i,j) + & + & dh_salt_v(i,j) + + elseif (subgrid_flag.eq.1.0) then + +! Just do the erosion. + snow_d(i,j) = snow_d(i,j) + min(0.0,dh_salt_u(i,j)) + & + & min(0.0,dh_salt_v(i,j)) + + soft_snow_d(i,j) = soft_snow_d(i,j) + & + & min(0.0,dh_salt_u(i,j))+ min(0.0,dh_salt_v(i,j)) + +! And save an array of what was deposited during this time step. + snow_d_dep(i,j) = max(0.0,dh_salt_u(i,j)) + & + & max(0.0,dh_salt_v(i,j)) + + soft_snow_d_dep(i,j) = & + & max(0.0,dh_salt_u(i,j))+ max(0.0,dh_salt_v(i,j)) + endif + + enddo + enddo + + return + end subroutine getnewdepth + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! subroutine subgrid_1(nx,ny,snow_d, +! & index_ue,index_uw,index_vn,index_vs, +! & tabler_nn,tabler_ss,tabler_ee,tabler_ww, +! & tabler_ne,tabler_se,tabler_sw,tabler_nw,uwind_grid, +! & vwind_grid,tabler_dir) + +! This subroutine forces SnowTran-3D's snow accumluation profiles +! to be bounded by the equilibrium topographic drift catchment +! profiles observed and modeled by Tabler (1975). + +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + +! implicit none + +! include 'snowmodel.inc' + +! integer i,j,nx,ny +! integer k,istart,iend,jstart,jend + +! real snow_d_extra,snow_sfc,tabler,tabler_dir + +! integer index_ue(ny_max,2*nx_max+1) +! integer index_uw(ny_max,2*nx_max+1) +! integer index_vn(nx_max,2*ny_max+1) +! integer index_vs(nx_max,2*ny_max+1) + +! real snow_d(nx,ny) +! real snow_d1(nx_max,ny_max) +! real snow_d2(nx_max,ny_max) +! real tabler_nn(nx_max,ny_max) +! real tabler_ss(nx_max,ny_max) +! real tabler_ee(nx_max,ny_max) +! real tabler_ww(nx_max,ny_max) +! real tabler_ne(nx_max,ny_max) +! real tabler_se(nx_max,ny_max) +! real tabler_sw(nx_max,ny_max) +! real tabler_nw(nx_max,ny_max) +! real uwind_grid(nx_max,ny_max) +! real vwind_grid(nx_max,ny_max) + +! real weight_u(nx_max,ny_max) +! real weight_v(nx_max,ny_max) + +! This is just a summary of all of the possibilities. +!! if(winddir(i,j).gt.337.5.or.winddir(i,j).le.22.5)then +!! tabler = tabler_nn(i,j) +!! elseif(winddir(i,j).gt.22.5.and.winddir(i,j).le.67.5)then +!! tabler = tabler_ne(i,j) +!! elseif(winddir(i,j).gt.67.5.and.winddir(i,j).le.112.5)then +!! tabler = tabler_ee(i,j) +!! elseif(winddir(i,j).gt.112.5.and.winddir(i,j).le.157.5)then +!! tabler = tabler_se(i,j) +!! elseif(winddir(i,j).gt.157.5.and.winddir(i,j).le.202.5)then +!! tabler = tabler_ss(i,j) +!! elseif(winddir(i,j).gt.202.5.and.winddir(i,j).le.247.5)then +!! tabler = tabler_sw(i,j) +!! elseif(winddir(i,j).gt.247.5.and.winddir(i,j).le.292.5)then +!! tabler = tabler_ww(i,j) +!! elseif(winddir(i,j).gt.292.5.and.winddir(i,j).le.337.5)then +!! tabler = tabler_nw(i,j) +!! endif + +! Create a copy of the incoming snow depth distribution. Also define +! the u and v weighting functions. +! do j=1,ny +! do i=1,nx +! snow_d1(i,j) = snow_d(i,j) +! snow_d2(i,j) = snow_d(i,j) + +! weight_u(i,j) = abs(uwind_grid(i,j)) / +! & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) +! weight_v(i,j) = abs(vwind_grid(i,j)) / +! & sqrt(uwind_grid(i,j)**2 + vwind_grid(i,j)**2) +! enddo +! enddo + +! Consider WESTERLY winds. +! do j=1,ny +! do k=1,index_uw(j,1) +! istart = index_uw(j,k*2)+1 +! iend = index_uw(j,k*2+1) +! do i=istart,iend + +! if(tabler_dir.gt.337.5.and.tabler_dir.le.360.0.or. +! & tabler_dir.ge.0.0.and.tabler_dir.le.22.5)then +! tabler = tabler_nn(i,j) +! elseif(tabler_dir.gt.157.5.and.tabler_dir.le.202.5)then +! tabler = tabler_ss(i,j) +! elseif(tabler_dir.gt.202.5.and.tabler_dir.le.247.5)then +! tabler = tabler_sw(i,j) +! elseif(tabler_dir.gt.247.5.and.tabler_dir.le.292.5)then +! tabler = tabler_ww(i,j) +! elseif(tabler_dir.gt.292.5.and.tabler_dir.le.337.5)then +! tabler = tabler_nw(i,j) +! endif + +! snow_sfc = tabler + +! if (snow_d1(i,j).gt.snow_sfc) then +! snow_d_extra = (snow_d1(i,j) - snow_sfc) * weight_u(i,j) +! snow_d1(i,j) = snow_d1(i,j) - snow_d_extra +! if (i.lt.nx) then +! snow_d1(i+1,j) = snow_d1(i+1,j) + snow_d_extra +! else +! snow_d1(i,j) = snow_d1(i,j) +! endif +! endif + +! enddo +! enddo +! enddo + +! Consider EASTERLY winds. +! do j=1,ny +! do k=1,index_ue(j,1) +! iend = index_ue(j,k*2) +! istart = index_ue(j,k*2+1)-1 +! do i=istart,iend,-1 + +! if(tabler_dir.gt.337.5.and.tabler_dir.le.360.0.or. +! & tabler_dir.ge.0.0.and.tabler_dir.le.22.5)then +! tabler = tabler_nn(i,j) +! elseif(tabler_dir.gt.22.5.and.tabler_dir.le.67.5)then +! tabler = tabler_ne(i,j) +! elseif(tabler_dir.gt.67.5.and.tabler_dir.le.112.5)then +! tabler = tabler_ee(i,j) +! elseif(tabler_dir.gt.112.5.and.tabler_dir.le.157.5)then +! tabler = tabler_se(i,j) +! elseif(tabler_dir.gt.157.5.and.tabler_dir.le.202.5)then +! tabler = tabler_ss(i,j) +! endif + +! snow_sfc = tabler + +! if (snow_d1(i,j).gt.snow_sfc) then +! snow_d_extra = (snow_d1(i,j) - snow_sfc) * weight_u(i,j) +! snow_d1(i,j) = snow_d1(i,j) - snow_d_extra +! if (i.gt.1) then +! snow_d1(i-1,j) = snow_d1(i-1,j) + snow_d_extra +! else +! snow_d1(i,j) = snow_d1(i,j) +! endif +! endif +! enddo +! enddo +! enddo + +! Consider SOUTHERLY winds. +! do i=1,nx +! do k=1,index_vs(i,1) +! jstart = index_vs(i,k*2)+1 +! jend = index_vs(i,k*2+1) +! do j=jstart,jend + +! if(tabler_dir.gt.67.5.and.tabler_dir.le.112.5)then +! tabler = tabler_ee(i,j) +! elseif(tabler_dir.gt.112.5.and.tabler_dir.le.157.5)then +! tabler = tabler_se(i,j) +! elseif(tabler_dir.gt.157.5.and.tabler_dir.le.202.5)then +! tabler = tabler_ss(i,j) +! elseif(tabler_dir.gt.202.5.and.tabler_dir.le.247.5)then +! tabler = tabler_sw(i,j) +! elseif(tabler_dir.gt.247.5.and.tabler_dir.le.292.5)then +! tabler = tabler_ww(i,j) +! endif + +! snow_sfc = tabler + +! if (snow_d2(i,j).gt.snow_sfc) then +! snow_d_extra = (snow_d2(i,j) - snow_sfc) * weight_v(i,j) +! snow_d2(i,j) = snow_d2(i,j) - snow_d_extra +! if (j.lt.ny) then +! snow_d2(i,j+1) = snow_d2(i,j+1) + snow_d_extra +! else +! snow_d2(i,j) = snow_d2(i,j) +! endif +! endif +! enddo +! enddo +! enddo + +! Consider NORTHERLY winds. +! do i=1,nx +! do k=1,index_vn(i,1) +! jend = index_vn(i,k*2) +! jstart = index_vn(i,k*2+1)-1 +! do j=jstart,jend,-1 + +! if(tabler_dir.gt.337.5.and.tabler_dir.le.360.0.or. +! & tabler_dir.ge.0.0.and.tabler_dir.le.22.5)then +! tabler = tabler_nn(i,j) +! elseif(tabler_dir.gt.22.5.and.tabler_dir.le.67.5)then +! tabler = tabler_ne(i,j) +! elseif(tabler_dir.gt.67.5.and.tabler_dir.le.112.5)then +! tabler = tabler_ee(i,j) +! elseif(tabler_dir.gt.247.5.and.tabler_dir.le.292.5)then +! tabler = tabler_ww(i,j) +! elseif(tabler_dir.gt.292.5.and.tabler_dir.le.337.5)then +! tabler = tabler_nw(i,j) +! endif + +! snow_sfc = tabler + +! if (snow_d2(i,j).gt.snow_sfc) then +! snow_d_extra = (snow_d2(i,j) - snow_sfc) * weight_v(i,j) +! snow_d2(i,j) = snow_d2(i,j) - snow_d_extra +! if (j.gt.1) then +! snow_d2(i,j-1) = snow_d2(i,j-1) + snow_d_extra +! else +! snow_d2(i,j) = snow_d2(i,j) +! endif +! endif + +! enddo +! enddo +! enddo + +! Update the snow depths resulting from these redistributions. +! do j=1,ny +! do i=1,nx +! snow_d(i,j) = snow_d1(i,j) * weight_u(i,j) + +! & snow_d2(i,j) * weight_v(i,j) +! enddo +! enddo + +! Clean up the boundaries. Make the boundary values equal to +! the values just inside the boundaries. +! do i=2,nx-1 +! snow_d(i,1) = snow_d(i,2) +! snow_d(i,ny) = snow_d(i,ny-1) +! enddo +! do j=1,ny +! snow_d(1,j) = snow_d(2,j) +! snow_d(nx,j) = snow_d(nx-1,j) +! enddo + +! return +! end + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine tabler_3d(nx,ny,topo_land,deltax,deltay,& + & tabler_ww,tabler_ee,tabler_ss,& + & tabler_nn,tabler_ne,tabler_se,& + & tabler_sw,tabler_nw,slope_adjust) + +! This subroutine uses Tabler (1975) to define equilibrium profiles +! for the topographic drift catchments, for the case of winds +! from the EAST, WEST, NORTH, and SOUTH, and anywhere inbetween. + + use snowmodel_inc + implicit none + + integer nx,ny,irotate_flag + + real deltax,deltay,slope_adjust + + real topo_land(nx,ny) + + real tabler_nn(nx,ny) + real tabler_ss(nx,ny) + real tabler_ee(nx,ny) + real tabler_ww(nx,ny) + + real tabler_ne(nx,ny) + real tabler_se(nx,ny) + real tabler_sw(nx,ny) + real tabler_nw(nx,ny) + +! Here we generate maximum snow accumulation surfaces for n, ne, e, +! se, s, sw, w, and nw winds. I call these "tabler surfaces". +! +! They are valid for the wind direction ranges: N=337.5-22.5, +! NE=22.5-67.5, E=67.5-112.5, SE=112.5-157.5, S=157.5-202.5, +! SW=202.5-247.5, W=247.5-292.5, and NW=292.5-337.5. +! +! These Tabler Surfaces define a "potential" snow surface that +! represents the maximum possible snow-accumulation depth from winds +! coming from these directions. +! +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + +! Consider N winds. + irotate_flag = 1 + call tabler_n(nx,ny,topo_land,tabler_nn,deltay,& + & irotate_flag,slope_adjust) + +! Consider NE winds. + irotate_flag = 2 + call tabler_e(nx,ny,topo_land,tabler_ne,1.41*deltax,& + & irotate_flag,slope_adjust) + +! Consider E winds. + irotate_flag = 1 + call tabler_e(nx,ny,topo_land,tabler_ee,deltax,& + & irotate_flag,slope_adjust) + +! Consider SE winds. + irotate_flag = 2 + call tabler_s(nx,ny,topo_land,tabler_se,1.41*deltay,& + & irotate_flag,slope_adjust) + +! Consider S winds. + irotate_flag = 1 + call tabler_s(nx,ny,topo_land,tabler_ss,deltay,& + & irotate_flag,slope_adjust) + +! Consider SW winds. + irotate_flag = 2 + call tabler_w(nx,ny,topo_land,tabler_sw,1.41*deltax,& + & irotate_flag,slope_adjust) + +! Consider W winds. + irotate_flag = 1 + call tabler_w(nx,ny,topo_land,tabler_ww,deltax,& + & irotate_flag,slope_adjust) + +! Consider NW winds. + irotate_flag = 2 + call tabler_n(nx,ny,topo_land,tabler_nw,1.41*deltay,& + & irotate_flag,slope_adjust) + + return + end subroutine tabler_3d + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine tabler_w(nx,ny,topo_land,tabler_ww,deltax,& + & irotate_flag,slope_adjust) + +! This subroutine uses Tabler (1975) to define equilibrium profiles +! for the topographic drift catchments, for the case of winds +! from the WEST and SOUTHWEST. + +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,istart,iend,JJ,irotate_flag,nny,nnx,& + & ii,iii,maxlines + real deltax,y,slope_adjust,xmax_slope,dx,test,& + & x,x1,x2,x3,x4,y1,y2,t1,t2,t3,t4,t5 + + real topo_land(nx,ny) + real tabler_ww(nx,ny) + real tabler(nx_max) + real topo_line(nx_max) + real drift_start_topo(nx_max) + integer, parameter :: nx_max_tabler = nx_max*1000 + real topo_1m(nx_max_tabler) + real tabler_1m(nx_max_tabler) + real drift_start_topo_1m(nx_max_tabler) + +! This program: +! 1) takes the coarse model topography and generates 1.0-m grid +! increment topo lines; +! 2) uses those to generate the Tabler surface profiles; and +! 3) extracts the profiles at the coarse model grid cells. + +! Fill the snow array with topo data. + do j=1,ny + do i=1,nx + tabler_ww(i,j) = topo_land(i,j) + enddo + enddo + +! Define the length of the j-looping, depending on whether there +! is any rotation done to get 45 deg winds. + if (irotate_flag.eq.2) then + nny = nx+ny-1 + else + nny = ny + endif + +! Required parameters. + if (irotate_flag.eq.2) then + dx = 1.41 + test = amod(deltax/1.41,dx/1.41) + else + dx = 1.0 + test = amod(deltax,dx) + endif + + xmax_slope = -0.20 + +! This Tabler program has not been made general enough to deal +! with deltax and deltay values that are not evenly divisible +! by 1.0 (or 1.41 for diagonal profiles). + if (abs(test).gt.1.0e10-5) then + print *,'To generate the Tabler surfaces, deltax and deltay' + print *,' must be evenly divisible by 1.0 or 1.41.' + print *,' deltax = ',deltax + stop + endif + +! Define the number of 1-m grid cells in each model grid cell, and +! calculate how many of these are in the entire nx domain. + nnx = nint(deltax/dx) + maxlines = (nx - 1) * nnx + 1 + +! Define the starting and ending points of the line we are going to +! work with. This is done to make sure we are never looking +! outside the data for numbers to work with. + istart = 1 + if (irotate_flag.eq.2) then + iend = maxlines - (32+11+10+11) + else + iend = maxlines - (45+15+15+15) + endif + +! Extract the line we are going to work with. + do j=1,nny + + if (irotate_flag.eq.2) then + do i=1,nx + JJ = j + i - nx + drift_start_topo(i) = 0.0 + if (JJ.le.0) then + tabler(i) = tabler_ww(1-j+nx,1) + topo_line(i) = tabler_ww(1-j+nx,1) + elseif (JJ.gt.ny) then + tabler(i) = tabler(i-1) + topo_line(i) = tabler(i-1) + else + tabler(i) = tabler_ww(i,JJ) + topo_line(i) = tabler_ww(i,JJ) + endif + enddo + else + do i=1,nx + tabler(i) = tabler_ww(i,j) + topo_line(i) = topo_land(i,j) + drift_start_topo(i) = 0.0 + enddo + endif + +! To build the 1.0 m line, use linear interpolation between the +! model topo data. Include the end point. + do i=1,nx-1 + do ii=1,nnx + iii = (i - 1) * nnx + ii + x1 = 0.0 + x = real(ii - 1) * dx + y2 = topo_line(i+1) + y1 = topo_line(i) + topo_1m(iii) = y1 + ((y2 - y1)/deltax) * (x - x1) + enddo + enddo + topo_1m((nx - 1) * nnx + 1) = topo_line(nx) + +! Use this topo array to be the starting point for generating the +! Tabler surfaces. + do i=1,maxlines + tabler_1m(i) = topo_1m(i) + drift_start_topo_1m(i) = 0.0 + enddo + +! Run the Tabler model. + do i=istart,iend + if (irotate_flag.eq.2) then + t1 = tabler_1m(i) + t2 = tabler_1m(i+31) + t3 = tabler_1m(i+31+11) + t4 = tabler_1m(i+31+21) + t5 = tabler_1m(i+31+32) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(i+32) = max(topo_1m(i+32),& + & tabler_1m(i+31) + y * slope_adjust * dx) + else + t1 = tabler_1m(i) + t2 = tabler_1m(i+44) + t3 = tabler_1m(i+44+15) + t4 = tabler_1m(i+44+30) + t5 = tabler_1m(i+44+45) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(i+45) = max(topo_1m(i+45),& + & tabler_1m(i+44) + y * slope_adjust * dx) + endif + enddo + +! Extract the profile at the model grid points. + do i=1,nx + ii = (i - 1) * nnx + 1 + tabler(i) = tabler_1m(ii) + drift_start_topo(i) = drift_start_topo_1m(ii) + enddo + +! Use the 1-D arrays to fill in the 2-D tabler-surface array. + do i=1,nx + if (irotate_flag.eq.2) then + JJ = j + i - nx + if (JJ.ge.1 .and. JJ.le.ny) then + tabler_ww(i,JJ) = tabler(i) + drift_start_topo(i) + endif + else + tabler_ww(i,j) = tabler(i) + drift_start_topo(i) + endif + enddo + + enddo + +! Convert snow_traps back to actual snow depths instead of +! depth plus topography. + do j=1,ny + do i=1,nx + tabler_ww(i,j) = tabler_ww(i,j) - topo_land(i,j) + enddo + enddo + + return + end subroutine tabler_w + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine tabler_e(nx,ny,topo_land,tabler_ee,deltax,& + & irotate_flag,slope_adjust) + +! This subroutine uses Tabler (1975) to define equilibrium profiles +! for the topographic drift catchments, for the case of winds +! from the EAST and NORTHEAST. + +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,istart,iend,JJ,irotate_flag,nny,nnx,& + & ii,iii,maxlines + real deltax,y,slope_adjust,xmax_slope,dx,test,& + & x,x1,x2,x3,x4,y1,y2,t1,t2,t3,t4,t5 + + real topo_land(nx,ny) + real tabler_ee(nx,ny) + real tabler(nx_max) + real topo_line(nx_max) + real drift_start_topo(nx_max) + + integer, parameter :: nx_max_tabler = nx_max*1000 + real topo_1m(nx_max_tabler) + real tabler_1m(nx_max_tabler) + real drift_start_topo_1m(nx_max_tabler) + +! This program: +! 1) takes the coarse model topography and generates 1.0-m grid +! increment topo lines; +! 2) uses those to generate the Tabler surface profiles; and +! 3) extracts the profiles at the coarse model grid cells. + +! Fill the snow array with topo data. + do j=1,ny + do i=1,nx + tabler_ee(i,j) = topo_land(i,j) + enddo + enddo + +! Define the length of the j-looping, depending on whether there +! is any rotation done to get 45 deg winds. + if (irotate_flag.eq.2) then + nny = nx+ny-1 + else + nny = ny + endif + +! Required parameters. + if (irotate_flag.eq.2) then + dx = 1.41 + test = amod(deltax/1.41,dx/1.41) + else + dx = 1.0 + test = amod(deltax,dx) + endif + + xmax_slope = -0.20 + +! This Tabler program has not been made general enough to deal +! with deltax and deltay values that are not evenly divisible +! by 1.0 (or 1.41 for diagonal profiles). + if (abs(test).gt.1.0e10-5) then + print *,'To generate the Tabler surfaces, deltax and deltay' + print *,' must be evenly divisible by 1.0 or 1.41.' + print *,' deltax = ',deltax + stop + endif + +! Define the number of 1-m grid cells in each model grid cell, and +! calculate how many of these are in the entire nx domain. + nnx = nint(deltax/dx) + maxlines = (nx - 1) * nnx + 1 + +! Define the starting and ending points of the line we are going to +! work with. This is done to make sure we are never looking +! outside the data for numbers to work with. + istart = maxlines + if (irotate_flag.eq.2) then + iend = 1 + (32+11+10+11) + else + iend = 1 + (45+15+15+15) + endif + +! Extract the line we are going to work with. + do j=1,nny + + if (irotate_flag.eq.2) then + do i=1,nx + JJ = j + i - nx + drift_start_topo(i) = 0.0 + if (JJ.le.0) then + tabler(i) = tabler_ee(1-j+nx,1) + topo_line(i) = tabler_ee(1-j+nx,1) + elseif (JJ.gt.ny) then + tabler(i) = tabler(i-1) + topo_line(i) = tabler(i-1) + else + tabler(i) = tabler_ee(i,JJ) + topo_line(i) = tabler_ee(i,JJ) + endif + enddo + else + do i=1,nx + tabler(i) = tabler_ee(i,j) + topo_line(i) = topo_land(i,j) + drift_start_topo(i) = 0.0 + enddo + endif + +! To build the 1.0 m line, use linear interpolation between the +! model topo data. Include the end point. + do i=1,nx-1 + do ii=1,nnx + iii = (i - 1) * nnx + ii + x1 = 0.0 + x = real(ii - 1) * dx + y2 = topo_line(i+1) + y1 = topo_line(i) + topo_1m(iii) = y1 + ((y2 - y1)/deltax) * (x - x1) + enddo + enddo + topo_1m((nx - 1) * nnx + 1) = topo_line(nx) + +! Use this topo array to be the starting point for generating the +! Tabler surfaces. + do i=1,maxlines + tabler_1m(i) = topo_1m(i) + drift_start_topo_1m(i) = 0.0 + enddo + +! Run the Tabler model. + do i=istart,iend,-1 + if (irotate_flag.eq.2) then + t1 = tabler_1m(i) + t2 = tabler_1m(i-31) + t3 = tabler_1m(i-31-11) + t4 = tabler_1m(i-31-21) + t5 = tabler_1m(i-31-32) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(i-32) = max(topo_1m(i-32),& + & tabler_1m(i-31) + y * slope_adjust * dx) + else + t1 = tabler_1m(i) + t2 = tabler_1m(i-44) + t3 = tabler_1m(i-44-15) + t4 = tabler_1m(i-44-30) + t5 = tabler_1m(i-44-45) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(i-45) = max(topo_1m(i-45),& + & tabler_1m(i-44) + y * slope_adjust * dx) + endif + enddo + +! Extract the profile at the model grid points. + do i=1,nx + ii = (i - 1) * nnx + 1 + tabler(i) = tabler_1m(ii) + drift_start_topo(i) = drift_start_topo_1m(ii) + enddo + +! Use the 1-D arrays to fill in the 2-D tabler-surface array. + do i=1,nx + if (irotate_flag.eq.2) then + JJ = j + i - nx + if (JJ.ge.1 .and. JJ.le.ny) then + tabler_ee(i,JJ) = tabler(i) + drift_start_topo(i) + endif + else + tabler_ee(i,j) = tabler(i) + drift_start_topo(i) + endif + enddo + + enddo + +! Convert snow_traps back to actual snow depths instead of +! depth plus topography. + do j=1,ny + do i=1,nx + tabler_ee(i,j) = tabler_ee(i,j) - topo_land(i,j) + enddo + enddo + + return + end subroutine tabler_e + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine tabler_s(nx,ny,topo_land,tabler_ss,deltay,& + & irotate_flag,slope_adjust) + +! This subroutine uses Tabler (1975) to define equilibrium profiles +! for the topographic drift catchments, for the case of winds +! from the SOUTH and SOUTHEAST. + +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,jstart,jend,II,irotate_flag,nny,nnx,& + & jj,jjj,maxlines + real deltay,y,slope_adjust,xmax_slope,dy,test,& + & x,x1,x2,x3,x4,y1,y2,t1,t2,t3,t4,t5 + + real topo_land(nx,ny) + real tabler_ss(nx,ny) + real tabler(ny_max) + real topo_line(ny_max) + real drift_start_topo(ny_max) + + integer, parameter :: ny_max_tabler=ny_max*1000 + real topo_1m(ny_max_tabler) + real tabler_1m(ny_max_tabler) + real drift_start_topo_1m(ny_max_tabler) + +! This program: +! 1) takes the coarse model topography and generates 1.0-m grid +! increment topo lines; +! 2) uses those to generate the Tabler surface profiles; and +! 3) extracts the profiles at the coarse model grid cells. + +! Fill the snow array with topo data. + do j=1,ny + do i=1,nx + tabler_ss(i,j) = topo_land(i,j) + enddo + enddo + +! Define the length of the i-looping, depending on whether there +! is any rotation done to get 45 deg winds. + if (irotate_flag.eq.2) then + nnx = nx+ny-1 + else + nnx = nx + endif + +! Required parameters. + if (irotate_flag.eq.2) then + dy = 1.41 + test = amod(deltay/1.41,dy/1.41) + else + dy = 1.0 + test = amod(deltay,dy) + endif + + xmax_slope = -0.20 + +! This Tabler program has not been made general enough to deal +! with deltax and deltay values that are not evenly divisible +! by 1.0 (or 1.41 for diagonal profiles). + if (abs(test).gt.1.0e10-5) then + print *,'To generate the Tabler surfaces, deltax and deltay' + print *,' must be evenly divisible by 1.0 or 1.41.' + print *,' deltay = ',deltay + stop + endif + +! Define the number of 1-m grid cells in each model grid cell, and +! calculate how many of these are in the entire nx domain. + nny = nint(deltay/dy) + maxlines = (ny - 1) * nny + 1 + +! Define the starting and ending points of the line we are going to +! work with. This is done to make sure we are never looking +! outside the data for numbers to work with. + jstart = 1 + if (irotate_flag.eq.2) then + jend = maxlines - (32+11+10+11) + else + jend = maxlines - (45+15+15+15) + endif + +! Extract the line we are going to work with. + do i=1,nnx + if (irotate_flag.eq.2) then + do j=1,ny + II = i - j + 1 + drift_start_topo(j) = 0.0 + if (II.le.0) then + tabler(j) = tabler(j-1) + topo_line(j) = tabler(j-1) + elseif (II.gt.nx) then + tabler(j) = tabler_ss(nx,i-nx+1) + topo_line(j) = tabler_ss(nx,i-nx+1) + else + tabler(j) = tabler_ss(II,j) + topo_line(j) = tabler_ss(II,j) + endif + enddo + else + do j=1,ny + tabler(j) = tabler_ss(i,j) + topo_line(j) = topo_land(i,j) + drift_start_topo(j) = 0.0 + enddo + endif + +! To build the 1.0 m line, use linear interpolation between the +! model topo data. Include the end point. + do j=1,ny-1 + do jj=1,nny + jjj = (j - 1) * nny + jj + x1 = 0.0 + x = real(jj - 1) * dy + y2 = topo_line(j+1) + y1 = topo_line(j) + topo_1m(jjj) = y1 + ((y2 - y1)/deltay) * (x - x1) + enddo + enddo + topo_1m((ny - 1) * nny + 1) = topo_line(ny) + +! Use this topo array to be the starting point for generating the +! Tabler surfaces. + do j=1,maxlines + tabler_1m(j) = topo_1m(j) + drift_start_topo_1m(j) = 0.0 + enddo + +! Run the Tabler model. + do j=jstart,jend + if (irotate_flag.eq.2) then + t1 = tabler_1m(j) + t2 = tabler_1m(j+31) + t3 = tabler_1m(j+31+11) + t4 = tabler_1m(j+31+21) + t5 = tabler_1m(j+31+32) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(j+32) = max(topo_1m(j+32),& + & tabler_1m(j+31) + y * slope_adjust * dy) + else + t1 = tabler_1m(j) + t2 = tabler_1m(j+44) + t3 = tabler_1m(j+44+15) + t4 = tabler_1m(j+44+30) + t5 = tabler_1m(j+44+45) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(j+45) = max(topo_1m(j+45),& + & tabler_1m(j+44) + y * slope_adjust * dy) + endif + enddo + +! Extract the profile at the model grid points. + do j=1,ny + jj = (j - 1) * nny + 1 + tabler(j) = tabler_1m(jj) + drift_start_topo(j) = drift_start_topo_1m(jj) + enddo + +! Use the 1-D arrays to fill in the 2-D tabler-surface array. + do j=1,ny + if (irotate_flag.eq.2) then + II = i - j + 1 + if (II.ge.1 .and. II.le.nx) then + tabler_ss(II,j) = tabler(j) + drift_start_topo(j) + endif + else + tabler_ss(i,j) = tabler(j) + drift_start_topo(j) + endif + enddo + + enddo + +! Convert snow_traps back to actual snow depths instead of +! depth plus topography. + do j=1,ny + do i=1,nx + tabler_ss(i,j) = tabler_ss(i,j) - topo_land(i,j) + enddo + enddo + + return + end subroutine tabler_s + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine tabler_n(nx,ny,topo_land,tabler_nn,deltay,& + & irotate_flag,slope_adjust) + +! This subroutine uses Tabler (1975) to define equilibrium profiles +! for the topographic drift catchments, for the case of winds +! from the NORTH and NORTHWEST. + +! Tabler, R. D., 1975: Predicting profiles of snowdrifts in +! topographic catchments. Proceedings of the 43rd Annual Western +! Snow Conference, San Diego, California, 87-97. + + use snowmodel_inc + implicit none + + integer nx,ny,i,j,jstart,jend,II,irotate_flag,nny,nnx,& + & jj,jjj,maxlines + real deltay,y,slope_adjust,xmax_slope,dy,test,& + & x,x1,x2,x3,x4,y1,y2,t1,t2,t3,t4,t5 + + real topo_land(nx,ny) + real tabler_nn(nx,ny) + real tabler(ny_max) + real topo_line(ny_max) + real drift_start_topo(ny_max) + + integer, parameter :: ny_max_tabler = ny_max*1000 + real topo_1m(ny_max_tabler) + real tabler_1m(ny_max_tabler) + real drift_start_topo_1m(ny_max_tabler) + +! This program: +! 1) takes the coarse model topography and generates 1.0-m grid +! increment topo lines; +! 2) uses those to generate the Tabler surface profiles; and +! 3) extracts the profiles at the coarse model grid cells. + +! Fill the snow array with topo data. + do j=1,ny + do i=1,nx + tabler_nn(i,j) = topo_land(i,j) + enddo + enddo + +! Define the length of the i-looping, depending on whether there +! is any rotation done to get 45 deg winds. + if (irotate_flag.eq.2) then + nnx = nx+ny-1 + else + nnx = nx + endif + +! Required parameters. + if (irotate_flag.eq.2) then + dy = 1.41 + test = amod(deltay/1.41,dy/1.41) + else + dy = 1.0 + test = amod(deltay,dy) + endif + + xmax_slope = -0.20 + +! This Tabler program has not been made general enough to deal +! with deltax and deltay values that are not evenly divisible +! by 1.0 (or 1.41 for diagonal profiles). + if (abs(test).gt.1.0e10-5) then + print *,'To generate the Tabler surfaces, deltax and deltay' + print *,' must be evenly divisible by 1.0 or 1.41.' + print *,' deltay = ',deltay + stop + endif + +! Define the number of 1-m grid cells in each model grid cell, and +! calculate how many of these are in the entire nx domain. + nny = nint(deltay/dy) + maxlines = (ny - 1) * nny + 1 + +! Define the starting and ending points of the line we are going to +! work with. This is done to make sure we are never looking +! outside the data for numbers to work with. + jstart = maxlines + if (irotate_flag.eq.2) then + jend = 1 + (32+11+10+11) + else + jend = 1 + (45+15+15+15) + endif + +! Extract the line we are going to work with. + do i=1,nnx + if (irotate_flag.eq.2) then + do j=1,ny + II = i - j + 1 + drift_start_topo(j) = 0.0 + if (II.le.0) then + tabler(j) = tabler(j-1) + topo_line(j) = tabler(j-1) + elseif (II.gt.nx) then + tabler(j) = tabler_nn(nx,i-nx+1) + topo_line(j) = tabler_nn(nx,i-nx+1) + else + tabler(j) = tabler_nn(II,j) + topo_line(j) = tabler_nn(II,j) + endif + enddo + else + do j=1,ny + tabler(j) = tabler_nn(i,j) + topo_line(j) = topo_land(i,j) + drift_start_topo(j) = 0.0 + enddo + endif + +! To build the 1.0 m line, use linear interpolation between the +! model topo data. Include the end point. + do j=1,ny-1 + do jj=1,nny + jjj = (j - 1) * nny + jj + x1 = 0.0 + x = real(jj - 1) * dy + y2 = topo_line(j+1) + y1 = topo_line(j) + topo_1m(jjj) = y1 + ((y2 - y1)/deltay) * (x - x1) + enddo + enddo + topo_1m((ny - 1) * nny + 1) = topo_line(ny) + +! Use this topo array to be the starting point for generating the +! Tabler surfaces. + do j=1,maxlines + tabler_1m(j) = topo_1m(j) + drift_start_topo_1m(j) = 0.0 + enddo + +! Run the Tabler model. + do j=jstart,jend,-1 + if (irotate_flag.eq.2) then + t1 = tabler_1m(j) + t2 = tabler_1m(j-31) + t3 = tabler_1m(j-31-11) + t4 = tabler_1m(j-31-21) + t5 = tabler_1m(j-31-32) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(j-32) = max(topo_1m(j-32),& + & tabler_1m(j-31) + y * slope_adjust * dy) + else + t1 = tabler_1m(j) + t2 = tabler_1m(j-44) + t3 = tabler_1m(j-44-15) + t4 = tabler_1m(j-44-30) + t5 = tabler_1m(j-44-45) + + x1 = (t2 - t1) / 45.0 + x2 = max((t3 - t2) / 15.0,xmax_slope) + x3 = max((t4 - t3) / 15.0,xmax_slope) + x4 = max((t5 - t4) / 15.0,xmax_slope) + + y = 0.25*x1 + 0.55*x2 + 0.15*x3 + 0.05*x4 + + tabler_1m(j-45) = max(topo_1m(j-45),& + & tabler_1m(j-44) + y * slope_adjust * dy) + endif + enddo + +! Extract the profile at the model grid points. + do j=1,ny + jj = (j - 1) * nny + 1 + tabler(j) = tabler_1m(jj) + drift_start_topo(j) = drift_start_topo_1m(jj) + enddo + +! Use the 1-D arrays to fill in the 2-D tabler-surface array. + do j=1,ny + if (irotate_flag.eq.2) then + II = i - j + 1 + if (II.ge.1 .and. II.le.nx) then + tabler_nn(II,j) = tabler(j) + drift_start_topo(j) + endif + else + tabler_nn(i,j) = tabler(j) + drift_start_topo(j) + endif + enddo + + enddo + +! Convert snow_traps back to actual snow depths instead of +! depth plus topography. + do j=1,ny + do i=1,nx + tabler_nn(i,j) = tabler_nn(i,j) - topo_land(i,j) + enddo + enddo + + return + end subroutine tabler_n + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine surface_snow_1(Tair,windspd_2m,prec,ro_soft_snow,& + & Utau_t,ro_soft_snow_old,dt,ro_nsnow) + + implicit none + + real C,alfa,ro_min,ro_max,prec,Tair,ro_nsnow,dt,Tf,& + & Utau_t,ro_soft_snow_old,ro_soft_snow,windspd_2m + +! Define the density rate coefficients. + C = 0.10 + +! Define alfa. + alfa = 0.2 + +! Define the minimum and maximum snow density that should be +! simulated. + ro_min = 50.0 + ro_max = 450.0 + +! Freezing temperature. + Tf = 273.15 + +! Calculate the new snow density. First calculate this under the +! assumption of no wind using the standard SnowModel formulation, +! then calculate the offset for wind speeds > 5 m/s. + if (prec.gt.0.0) then + ro_soft_snow = ro_nsnow + ro_soft_snow = min(ro_soft_snow,ro_max) + ro_soft_snow = max(ro_soft_snow,ro_min) + if (ro_soft_snow.le.300.0) then + Utau_t = 0.10 * exp(0.003 * ro_soft_snow) + else + Utau_t = 0.005 * exp(0.013 * ro_soft_snow) + endif + ro_soft_snow_old = ro_soft_snow + else + call surface_snow_2(ro_soft_snow_old,ro_soft_snow,Utau_t,& + & dt,Tair,windspd_2m,C,ro_max,ro_min,alfa,Tf) + ro_soft_snow_old = ro_soft_snow + endif + + return + end subroutine surface_snow_1 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + subroutine surface_snow_2(ro_soft_snow_old,ro_soft_snow,Utau_t,& + & dt,Tair,windspd_2m,C,ro_max,ro_min,alfa,Tf) + + implicit none + + real Tf,Tsnow,Tair,ro_soft_snow,dt,A1,A2,B,U,C,& + & windspd_2m,Utau_t,ro_soft_snow_old,ro_max,ro_min,alfa + + A1 = 0.0013 + A2 = 0.021 + B = 0.08 + +! Evolve the near-surface snow density under the influence of +! temperature and snow-transporting wind speeds. + +! Assume that the near-surface snow temperature equals the air +! temperature, but is not above the melting point. + Tsnow = min(Tf,Tair) + +! Update the snow density of the soft snow layer. Eliminate the +! wind speed influence for speeds below 5 m/s, but account for it +! if speeds are >= 5 m/s. + if (windspd_2m.ge.5.0) then + U = 5.0 + 15.0 * (1.0 - exp(-(alfa*(windspd_2m - 5.0)))) + else + U = 1.0 + endif + + ro_soft_snow = ro_soft_snow_old + dt * & + & (C * A1 * U * ro_soft_snow_old * & + & exp((- B)*(Tf-Tsnow)) * exp((- A2)*ro_soft_snow_old)) + +! Bound the calculated density. + ro_soft_snow = min(ro_max,ro_soft_snow) + ro_soft_snow = max(ro_min,ro_soft_snow) + +! Calculate the snow threshold friction velocity. + if (ro_soft_snow.le.300.0) then + Utau_t = 0.10 * exp(0.003 * ro_soft_snow) + else + Utau_t = 0.005 * exp(0.013 * ro_soft_snow) + endif + + return + end subroutine surface_snow_2 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 new file mode 100644 index 000000000..59e063ed9 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 @@ -0,0 +1,135 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: SnowModel_coldstart +! \label{SnowModel_coldstart} +! +! !REVISION HISTORY: +! This subroutine is generated with the Model Implementation Toolkit developed +! by Shugong Wang for the NASA Land Information System Version 7. The initial +! specification of the subroutine is defined by Sujay Kumar. +! +! 05 Aug 2022: Kristi Arsenault; Added SnowModel coldstart routine +! +! !INTERFACE: +subroutine SnowModel_coldstart(mtype) + +! USES: + use LIS_coreMod + use LIS_logMod + use LIS_timeMgrMod, only: LIS_date2time + + use SnowModel_lsmMod + use snowmodel_inc + use snowmodel_vars +! +! !DESCRIPTION: +! +! This routine initializes the SnowModel state variables with some +! predefined values constantly for the entire domain. +! +!EOP + implicit none + integer :: mtype + integer :: t, l, n + + do n=1, LIS_rc%nnest + if( trim(LIS_rc%startcode) .eq. "coldstart" ) then + + write(LIS_logunit,*) "[INFO] SnowModel_coldstart -- initializing SnowModel states" + + ! Initialize snow fields + snowmodel_struc(n)%sm(:)%sden = 0. + snowmodel_struc(n)%sm(:)%sublim = 0. + snowmodel_struc(n)%sm(:)%swemelt = 0. + snowmodel_struc(n)%sm(:)%runoff = 0. + + ! Initialize other state fields used + snowmodel_struc(n)%sm(:)%swe_depth = 0. + snowmodel_struc(n)%sm(:)%snow_depth = 0. + snowmodel_struc(n)%sm(:)%snow_d = 0. + snowmodel_struc(n)%sm(:)%canopy_int = 0. + snowmodel_struc(n)%sm(:)%soft_snow_d = 0. + snowmodel_struc(n)%sm(:)%ro_snow_grid = 0. + snowmodel_struc(n)%sm(:)%ro_soft_snow_old = 0. + snowmodel_struc(n)%sm(:)%snow_d_init = 0. + snowmodel_struc(n)%sm(:)%swe_depth_old = 0. + snowmodel_struc(n)%sm(:)%canopy_int_old = 0. + snowmodel_struc(n)%sm(:)%topo = 0. + snowmodel_struc(n)%sm(:)%sum_sprec = 0. + + ! SnowModel "initialize" routine code (from preprocess_code.f90) + do i=1,nx + do j=1,ny + ! Fill the summing arrays. + sum_runoff(i,j) = 0.0 + sum_prec(i,j) = 0.0 + sum_sprec(i,j) = 0.0 + sum_qsubl(i,j) = 0.0 + sum_trans(i,j) = 0.0 + sum_unload(i,j) = 0.0 + sum_Qcs(i,j) = 0.0 + sum_glacmelt(i,j) = 0.0 + sum_swemelt(i,j) = 0.0 + sum_d_canopy_int(i,j) = 0.0 + sum_sfcsublim(i,j) = 0.0 + + ! Define the initial snow-depth distributions. + snow_d_init(i,j) = snow_d_init_const + snow_d(i,j) = snow_d_init(i,j) + snow_depth(i,j) = snow_d_init(i,j) + canopy_int(i,j) = 0.0 + soft_snow_d(i,j) = snow_d(i,j) + ro_snow_grid(i,j) = ro_snow + swe_depth(i,j) = snow_d(i,j) * ro_snow_grid(i,j) / ro_water + ro_soft_snow_old(i,j) = 50.0 + swe_depth_old(i,j) = swe_depth(i,j) + canopy_int_old(i,j) = canopy_int(i,j) + + ! Initialize the multi-layer snowpack arrays. + KK(i,j) = 0 + tslsnowfall(i,j) = tsls_threshold + + enddo + enddo + + do i=1,nx + do j=1,ny + do k=1,nz_max + snod_layer(i,j,k) = 0.0 + swed_layer(i,j,k) = 0.0 + ro_layer(i,j,k) = ro_snow + T_old(i,j,k) = 273.15 + gamma(i,j,k) = 0.138 - 1.01 * (ro_layer(i,j,k)/1000.0) + & + 3.233 * (ro_layer(i,j,k)/1000.0)**2 + diam_layer(i,j,k) = 0.5 / 1000.0 + enddo + enddo + enddo + + if (topoflag.eq.1.0) then + do i=1,nx + do j=1,ny + topo(i,j) = topo_land(i,j) + snow_d(i,j) + enddo + enddo + elseif (topoflag.eq.0.0) then + do i=1,nx + do j=1,ny + topo(i,j) = topo_land(i,j) + enddo + enddo + endif + + endif + enddo + +end subroutine SnowModel_coldstart diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 new file mode 100644 index 000000000..4e8f378f4 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 @@ -0,0 +1,37 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: snowmodel_dynsetup +! \label{snowmodel_dynsetup} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_dynsetup(n) +! !USES: + use LIS_coreMod, only : LIS_rc,LIS_domain, LIS_surface + use LIS_logMod, only : LIS_logunit, LIS_endrun +! use LIS_snowMod, only : LIS_snow_struc +! use LIS_vegDataMod, only : LIS_gfrac, LIS_lai, LIS_roughness + use snowmodel_lsmMod, only : snowmodel_struc + use LIS_timeMgrMod, only : LIS_date2time,LIS_tick +! +! !DESCRIPTION: +! This routine sets up the time-dependent variables in SnowModel. +! +!EOP + + implicit none + integer, intent(in) :: n + + write(LIS_logunit,*) '[INFO] Call to the SnowModel dynamic setup routine ...' + +end subroutine snowmodel_dynsetup diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 new file mode 100644 index 000000000..c87755a93 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 @@ -0,0 +1,244 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: snowmodel_f2t +! \label{snowmodel_f2t} +! +! !REVISION HISTORY: +! 15 Oct 2002: Sujay Kumar; Initial Code +! 14 Apr 2020: Kristi Arsenault; Added G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_f2t(n) +! !USES: + use ESMF + use LIS_coreMod, only : LIS_rc, LIS_surface + use LIS_FORC_AttributesMod + use LIS_metforcingMod, only : LIS_FORC_State + use LIS_logMod, only : LIS_logunit, LIS_verify, & + LIS_endrun + use snowmodel_lsmMod + use snowmodel_vars + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n +! +! !DESCRIPTION: +! This routine transfers the LIS provided forcing onto the SnowModel +! model tiles. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \end{description} +! +!EOP + + integer :: t,v,status + integer :: tid + type(ESMF_Field) :: tmpField,q2Field,uField,vField,swdField,lwdField + type(ESMF_Field) :: psurfField,pcpField,snowfField,fhgtField + real,pointer :: tmp(:),q2(:),uwind(:),vwind(:),snowf(:) + real,pointer :: swd(:),lwd(:),psurf(:),pcp(:) + real,pointer :: fheight1(:,:),fheight(:) + integer, pointer :: layer_windht(:), layer_relhumht(:) +! __________________ + + write(LIS_logunit,*) '[INFO] Call to the SnowModel Forcing 2 tile routine ...' + + if ( LIS_FORC_Forc_Hgt%selectOpt.eq.1 ) then + + allocate(fheight1(LIS_FORC_Forc_Hgt%vlevels,LIS_rc%ntiles(n))) + allocate(layer_windht(LIS_rc%ntiles(n))) + allocate(layer_relhumht(LIS_rc%ntiles(n))) + + ! Forcing heights are specified. Find the layers corresponding to the reference heights. + ! If not, use the lowest model layer as the height. + + do v=1,LIS_FORC_Forc_Hgt%vlevels + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Forc_Hgt%varname(v)),& + fhgtField, rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Forc_Hgt') + + call ESMF_FieldGet(fhgtField,localDE=0,farrayPtr=fheight,rc=status) + fheight1(v,:) = fheight(:) + call LIS_verify(status,'snowmodel_f2t: error retrieving fheight') + enddo + + call snowmodel_find_forcing_heights(LIS_FORC_Forc_Hgt%vlevels, LIS_rc%ntiles(n),& + fheight1, snowmodel_struc(n)%ht_rhobs, snowmodel_struc(n)%ht_windobs, & + layer_windht, layer_relhumht) + + if (LIS_rc%ntiles(n).ne.0) then + snowmodel_struc(n)%ht_rhobs = fheight1(layer_relhumht(1),1) + snowmodel_struc(n)%ht_windobs = fheight1(layer_windht(1),1) + endif + + deallocate(fheight1) + deallocate(layer_windht) + deallocate(layer_relhumht) + endif + ! If forcing heights are not specified, then LIS will assume that forcing data + ! corresponds to the reference heights snowmodel.par (tmprh_ht, wind_ht). + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Tair%varname(1)),tmpField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Tair') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Qair%varname(1)),q2Field,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Qair') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Wind_E%varname(1)),uField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Wind_E') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Wind_N%varname(1)),vField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Wind_N') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_SWdown%varname(1)),swdField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting SWdown') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_LWdown%varname(1)),lwdField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting LWdown') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Psurf%varname(1)),psurfField,& + rc=status) + call LIS_verify(status, 'snowmodel_f2t: error getting PSurf') + + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Rainf%varname(1)),pcpField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Rainf') + + if(LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Forc_Hgt%varname(1)),fhgtField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Forc_Hgt') + endif + + if(LIS_FORC_Snowf%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_State(n),(LIS_FORC_Snowf%varname(1)),snowfField,& + rc=status) + call LIS_verify(status,'snowmodel_f2t: error getting Snowf') + endif + + call ESMF_FieldGet(tmpField, localDE=0, farrayPtr=tmp,rc=status) + call LIS_verify(status, 'snowmodel_f2t: error retrieving Tair') + + call ESMF_FieldGet(q2Field,localDE=0, farrayPtr=q2,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving q2') + + call ESMF_FieldGet(swdField,localDE=0, farrayPtr=swd,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving swd') + + call ESMF_FieldGet(lwdField,localDE=0, farrayPtr=lwd,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving lwd') + + call ESMF_FieldGet(uField,localDE=0, farrayPtr=uwind,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving u') + + call ESMF_FieldGet(vField,localDE=0, farrayPtr=vwind,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving v') + + call ESMF_FieldGet(psurfField,localDE=0, farrayPtr=psurf,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving psurf') + + call ESMF_FieldGet(pcpField,localDE=0, farrayPtr=pcp,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving pcp') + + if(LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + call ESMF_FieldGet(fhgtField,localDE=0, farrayPtr=fheight,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving forc_hgt') + endif + + if(LIS_FORC_Snowf%selectOpt.eq.1) then + call ESMF_FieldGet(snowfField,localDE=0, farrayPtr=snowf,rc=status) + call LIS_verify(status,'snowmodel_f2t: error retrieving snowf') + endif + + snowmodel_struc(n)%forc_count = snowmodel_struc(n)%forc_count + 1 + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + ! Transform tile to the patch + tid = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%tile_id + snowmodel_struc(n)%sm(t)%tair=snowmodel_struc(n)%sm(t)%tair + tmp(tid) + snowmodel_struc(n)%sm(t)%qair=snowmodel_struc(n)%sm(t)%qair + q2(tid) + snowmodel_struc(n)%sm(t)%swdown=snowmodel_struc(n)%sm(t)%swdown + swd(tid) + snowmodel_struc(n)%sm(t)%lwdown=snowmodel_struc(n)%sm(t)%lwdown + lwd(tid) + snowmodel_struc(n)%sm(t)%uwind=snowmodel_struc(n)%sm(t)%uwind + uwind(tid) + snowmodel_struc(n)%sm(t)%vwind=snowmodel_struc(n)%sm(t)%vwind + vwind(tid) + snowmodel_struc(n)%sm(t)%psurf=snowmodel_struc(n)%sm(t)%psurf + psurf(tid) + + if ( LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + snowmodel_struc(n)%sm(t)%fheight=fheight(tid) + endif + + if(pcp(tid).ne.LIS_rc%udef) then + snowmodel_struc(n)%sm(t)%rainf=snowmodel_struc(n)%sm(t)%rainf + pcp(tid) + else + snowmodel_struc(n)%sm(t)%rainf=snowmodel_struc(n)%sm(t)%rainf + 0.0 + endif + + ! If there is snowf add it to precipitation. + ! NOTE: SnowModel has options/code to discriminate between rainf/snowf + ! within MicroMet. + ! Will need to address this issue ... + ! Place options / code in new "sliced out" MicroMet routines ... + if ( LIS_FORC_Snowf%selectOpt.eq.1) then + if(snowf(tid).ne.LIS_rc%udef) then + snowmodel_struc(n)%sm(t)%rainf=snowmodel_struc(n)%sm(t)%rainf + & + snowf(tid) + endif + endif + snowmodel_struc(n)%sm(t)%snowf = snowmodel_struc(n)%sm(t)%snowf+ 0.0 + + enddo + +! if(pcp(100) < 0) then +! print *, "pcp :: ",snowmodel_struc(n)%forc_count, pcp(100) +! endif +! print *, tmp(100), snowmodel_struc(n)%sm(100)%tair +! print *, uwind(100), snowmodel_struc(n)%sm(100)%uwind +! print *, vwind(100), snowmodel_struc(n)%sm(100)%vwind +! print *, psurf(100), snowmodel_struc(n)%sm(100)%psurf +! print *, pcp(100), snowmodel_struc(n)%sm(100)%rainf + +end subroutine snowmodel_f2t + + +subroutine snowmodel_find_forcing_heights(vlevels, ntiles, fheight, & + tmprh_ht, wind_ht, layer_tmprh, layer_wind) + + implicit none + + integer :: vlevels, ntiles + real :: fheight(vlevels, ntiles) + real :: tmprh_ht, wind_ht + integer :: layer_tmprh(ntiles) + integer :: layer_wind(ntiles) + integer :: t,v + +!assume lowest model layer to start with. + layer_tmprh = 1 + layer_wind = 1 + + do t=1,ntiles + do v=1,vlevels + if(fheight(v,t).ge.tmprh_ht) layer_tmprh(t) = v + if(fheight(v,t).ge.wind_ht) layer_wind(t) = v + enddo + enddo + +end subroutine snowmodel_find_forcing_heights diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 new file mode 100644 index 000000000..cfc3d71c2 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 @@ -0,0 +1,44 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: snowmodel_finalize +! \label{snowmodel_finalize} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_finalize() +! !USES: + use LIS_logMod, only : LIS_logunit + use snowmodel_lsmMod +! +! !DESCRIPTION: +! +! This routine cleans up the allocated memory structures in SnowModel +! +!EOP + implicit none + + integer :: t + + ! Print a banner when the model run is finished. + write(LIS_logunit,*)& + & 'ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' + write(LIS_logunit,*)& + & ' The SnowModel Run Has Finished ' + write(LIS_logunit,*)& + & 'ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc' + + +end subroutine snowmodel_finalize + + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 new file mode 100644 index 000000000..fc01b019b --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 @@ -0,0 +1,615 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +module snowmodel_lsmMod +!BOP +! +! !MODULE: snowmodel_lsmMod +! +! !DESCRIPTION: +! +! This module provides the definition of derived data type used to +! control the operation of SnowModel. It also provides the entry +! method for the initialization of SnowModel-specific variables. +! The derived data type {\tt snowmodel\_struc} includes the variables +! that specify the runtime options and other control variables as +! described below: +! +! \begin{description} +! \item[rfile] +! name of the SnowModel restart file +! \item[rformat] +! format of restart file (binary or netcdf) for SnowModel +! \item[vfile] +! name of the static vegetation parameter table +! \item[parfile] +! name of the main input parameter for SnowModel +! \item[count] +! variable to keep track of the number of timesteps before an output +! \item[nsnow] +! number of snow layers +! \item[nvegp] +! number of static vegetation parameters in the table +! \item[inittemp] +! initial soil temperatures for a cold start run +! \item[rstInterval] +! restart writing interval +! \item[ht_rhobs] +! reference height of T and q forcing +! \item[ht_windobs] +! reference height of u and v forcing +! \item[lyrthk] +! thickness of soil layers +! \item[snowmodel] +! SnowModel specific variables +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Added G. Liston's SnowModel +! +! !USES: + use snowmodel_module + use snowmodel_vars + + implicit none + + PRIVATE +!----------------------------------------------------------------------------- +! !PUBLIC MEMBER FUNCTIONS: +!----------------------------------------------------------------------------- + public :: snowmodel_init +!----------------------------------------------------------------------------- +! !PUBLIC TYPES: +!----------------------------------------------------------------------------- + public :: snowmodel_struc +!EOP + type, public :: snowmodel_type_dec + + ! LIS related parameters: + real :: rstInterval + character(256) :: rfile + character(256) :: rformat + + ! LIS-SnowModel related parameters: + character(256) :: parfile + character(256) :: vfile + real :: ht_windobs + real :: ht_rhobs + integer :: call_sm_preproc + integer :: write_sm_metfields + character(10) :: sm_params_opt + character(10) :: sm_micromet_opt + + integer :: nsnow + real, allocatable :: lyrthk(:) + real, allocatable :: inittemp(:) + real :: initsnowdepth + real :: initsnowequiv + + integer :: forc_count + + real :: ts + integer :: iter + + ! SnowModel parameter - snowmodel.h +! integer :: nx_max +! integer :: ny_max +! integer :: nstns_max +! integer :: nvegtypes +! integer :: max_time_steps +! integer :: max_obs_dates +! integer :: nz_max +! integer :: n_print_vars + + ! SnowModel parameter - snowmodel_vars.h + integer :: max_iter + integer :: nx + integer :: ny + real :: deltax + real :: deltay + + real :: run_micromet + real :: run_enbal + real :: run_snowpack + real :: run_snowtran + + real :: usum_glb + real :: vsum_glb + real :: windspdflg_glb + real :: wslopemax_glb + real :: curvemax_glb + real :: bsflag_glb + + type(snowmodeldec), allocatable :: sm(:) + + end type snowmodel_type_dec + + type(snowmodel_type_dec), allocatable :: snowmodel_struc(:) + SAVE + +contains +!BOP +! +! !ROUTINE: snowmodel_init +! \label{snowmodel_init} +! +! !INTERFACE: + subroutine snowmodel_init(eks) +! !USES: + use ESMF + use LIS_coreMod + use LIS_logMod + use LIS_timeMgrMod, only : LIS_clock, LIS_calendar, & + LIS_update_timestep, LIS_registerAlarm + use LIS_surfaceModelDataMod + use LIS_lsmMod + use snowmodel_inc + use snowmodel_vars +! +! !DESCRIPTION: +! +! This routine creates the datatypes and allocates memory for +! SnowModel-specific variables. It also invokes the routine to +! read the runtime specific options for SnowModel from the +! configuration file. +! +! The routines invoked are: +! \begin{description} +! \item[snowmodel\_readconfig](\ref{snowmodel_readconfig}) \newline +! reads the runtime options for SnowModel +! \end{description} +!EOP + implicit none + integer, intent(in) :: eks + + integer :: n,t + character(3) :: fnest + integer :: status + + type(ESMF_ArraySpec) :: arrspec1 + type(ESMF_Field) :: sweField, snwdField + +! _____________________________________________________ + + allocate(snowmodel_struc(LIS_rc%nnest)) + + ! Read in LIS config entries for SnowModel: + call snowmodel_readconfig() + + do n=1,LIS_rc%nnest + + allocate(snowmodel_struc(n)%sm(LIS_rc%npatch(n,LIS_rc%lsm_index))) + + ! Number of snow layers (e.g., 2, 25) + snowmodel_struc(n)%nsnow = 1 ! Set to 1 for now, can be high as 25 + + ! Call Snowmodel read parameter subroutine to read in + ! primary parameter and input settings to run the model: + + snowmodel_dot_par_fname = trim(snowmodel_struc(n)%parfile) + + if( LIS_localPet==0 ) then + snowmodel_masterproc = .true. + else + snowmodel_masterproc = .false. + endif + + call READPARAM_CODE(& + dt,deltax,deltay,Utau_t_flag,& + subgrid_flag,twolayer_flag,snowmodel_dot_par_fname,& + bc_flag,curve_len_scale,slopewt,curvewt,ht_windobs,& + ht_rhobs,ro_snow,snow_d_init_const,const_veg_flag,& + vegsnowdepth,LIS_rc%lnc(n),LIS_rc%lnr(n),max_iter,met_input_fname,xmn,ymn,& ! KRA: nx,ny + iyear_init,imonth_init,iday_init,xhour_init,undef,ifill,& + iobsint,dn,xlat,i_tair_flag,i_rh_flag,i_wind_flag,& + i_solar_flag,i_prec_flag,isingle_stn_flag,igrads_metfile,& + windspd_min,icond_flag,run_micromet,run_enbal,run_snowpack,& + run_snowtran,topoflag,topoveg_fname,snowtran_output_fname,& + micromet_output_fname,enbal_output_fname,Utau_t_const,& + snowpack_output_fname,print_micromet,print_enbal,& + print_snowpack,print_snowtran,i_longwave_flag,print_user,& + ascii_topoveg,topo_ascii_fname,veg_ascii_fname,& + irun_data_assim,lapse_rate_user_flag,& + iprecip_lapse_rate_user_flag,use_shortwave_obs,& + use_longwave_obs,use_sfc_pressure_obs,calc_subcanopy_met,& + sfc_sublim_flag,gap_frac,cloud_frac_factor,& + albedo_snow_forest,albedo_snow_clearing,albedo_glacier,& + barnes_lg_domain,n_stns_used,tabler_dir,slope_adjust,& + lat_solar_flag,UTC_flag,iveg_ht_flag,ihrestart_flag,& + ihrestart_inc,i_dataassim_loop,tsls_threshold,dz_snow_min,& + print_multilayer,multilayer_snowpack,max_layers,& + multilayer_output_fname,izero_snow_date,curve_lg_scale_flag,& + check_met_data,seaice_run,snowmodel_line_flag,wind_lapse_rate,& + iprecip_scheme,cf_precip_flag,snowfall_frac,print_inc,& + output_path_wo_assim,output_path_wi_assim,Tabler_1_flag,& + Tabler_2_flag,tabler_sfc_path_name,print_var) + + ! Check SnowModel parameter source origins: + if( snowmodel_struc(n)%sm_params_opt == "LDT" ) then + write(LIS_logunit,*) "[INFO] Reading in SnowModel LSM parameters from LDT" + ascii_topoveg = 2.0 ! No file read in by SnowModel; use LDT input + else + write(LIS_logunit,*) "[INFO] Reading in SnowModel LSM parameters from snowmodel.par file " + endif + + ! Check SnowModel Micromet source calls: + if( snowmodel_struc(n)%sm_micromet_opt == "SnowModel" ) then + write(LIS_logunit,*) "[INFO] Calling MicroMet routines within SnowModel " + elseif( snowmodel_struc(n)%sm_micromet_opt == "LIS" ) then + write(LIS_logunit,*) "[INFO] Calling MicroMet routines from LIS metforcing layer " + else + write(LIS_logunit,*) "[ERR] Incorrect option set for " + write(LIS_logunit,*) "[ERR] SnowModel MicroMet input source: " + write(LIS_logunit,*) "[ERR] See documentation in configs/lis.config.adoc " + write(LIS_logunit,*) "[ERR] for option details. " + call LIS_endrun + endif + + ! Check inputs to driving SnowModel: + write(LIS_logunit,*) "[INFO] Reading in SnowModel input options" + write(LIS_logunit,*) ' Run Micromet : ',run_micromet + write(LIS_logunit,*) ' Run EnBal : ',run_enbal + write(LIS_logunit,*) ' Run Snowpack : ',run_snowpack + write(LIS_logunit,*) ' Run Snowtran : ',run_snowtran + write(LIS_logunit,*) ' Run data assimilation: ',irun_data_assim + write(LIS_logunit,*) ' Data assimilation loop: ',i_dataassim_loop + write(LIS_logunit,*) ' Undefined value: ',undef + write(LIS_logunit,*) '' + write(LIS_logunit,*) "[INFO] SnowModel grid information: " + write(LIS_logunit,*) "[INFO] Note: SnowModel typically runs on an" + write(LIS_logunit,*) " equal-area grid, e.g., UTM or Albers Equal Area" + write(LIS_logunit,*) ' Number of x cells in grid: ',nx + write(LIS_logunit,*) ' Number of y cells in grid: ',ny + write(LIS_logunit,*) ' Increment in x direction(m): ',deltax + write(LIS_logunit,*) ' Increment in y direction(m): ',deltay + write(LIS_logunit,*) ' LL_X Location in meters (UTM): ',xmn + write(LIS_logunit,*) ' LL_Y Location in meters (UTM): ',ymn + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) "[INFO] SnowModel date/time information: " + write(LIS_logunit,*) ' Model time step: ',dt + write(LIS_logunit,*) ' Start year of input data: ',iyear_init + write(LIS_logunit,*) ' Start month of input data: ',imonth_init + write(LIS_logunit,*) ' Start day of input data: ',iday_init + write(LIS_logunit,*) ' Start hour of input data: ',xhour_init + write(LIS_logunit,*) ' Maximum iterations: ',max_iter + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) "[INFO] SnowModel veg and topo information: " + write(LIS_logunit,*) ' Topo and veg input file type: ',ascii_topoveg + write(LIS_logunit,*) ' Topo and veg file name: ',trim(topoveg_fname) + write(LIS_logunit,*) ' Constant veg type: ',const_veg_flag + write(LIS_logunit,*) ' Veg height flag: ',iveg_ht_flag + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) '[INFO] SnowModel solar radiation calculations: ' + write(LIS_logunit,*) ' UTC flag(local=0; UTC: GRADS_long=-1,TXT_long=1): ',UTC_flag + write(LIS_logunit,*) ' Latitude solar flag (same as UTC flag options): ',lat_solar_flag + write(LIS_logunit,*) ' Domain center latitude (used when lat_solar_flag=0): ',xlat + ! Input height of wind and rh observations (ENBAL and SNOWTRAN): + write(LIS_logunit,*) '[INFO] Other SnowModel Inputs (ENBAL AND SNOWTRAN)' + write(LIS_logunit,*) ' Height of wind obs: ',ht_windobs + write(LIS_logunit,*) ' Height of rel hum obs: ',ht_rhobs + write(LIS_logunit,*) ' ' + ! Micromet Model setup:: + write(LIS_logunit,*) '[INFO] MICROMET ENTRIES ... ' + write(LIS_logunit,*) ' Tair output : ',i_tair_flag + write(LIS_logunit,*) ' RH output : ',i_rh_flag + write(LIS_logunit,*) ' Wind output : ',i_wind_flag + write(LIS_logunit,*) ' SWrad output: ',i_solar_flag + write(LIS_logunit,*) ' LWdown output: ',i_longwave_flag + write(LIS_logunit,*) ' Prec output : ',i_prec_flag + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) ' Met Input Filename: ',trim(met_input_fname) + write(LIS_logunit,*) ' Run met forcing check: ',check_met_data + write(LIS_logunit,*) ' MicroMet station flag: ',isingle_stn_flag + write(LIS_logunit,*) ' MicroMet GrADS Metfile: ',igrads_metfile + write(LIS_logunit,*) ' Barnes station interp: ',barnes_lg_domain + write(LIS_logunit,*) ' Barnes nearest stations number: ',n_stns_used + write(LIS_logunit,*) ' Radius of influence: ',iobsint + write(LIS_logunit,*) ' Radius of influence - obs interval: ',dn + + write(LIS_logunit,*) ' ' + ! These may be useful and considered: + write(LIS_logunit,*) ' Run grid as 1d vector (not 2d): ', snowmodel_line_flag + + ! Preprocess, MicroMet, SnowTran3D + write(LIS_logunit,*) '[INFO] Wind model curvature entries (MicroMet, SNOWTRAN)' + write(LIS_logunit,*) ' Wind model curvature (len scale): ',curve_len_scale + write(LIS_logunit,*) ' Wind model curve weight: ',curvewt + write(LIS_logunit,*) ' Wind model slope weight: ',slopewt + write(LIS_logunit,*) ' Wind 2nd len scale curve affect: ',curve_lg_scale_flag + + ! MicroMet option for mininum windspeed threshold + write(LIS_logunit,*) ' Min. windspeed threshold: ',windspd_min + + ! Default is 0, but if user wants to change lapse-rate values, + ! they need to do it within micromet_code.f: + write(LIS_logunit,*) ' Monthly lapse rate values: ',lapse_rate_user_flag + + ! Default is 0, but if users want to change precip LR scaling values, + ! they need to do it within micromet_code.f: + write(LIS_logunit,*) ' Precip adjustment factor (precip LR scaling): ',iprecip_lapse_rate_user_flag + + ! Two precip-increase-with-elev schemes; 1-orig, 2-van Pelt scheme: + write(LIS_logunit,*) ' Precip-increase-elev scheme: ',iprecip_scheme + + ! Define rain-snow fraction of precip water equiv (forcing) calculation scheme: + write(LIS_logunit,*) ' Rain-snow fraction WE calculation scheme: ',snowfall_frac + + ! Turn on wind lapse-rate factor: + write(LIS_logunit,*) ' Wind lapse-rate factor: ',wind_lapse_rate + + ! Turn on sub-forest-canopy estimates for wind-speed, solar rad, and LW rad: + write(LIS_logunit,*) ' Calc Sub-forest-canopy estimates: ',calc_subcanopy_met + + ! Define canopy gap fraction (0-1) for solar radiation reaching snow below canopy: + write(LIS_logunit,*) ' Canopy gap fraction: ',gap_frac + + ! Cloud fraction factor can be used to reduce cloud-cover fraction, + ! like in valley locations. + write(LIS_logunit,*) ' Cloud fraction factor: ',cloud_frac_factor + + ! Select whether SW radiation obs will be assimilated: + write(LIS_logunit,*) ' SW radiation obs DA: ',use_shortwave_obs + + ! Select whether LW radiation obs will be assimilated: + write(LIS_logunit,*) ' LW radiation obs DA: ',use_longwave_obs + + ! Select whether sfc pressure obs will be assimilated: + write(LIS_logunit,*) ' Surface pressure obs DA: ',use_sfc_pressure_obs + + ! User-defined precip correction factor, either 2d field applied, or constant factor: + ! default=0, turned off + write(LIS_logunit,*) ' Precipitation correction factor: ',cf_precip_flag + + write(LIS_logunit,*) '** ENDING MICROMET ENTRIES ... ' + + ! EnBAL Model setup:: + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) '[INFO] ENBAL ENTRIES ... ' + + ! Surface energy balance calculation accounting for non-0 conduction term + ! 0-single layer; 1-multilayer snowpack physics + write(LIS_logunit,*) ' Energy balance calc with non-0 cond. term: ', icond_flag + + ! Define albedo for melting snow cover under forest canopy + write(LIS_logunit,*) ' ENBAL: Forest snow melt albedo value: ',albedo_snow_forest + + ! Define albedo for melting snow cover in non-forested areas: + write(LIS_logunit,*) ' ENBAL: Nonforest snow melt albedo value: ',albedo_snow_clearing + + ! Define albedo for glacier surface: + write(LIS_logunit,*) ' ENBAL: Glacier surface albedo value: ',albedo_glacier + + write(LIS_logunit,*) '** ENDING ENBAL ENTRIES ... ' + + write(LIS_logunit,*) ' ' + ! SnowPack Model setup:: + write(LIS_logunit,*) '[INFO] SNOWPACK ENTRIES ... ' + + ! Set static-surface (non-blowing snow) sublimation effect on: + ! If on, Qle from ENBAL is used to add/remove snow via sublimation: + write(LIS_logunit,*) ' SNOWPACK: non-blowing snow sublimation effect: ',sfc_sublim_flag + + ! Turn on multilayer snowpack option: + write(LIS_logunit,*) ' SNOWPACK: multilayer option: ',multilayer_snowpack + + ! Define time since last snowfall to determine if new snow layer gets created: + write(LIS_logunit,*) ' SNOWPACK: time since snowfall for creating new snow layer: ',tsls_threshold + + ! Define the min snow layer thickness (m) for multi-layer snowpack model. + write(LIS_logunit,*) ' SNOWPACK: min snow layer thickness(m): ',dz_snow_min + + ! Set date to reset snowpack to 0 to not allow glacier formation in multi-year runs: + ! To disable setting = 999999 + write(LIS_logunit,*) ' SNOWPACK: date for zeroing out snowpack: ',izero_snow_date + + write(LIS_logunit,*) '** ENDING SNOWPACK ENTRIES ... ' + + write(LIS_logunit,*) ' ' + ! SnowTran-3d Model setup:: + write(LIS_logunit,*) '[INFO] SNOWTRAN3D ENTRIES ... ' + + ! Threshold surface shear velocity as function of AirTemp and Wspd: + write(LIS_logunit,*) ' SNOWTRAN: Surface shear velocity flag (T+Wspd): ',Utau_t_flag + + ! Surface shear velocity threshold (when Utau_t_flag=0): + write(LIS_logunit,*) ' SNOWTRAN: Surface shear velocity threshold: ',Utau_t_const + + ! Flag to turn on the Tabler subgrid algorithm (0-no snow redistribution) + ! Not appropriate for grid increments > 30 m. If turned on, topoflag = 1. + write(LIS_logunit,*) ' SNOWTRAN: Tabler subsgrid snow redistribution option: ',subgrid_flag + + ! When Tabler flag on, user can define dominant wind direction (of 8 directions). + ! Value is set constant over domain area: + write(LIS_logunit,*) ' SNOWTRAN: Tabler constant wind directory: ',tabler_dir + + ! Adjust slopes of Tabler surfaces using 'slope-adjust' parameter, which + ! is multiplied by calc. Tabler equilibrium drift sufrace slope. + write(LIS_logunit,*) ' SNOWTRAN: Tabler slope surface adjustment: ',slope_adjust + + ! Account for two snow-layer movement: + write(LIS_logunit,*) ' SNOWTRAN: Snow-layer movement: ',twolayer_flag + + ! Define upwind boundary to have 0 incoming transport flux: + write(LIS_logunit,*) ' SNOWTRAN: Upwind boundary incoming transport flux: ',bc_flag + + ! Snowtran wo Snowpack -- Provide Snow density: + write(LIS_logunit,*) ' SNOWTRAN: snow density (when Snowpack off): ',ro_snow + + ! Define initial snow-depth distributions: + write(LIS_logunit,*) ' SNOWTRAN: Initial snow-depth distribution: ',snow_d_init_const + + ! Flag to set surface topography to ground topography: + write(LIS_logunit,*) ' SNOWTRAN: Set surface topography to ground topography: ',topoflag + + write(LIS_logunit,*) '** END SNOWTRAN3D ENTRIES ... WILL CHECK WITH OTHER SUBMODELS' + write(LIS_logunit,*) ' ' + + ! SeaIce Model: + write(LIS_logunit,*) '[INFO] SEAICE ENTRIES ... ' + ! Define whether to simulate snow on sea ice: + write(LIS_logunit,*) 'SEAICE: Turn on sea-ice option: ',seaice_run + write(LIS_logunit,*) '** END SEAICE ENTRIES ... ' + + write(LIS_logunit,*) ' ' + write(LIS_logunit,*) '[INFO] Output directory information ' + write(LIS_logunit,*) ' OUTPUT: Output directory: ',trim(output_path_wo_assim) + write(LIS_logunit,*) ' OUTPUT: DA Output directory: ',trim(output_path_wi_assim) + write(LIS_logunit,*) ' OUTPUT: Write individual files(1=yes): ',print_user + ! This option below defines the write output increment, etc., 8 = 3 hourly + write(LIS_logunit,*) ' OUTPUT: Print increment, (times)X(day): ',print_inc + ! Output print options: + write(LIS_logunit,*) '[INFO] SnowModel values averaged over the period' + write(LIS_logunit,*) ' OUTPUT: Tair (degC) : ',print_var(1) + write(LIS_logunit,*) ' OUTPUT: RH (%) : ',print_var(2) + write(LIS_logunit,*) ' OUTPUT: Wind spd (m/s) : ',print_var(3) + write(LIS_logunit,*) ' OUTPUT: Inc solar radiation (W/m2) : ',print_var(4) + write(LIS_logunit,*) ' OUTPUT: Inc LW radiation (W/m2) : ',print_var(5) + write(LIS_logunit,*) ' OUTPUT: Emitted LW rad (W/m2) : ',print_var(6) + write(LIS_logunit,*) ' OUTPUT: albedo (-) : ',print_var(7) + write(LIS_logunit,*) ' OUTPUT: wind direction (deg) : ',print_var(8) + write(LIS_logunit,*) ' OUTPUT: Cloud fraction (ave over period): ',print_var(21) + + write(LIS_logunit,*) '[INFO] SnowModel values summed over period' + write(LIS_logunit,*) ' OUTPUT: Wat eqv precip (m/ts) : ',print_var(9) + write(LIS_logunit,*) ' OUTPUT: Liq precip (m/ts) : ',print_var(10) + write(LIS_logunit,*) ' OUTPUT: Solid precip (m/ts) : ',print_var(11) + write(LIS_logunit,*) ' OUTPUT: SWE melt (m) : ',print_var(12) + write(LIS_logunit,*) ' OUTPUT: Surface sublmiation (m) : ',print_var(13) + write(LIS_logunit,*) ' OUTPUT: Runoff from snowpack base (m/ts): ',print_var(14) + write(LIS_logunit,*) ' OUTPUT: SWE melt from glacier ice (m) : ',print_var(15) + + write(LIS_logunit,*) '[INFO] SnowModel values saved at the end of period' + write(LIS_logunit,*) ' OUTPUT: Snow depth (m) : ',print_var(16) + write(LIS_logunit,*) ' OUTPUT: Snow density (kg/m3) : ',print_var(17) + write(LIS_logunit,*) ' OUTPUT: SWE (m) : ',print_var(18) + write(LIS_logunit,*) ' OUTPUT: Summed snow precip year (m) : ',print_var(19) + write(LIS_logunit,*) ' OUTPUT: Summed SWE melt for year (m) : ',print_var(20) + + ! Output print options: +! write(LIS_logunit,*) ' OUTPUT: Micromet variables: ',print_micromet +! write(LIS_logunit,*) ' OUTPUT: EnBal variables: ',print_enbal +! write(LIS_logunit,*) ' OUTPUT: Snowpack variables: ',print_snowpack +! write(LIS_logunit,*) ' OUTPUT: Snowpack multilayer variables: ',print_multilayer +! write(LIS_logunit,*) ' OUTPUT: SnowTran variables: ',print_snowtran +! write(LIS_logunit,*) ' OUTPUT: SnowTran Tabler1 fields: ',Tabler_1_flag +! write(LIS_logunit,*) ' OUTPUT: SnowTran Tabler2 fields: ',Tabler_2_flag + + ! ------------------------------ + + ! SnowModel Main code calls and options for reading in and + ! preprocessing necessary inputs to the submodel components: + ! All below from the original snomodel_main.f ... + + ! This loop runs the correction/data assimilation adjustment + ! iterations. + if (ihrestart_flag.ge.0) then + if (i_dataassim_loop.lt.0.0) then + i_corr_start = 2 + else + i_corr_start = 1 + endif + else + i_corr_start = 1 + endif + + do icorr_factor_loop=i_corr_start,irun_data_assim+1 + + ! Perform the correction (precipitation and melt) factor + ! calculations. + if (irun_data_assim.eq.1 .and. icorr_factor_loop.eq.2) then + write(LIS_logunit,*) "[WARN] No call to 'DATAASSIM_USER' at this time" + CALL DATAASSIM_USER(LIS_rc%lnc(n),LIS_rc%lnr(n),icorr_factor_index,& ! KRA: nx,ny + corr_factor,max_iter,deltax,deltay,xmn,ymn,nobs_dates,& + print_inc,iday_init,imonth_init,iyear_init,dt,& + output_path_wo_assim,xhour_init) + if (ihrestart_flag.ge.-1) then + write(LIS_logunit,*) "[WARN] No call to 'HRESTART_SAVE_DA' at this time" + CALL HRESTART_SAVE_DA(LIS_rc%lnc(n),LIS_rc%lnr(n),max_iter,corr_factor,& ! KRA: nx,ny + icorr_factor_index,nobs_dates) + endif + endif + + end do + + ! ------------------------------ + + ! Passing the required SnowModel fields to LIS for what LIS requires ... + snowmodel_struc(n)%iter = 0 + + ! Initialize forcing fields: + snowmodel_struc(n)%forc_count = 0 + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + snowmodel_struc(n)%sm(t)%tair = 0 + snowmodel_struc(n)%sm(t)%qair = 0 + snowmodel_struc(n)%sm(t)%swdown = 0 + snowmodel_struc(n)%sm(t)%lwdown = 0 + snowmodel_struc(n)%sm(t)%uwind = 0 + snowmodel_struc(n)%sm(t)%vwind = 0 + snowmodel_struc(n)%sm(t)%psurf = 0 + snowmodel_struc(n)%sm(t)%rainf = 0 + snowmodel_struc(n)%sm(t)%snowf = 0 + enddo + +!------------------------------------------------------------------------ +! Model timestep Alarm +!------------------------------------------------------------------------ + call LIS_update_timestep(LIS_rc, n, snowmodel_struc(n)%ts) + + write(fnest,'(i3.3)') n + call LIS_registerAlarm("SnowModel model alarm "//trim(fnest),& + snowmodel_struc(n)%ts,& + snowmodel_struc(n)%ts) + + call LIS_registerAlarm("SnowModel restart alarm "//trim(fnest),& + snowmodel_struc(n)%ts,& + snowmodel_struc(n)%rstInterval) + + LIS_sfmodel_struc(n)%ts = snowmodel_struc(n)%ts + + +!------------------------------------------------------------------------ +! Create fields for LSM2SUBLSM exchanges +!------------------------------------------------------------------------ + call ESMF_ArraySpecSet(arrspec1,& + rank=1,typekind=ESMF_TYPEKIND_R4,& + rc=status) + call LIS_verify(status, & + 'ESMF_ArraySpecSet failed in snowmodel_init') + + sweField = ESMF_FieldCreate(& + grid=LIS_vecPatch(n,LIS_rc%lsm_index),& + arrayspec=arrspec1, & + name="Total SWE",& + rc=status) + call LIS_verify(status,& + 'ESMF_FieldCreate failed for SWE in snowmodel_init') + + snwdField = ESMF_FieldCreate(& + grid=LIS_vecPatch(n,LIS_rc%lsm_index),& + arrayspec=arrspec1, & + name="Total snowdepth",& + rc=status) + call LIS_verify(status,& + 'ESMF_FieldCreate failed for snowdepth in snowmodel_init') + + call ESMF_StateAdd(LIS_SUBLSM2LSM_State(n,eks),& + (/sweField/),rc=status) + call LIS_verify(status,& + 'ESMF_StateAdd failed for swe in snowmodel_init') + call ESMF_StateAdd(LIS_SUBLSM2LSM_State(n,eks),& + (/snwdField/),rc=status) + call LIS_verify(status,& + 'ESMF_StateAdd failed for snwd in snowmodel_init') + + enddo + + end subroutine snowmodel_init + +end module snowmodel_lsmMod + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 new file mode 100644 index 000000000..77db618ee --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 @@ -0,0 +1,750 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: snowmodel_main +! \label{snowmodel_main} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_main(n) +! !USES: + use LIS_coreMod + use LIS_timeMgrMod, only : LIS_isAlarmRinging + use LIS_logMod, only : LIS_logunit, LIS_endrun + use LIS_histDataMod + use LIS_FORC_AttributesMod + use LIS_mpiMod + use LIS_metforcingMod, only : LIS_forc + + use snowmodel_module + use snowmodel_lsmMod + use snowmodel_inc + use snowmodel_vars + use micromet_module + +! +! !DESCRIPTION: +! This is the entry point for calling the SnowModel physics. +! This routine calls the {\tt ENBAL} routine that performs the +! land surface computations, to solve for water and energy equations. +! For documentation of the {\tt ENBAL} and routines from the +! SnowModel, please see: +! ftp://gliston.cira.colostate.edu/SnowModel/code/ +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \end{description} +!EOP + implicit none + + integer, intent(in) :: n + + integer :: t, ierr + integer :: row, col, c, r + double precision :: xmn_part ! center x of local LL starting point + double precision :: ymn_part ! center y of local LL starting point + + integer :: J_day ! model Julian day, actually day-of-year + integer :: nveg + real :: rad2deg + real, allocatable :: sphm_grid(:,:) + + real :: delta_topo + real :: T_lapse_rate, Td_lapse_rate + real :: precip_lapse_rate + real :: forcelev + real :: forest_frac, trans_veg + + ! Vegetation impact on winds: + real :: beta, a + real :: veg_ht, canopy_windwt + +! Define the Stefan Boltzmann constant. + real, parameter :: Stef_Boltz = 5.6696e-8 + + character*3 :: fnest + logical :: isTimeToRunCheck + +! -------------------------------------------- + + write(fnest,'(i3.3)') n + isTimeToRunCheck = LIS_isAlarmRinging(LIS_rc, "SnowModel model alarm "//trim(fnest) ) + + if(isTimeToRunCheck .neqv. .true.) return + + write(LIS_logunit,*) '[INFO] Call to the SnowModel Main routine ...' + + ! Using local parallel subdomain starting index values: + ! LIS_ews_halo_ind(n,LIS_localPet+1) -- defined in LIS_coreMod.F90 ... + xmn_part = xmn + deltax * ( real(LIS_ews_halo_ind(n,LIS_localPet+1)) - 1.0 ) + ymn_part = ymn + deltay * ( real(LIS_nss_halo_ind(n,LIS_localPet+1)) - 1.0 ) + + iter_start = 1 + snowmodel_struc(n)%iter = snowmodel_struc(n)%iter + 1 + iter = snowmodel_struc(n)%iter + + write(LIS_logunit,*) "[INFO] Print Snowmodel iter counter: ",iter + + ! Determine source of calls to MicroMet-based routines: + if( snowmodel_struc(n)%sm_micromet_opt == "LIS" ) then + + ! Calculate what the current simulation date should be. + call get_model_time(iyear_init,imonth_init,iday_init,& + xhour_init,iter,dt,iyear,imonth,iday,xhour,J_day) + + if( LIS_masterproc ) then + write(LIS_logunit,151) iyear,imonth,iday,xhour + endif + 151 format(' [INFO] SNOWMODEL TIME =',& + i5,2i4,f6.1) + + ! _________________________________________________________ + + ! Convert local LIS npatch array to the the SnowModel nx,ny grids + if( LIS_masterproc ) then + write(LIS_logunit,*) "[INFO] Replacing MicroMet grid forcings with LIS forcing " + write(LIS_logunit,*) " main:", LIS_rc%mo, LIS_rc%da, LIS_rc%hr, snowmodel_struc(n)%forc_count + endif + + ! Constants required for wind direction and RH calculations: + rad2deg = 180.0 / (2.0 * acos(0.0)) ! pi = (2.0 * acos(0.0)) + windspd_flag = 0.0 + + allocate( sphm_grid(LIS_rc%lnc(n),LIS_rc%lnr(n)) ) + + do t = 1,LIS_rc%npatch(n,LIS_rc%lsm_index) + col = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col + row = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row + + ! Translate LIS-based metforcing into SnowModel required inputs: + tair_grid(col,row) = snowmodel_struc(n)%sm(t)%tair / snowmodel_struc(n)%forc_count + Qsi_grid(col,row) = snowmodel_struc(n)%sm(t)%swdown / snowmodel_struc(n)%forc_count + Qli_grid(col,row) = snowmodel_struc(n)%sm(t)%lwdown / snowmodel_struc(n)%forc_count + sfc_pressure(col,row) = snowmodel_struc(n)%sm(t)%psurf / snowmodel_struc(n)%forc_count + + ! Total precip (in meters) + prec_grid(col,row) = snowmodel_struc(n)%sm(t)%rainf / snowmodel_struc(n)%forc_count + + ! Convert the precipitation values from mm to m swe. Also, make + ! sure the interpolation has not created any negetive + ! precipitation values. + prec_grid(col,row) = (prec_grid(col,row) / 1000.0) * 3600 * snowmodel_struc(n)%forc_count + prec_grid(col,row) = max(0.0,prec_grid(col,row)) + + ! U- and V-gridded winds: + uwind_grid(col,row) = snowmodel_struc(n)%sm(t)%uwind & + / snowmodel_struc(n)%forc_count + vwind_grid(col,row) = snowmodel_struc(n)%sm(t)%vwind & + / snowmodel_struc(n)%forc_count + + ! Wind speed grid: + windspd_grid(col,row) = sqrt(uwind_grid(col,row)**2 + vwind_grid(col,row)**2) + ! Max windspeed flag: + windspd_flag = max(windspd_flag,windspd_grid(col,row)) ! Handled below in "micromet_wind" call + + ! Wind direction: + ! Some compilers do not allow both u and v to be 0.0 in + ! the atan2 computation. + if( abs(uwind_grid(col,row)).lt.1e-10 ) then + uwind_grid(col,row) = 1e-10 + endif + winddir_grid(col,row) = rad2deg * atan2(uwind_grid(col,row),vwind_grid(col,row)) + if( winddir_grid(col,row).ge.180.0 ) then + winddir_grid(col,row) = winddir_grid(col,row) - 180.0 + else + winddir_grid(col,row) = winddir_grid(col,row) + 180.0 + endif + + ! Specific humidity: + sphm_grid(col,row) = snowmodel_struc(n)%sm(t)%qair / snowmodel_struc(n)%forc_count + + end do + + + ! Call functions to derive additional forcing inputs to SnowModel: + call micromet_relhum( LIS_rc%lnc(n),LIS_rc%lnr(n), & + tair_grid, sphm_grid, sfc_pressure, rh_grid ) + + call micromet_snowfall(LIS_rc%lnc(n),LIS_rc%lnr(n), & + snowfall_frac, prec_grid, tair_grid, sprec) + + deallocate( sphm_grid ) + + ! Calculate the forest lai for each of the five forest types, and + ! for this day of the simulation (the lai varies seasonally for + ! the case of deciduous trees). + call get_lai(J_day,forest_LAI) + + + ! Account for vegetation impacts on SWdown, LWdown, and winds : + do t = 1,LIS_rc%npatch(n,LIS_rc%lsm_index) + col = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col + row = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row + + if( vegtype(col,row).le.5.0 ) then + if( calc_subcanopy_met.eq.1.0 ) then + + nveg = nint(vegtype(col,row)) + + ! [SWdown] Incoming solar radiation veg-modifications: + ! Define the forest-canopy transmissivity. 0.71 provided a + ! best-fit to the observations, when averaged over the two years + ! of hourly data. + trans_veg = exp((- 0.71) * forest_LAI(nveg)) + + ! Account for any gaps in the forest canopy that will allow + ! direct incoming solar radiation to reach the snow surface. + trans_veg = gap_frac * (1.0 - trans_veg) + trans_veg + Qsi_grid(col,row) = trans_veg * Qsi_grid(col,row) + + ! [LWdown] Modify the incoming longwave radiation for the forest canopy. + if( forest_LAI(nveg).lt.0.2 ) then + forest_frac = 0.5 * forest_LAI(nveg) + else + forest_frac = & + min(1.0,0.55 + 0.29 * log(forest_LAI(nveg))) + endif + Qli_grid(col,row) = Qli_grid(col,row) * (1.0 - forest_frac) + & + (Stef_Boltz * Tair_grid(col,row)**4) * forest_frac + + !i [Wind] Further modify the wind speed to account for forest canopies. + ! Define the canopy wind-weighting factor. Assume z=0.6*canopy_ht, + ! and the canopy_ht equals the vegetation snow-holding depth. + beta = 0.9 + veg_ht = vegsnowd_xy(col,row) + a = beta * forest_LAI(nveg) + canopy_windwt = exp((- a)*(1.0 - (0.6*veg_ht)/veg_ht)) + windspd_grid(col,row) = canopy_windwt * windspd_grid(col,row) + + endif + endif + enddo + + ! Need to deterime max windspeed for entire domain: +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(windspd_flag, snowmodel_struc(n)%windspdflg_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + windspd_flag = snowmodel_struc(n)%windspdflg_glb +#endif + +#if 0 + ! Make the topographic calculations required by the wind and solar + ! radiation models. These calculations are not fixed in time + ! because as the snow depth evolves it modifies the "topography". + call topo_data(LIS_rc%lnc(n),LIS_rc%lnr(n),deltax,deltay,topo,& + curvature,terrain_slope,slope_az,curve_len_scale) + + ! Calculate the temperature and dew-point lapse rates to be used in + ! the interpolations. + call get_lapse_rates(imonth,iday,T_lapse_rate,& + Td_lapse_rate,xlat_grid(1,1),lapse_rate_user_flag,& + precip_lapse_rate,iprecip_lapse_rate_user_flag) +#endif + +#if 0 + ! WIND SPEED AND DIRECTION. + if (i_wind_flag.eq.1) then + call micromet_wind( LIS_rc%lnc(n),LIS_rc%lnr(n),deltax,deltay, & + uwind_grid,vwind_grid,slopewt,curvewt,& + curvature,slope_az,terrain_slope,windspd_grid,& + winddir_grid,windspd_flag,winddir_flag,windspd_min,& + vegtype,forest_LAI,calc_subcanopy_met,vegsnowd_xy,& + topo,wind_lapse_rate,curve_len_scale) + else + ! Need to deterime max windspeed for entire domain: +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) + call MPI_ALLREDUCE(windspd_flag, snowmodel_struc(n)%windspdflg_glb, 1,& + MPI_REAL, MPI_MAX,& + LIS_mpi_comm, ierr) + windspd_flag = snowmodel_struc(n)%windspdflg_glb +#endif + endif +#endif + +#if 0 + ! SOLAR RADIATION. + if (i_solar_flag.eq.1) then + call solar( LIS_rc%lnc(n),LIS_rc%lnr(n),& + xhour,J_day,topo,rh_grid,Tair_grid,& + xlat_grid,Qsi_grid,slope_az,terrain_slope,dt,vegtype,& + forest_LAI,T_lapse_rate,Td_lapse_rate,& + calc_subcanopy_met,gap_frac,cloud_frac_factor,UTC_flag,& + xlon_grid,cloud_frac_grid) + endif +#endif + +! ------------------------------------------------------------------- + +! *** Read in SnowModel preprocessed forcing, which can be directly +! fed into SnowModel's MicroMet routines: + + elseif( snowmodel_struc(n)%sm_micromet_opt == "SnowModel" .and. & + run_micromet.eq.1.0 ) then + + ! SnowModel calls: Distribute the meteorological station data. + CALL MICROMET_CODE(LIS_rc%lnc(n),LIS_rc%lnr(n),xmn_part,ymn_part,deltax,deltay, & + iyear_init,imonth_init,iday_init,xhour_init,dt,undef,& + ifill,iobsint,dn,iter,curve_len_scale,slopewt,curvewt,& + topo,curvature,terrain_slope,slope_az,Tair_grid,& + rh_grid,uwind_grid,vwind_grid,Qsi_grid,prec_grid,& + i_tair_flag,i_rh_flag,i_wind_flag,i_solar_flag,& + i_prec_flag,isingle_stn_flag,igrads_metfile,& + windspd_grid,winddir_grid,windspd_flag,winddir_flag,& + sprec,windspd_min,Qli_grid,i_longwave_flag,vegtype,& + forest_LAI,iyear,imonth,iday,xhour,corr_factor,& + icorr_factor_index,lapse_rate_user_flag,& + iprecip_lapse_rate_user_flag,use_shortwave_obs,& + use_longwave_obs,use_sfc_pressure_obs,sfc_pressure,& + run_enbal,run_snowpack,calc_subcanopy_met,vegsnowd_xy,& + gap_frac,cloud_frac_factor,barnes_lg_domain,n_stns_used,& + k_stn,xlat_grid,xlon_grid,UTC_flag,icorr_factor_loop,& + snowmodel_line_flag,xg_line,yg_line,irun_data_assim,& + wind_lapse_rate,iprecip_scheme,cf_precip_flag,cf_precip,& + cloud_frac_grid,snowfall_frac,seaice_run,metforce_opt) + + else + write(LIS_logunit,*) "[ERR] Incorrect option set for " + write(LIS_logunit,*) "[ERR] SnowModel MicroMet input source: " + write(LIS_logunit,*) "[ERR] See documentation in configs/lis.config.adoc " + write(LIS_logunit,*) "[ERR] for option details. " + call LIS_endrun + endif + + ! Perform a surface energy balance over the domain. + if (run_enbal.eq.1.0) then + CALL ENBAL_CODE(LIS_rc%lnc(n),LIS_rc%lnr(n),Tair_grid,uwind_grid,sfc_pressure,& + vwind_grid,rh_grid,Tsfc,Qsi_grid,Qli_grid,Qle,Qh,Qe,& + Qc,Qm,e_balance,Qf,snow_d,ht_windobs,icond_flag,& + albedo,snow_z0,veg_z0,vegtype,undef,albedo_snow_forest,& + albedo_snow_clearing,albedo_glacier,snod_layer,T_old,& + gamma,KK) + endif + + ! Evolve the snowpack according to the defined melt and + ! precipitation inputs. + if (run_snowpack.eq.1.0) then + CALL SNOWPACK_CODE(LIS_rc%lnc(n),LIS_rc%lnr(n),Tair_grid,rh_grid,ro_nsnow,& + dt,swe_depth,Tsfc,snow_d,prec_grid,runoff,Qm,rain,& + sprec,iter,w_balance,sum_prec,sum_runoff,xro_snow,& + undef,ro_snow,ro_snow_grid,soft_snow_d,sum_sprec,& + snow_depth,windspd_grid,Qsi_grid,sum_Qcs,canopy_int,& + Qcs,vegtype,forest_LAI,albedo,glacier_melt,& + canopy_unload,sum_unload,sum_glacmelt,run_snowtran,& + swemelt,d_canopy_int,sum_d_canopy_int,snow_d_init,& + sfc_pressure,Qe,sfc_sublim_flag,sum_sfcsublim,& + sum_swemelt,corr_factor,icorr_factor_index,swesublim,& + swe_depth_old,canopy_int_old,KK,max_layers,melt_flag,& + ro_snowmax,tsls_threshold,dz_snow_min,tslsnowfall,& + change_layer,snod_layer,swed_layer,ro_layer,T_old,gamma,& + multilayer_snowpack,seaice_run,seaice_conc,ht_windobs,& + windspd_2m_grid,diam_layer,flux_layer) + endif + + ! Run the blowing-snow model. + if (run_snowtran.eq.1.0) then + CALL SNOWTRAN_CODE(bc_flag,bs_flag,C_z,& + conc_salt,deltax,deltay,dh_salt,dh_salt_u,dh_salt_v,& + dh_susp,dh_susp_u,dh_susp_v,dt,dz_susp,fall_vel,fetch,& + gravity,h_const,h_star,ht_rhobs,ht_windobs,index_ue,& + index_uw,index_vn,index_vs,iter,LIS_rc%lnc(n),LIS_rc%lnr(n),pi,Qsalt,Qsalt_max,& + Qsalt_maxu,Qsalt_maxv,Qsalt_u,Qsalt_v,Qsubl,Qsusp,& + Qsusp_u,Qsusp_v,rh_grid,ro_air,ro_snow,ro_water,snow_d,& + snow_d_init,snow_z0,soft_snow_d,sprec,sum_glacmelt,& + subgrid_flag,wbal_salt,wbal_susp,wbal_qsubl,sum_sprec,& + tabler_ee,tabler_ne,tabler_nn,tabler_nw,tabler_se,& + tabler_ss,tabler_sw,tabler_ww,tair_grid,topo,topo_land,& + topoflag,twolayer_flag,Up_const,Ur_const,Utau,& + Utau_t,uwind_grid,veg_z0,vegsnowd_xy,vegtype,vonKarman,& + vwind_grid,wind_min,winddir_flag,winddir_grid,& + windspd_flag,windspd_grid,xmu,z_0,ztop_susp,max_iter,& + run_enbal,run_snowpack,wbal_subgrid,sum_qsubl,sum_trans,& + swe_depth,snow_depth,ro_snow_grid,sum_prec,sum_runoff,& + sum_Qcs,canopy_int,w_balance,sum_sfcsublim,tabler_dir,& + slope_adjust,Utau_t_const,Utau_t_flag,ro_soft_snow_old,& + ro_soft_snow,ro_nsnow,prec_grid,Qcs,runoff,d_canopy_int,& + glacier_melt,swe_depth_old,swesublim,canopy_unload,& + canopy_int_old,iter_start,multilayer_snowpack,swed_layer,& + KK,snod_layer,ro_layer,curve_lg_scale_flag,curve_wt_lg,& + seaice_run,seaice_conc,tslsnowfall,T_old,tsls_threshold,& + curve_len_scale,Tabler_1_flag,Tabler_2_flag,undef,& + tabler_sfc_path_name,output_path_wo_assim,& + output_path_wi_assim,icorr_factor_loop,windspd_2m_grid,& + Qsubl_depth) + endif + + +#if 0 + ! Save the outputs from the SNOWPACK and SNOWTRAN routines + if (print_user.eq.1.0) then + CALL OUTPUTS_USER(LIS_rc%lnc(n),LIS_rc%lnr(n),iter,Tair_grid,rh_grid,& + uwind_grid,vwind_grid,windspd_grid,winddir_grid,& + Qsi_grid,Qli_grid,prec_grid,Tsfc,Qle,Qh,Qe,Qc,Qm,Qf,& + e_balance,snow_depth,xro_snow,swe_depth,ro_nsnow,& + runoff,rain,sprec,sum_prec,sum_runoff,w_balance,& + snow_d,topo_land,wbal_qsubl,sum_sprec,wbal_salt,& + wbal_susp,ro_snow_grid,sum_Qcs,canopy_int,Qcs,& + iyear,imonth,iday,xhour,undef,deltax,xmn,ymn,& + wbal_subgrid,canopy_unload,sum_qsubl,sum_trans,& + sum_unload,sum_glacmelt,glacier_melt,swemelt,& + sfc_pressure,sum_swemelt,albedo,nrecs_max,& + icorr_factor_loop,swesublim,vegtype,iter_start,& + seaice_run,print_inc,cloud_frac_grid,& + output_path_wo_assim,output_path_wi_assim,print_var,& + print_outvars,Qsubl_depth) + endif +#endif + +!- Write out final 1D variables to LIS output files: + do t = 1,LIS_rc%npatch(n,LIS_rc%lsm_index) + + ! Need to convert the SnowModel nx,ny grids to + ! local LIS npatch array ... + col = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col + row = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row + + !-- Meteorological forcing fields -- + + ! Air temperature (units: K; Tair_grid) + ! Snowmodel units: degrees C (tair); + snowmodel_struc(n)%sm(t)%tair = & + tair_grid(col,row) + + ! Downward radiation components: + snowmodel_struc(n)%sm(t)%swdown = & + Qsi_grid(col,row) + + snowmodel_struc(n)%sm(t)%lwdown = & + Qli_grid(col,row) + + ! U-/V-wind components (units: m/s): + snowmodel_struc(n)%sm(t)%uwind = & + uwind_grid(col,row) + snowmodel_struc(n)%sm(t)%vwind = & + vwind_grid(col,row) + + ! Write out SnowModel metforcing file fields ("native" text file fields): + if( snowmodel_struc(n)%write_sm_metfields == 1 ) then + + call LIS_diagnoseSurfaceOutputVar(n, t,LIS_MOC_TAIRFORC, & + value=snowmodel_struc(n)%sm(t)%tair,& + unit="K",vlevel=1,direction="-",& + surface_type=LIS_rc%lsm_index) + + call LIS_diagnoseSurfaceOutputVar(n,t,LIS_MOC_SWDOWNFORC_SM,& + value=snowmodel_struc(n)%sm(t)%swdown,& + unit="W m-2",vlevel=1,direction="DN",& + surface_type=LIS_rc%lsm_index) + + call LIS_diagnoseSurfaceOutputVar(n,t,LIS_MOC_LWDOWNFORC_SM,& + value=snowmodel_struc(n)%sm(t)%lwdown,& + unit="W m-2",vlevel=1,direction="DN",& + surface_type=LIS_rc%lsm_index) + + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_EWINDFORC_SM, & + value=snowmodel_struc(n)%sm(t)%uwind, & + unit="m s-1", vlevel=1, direction="E", & + surface_type=LIS_rc%lsm_index) + + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_NWINDFORC_SM, & + value=snowmodel_struc(n)%sm(t)%vwind, & + unit="m s-1", vlevel=1, direction="N", & + surface_type=LIS_rc%lsm_index) + + endif + + ! ----------------------------------------- + + ! SWE depth (units: m, SnowModel) + snowmodel_struc(n)%sm(t)%swe_depth = & + swe_depth(col,row) + + call LIS_diagnoseSurfaceOutputVar(n,t,LIS_MOC_SWE_SM, & + value=snowmodel_struc(n)%sm(t)%swe_depth, & + unit="m", vlevel=1, direction="-", & + surface_type=LIS_rc%lsm_index) + +! IF user wants to write out SWE in kg m-2 units (need conversion) +! call LIS_diagnoseSurfaceOutputVar(n,t,LIS_MOC_SWE, & +! value=snowmodel_struc(n)%sm(t)%swe_depth, & +! unit="kg m-2", vlevel=1, direction="-", & +! surface_type=LIS_rc%lsm_index) + + ! Snow depth (units: m) + snowmodel_struc(n)%sm(t)%snow_depth = & + snow_depth(col,row) + call LIS_diagnoseSurfaceOutputVar(n,t,LIS_MOC_SNOWDEPTH_SM, & + value=snowmodel_struc(n)%sm(t)%snow_depth, & + unit="m", vlevel=1, direction="-", & + surface_type = LIS_rc%lsm_index) + + ! Snow density (units: kg m-3): + snowmodel_struc(n)%sm(t)%sden = & + xro_snow(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWDENSITY_SM, & + value = snowmodel_struc(n)%sm(t)%sden, & + unit="kg m-3", vlevel=1, direction="-", & + surface_type = LIS_rc%lsm_index) + + ! SWE melt (units: m, for Snowmodel; units: kg m-2 s-1, for other models). + ! Snow melt (QSM): + snowmodel_struc(n)%sm(t)%swemelt = & + swemelt(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_QSM_SM, & + value = snowmodel_struc(n)%sm(t)%swemelt, & + unit="m", vlevel=1, direction="S2L", & +! unit="kg m-2 s-1", vlevel=1, direction="S2L", & +! Note: "S2L" is "Solid to Liquid" +! (https://www.lmd.jussieu.fr/~polcher/ALMA/convention_output_3.html) + surface_type = LIS_rc%lsm_index) + + ! Snow sublimation (units: m, for Snowmodel; kg m-2 s-1, for other models): + snowmodel_struc(n)%sm(t)%sublim = & + swesublim(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SUBSNOW_SM, & + value = snowmodel_struc(n)%sm(t)%sublim, & + unit="m", vlevel = 1, direction="-", & +! unit="kg m-2 s-1", vlevel = 1, direction="-", & + surface_type = LIS_rc%lsm_index ) + + ! Runoff from base of snowpack + ! (units: m/dt for Snowmodel; otherwise, units: kg m-2 s-1): + snowmodel_struc(n)%sm(t)%runoff = & + runoff(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_QS_SM, & + value = snowmodel_struc(n)%sm(t)%runoff, & + unit="m", vlevel=1, direction="OUT", & +! unit="kg m-2 s-1", vlevel=1, direction="OUT", & + surface_type = LIS_rc%lsm_index) + + ! Total (water-equivalent) precipitation (units: m/time_step, for SnowModel) + snowmodel_struc(n)%sm(t)%totprecip = & + prec_grid(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_TOTALPRECIP_SM, & + value=snowmodel_struc(n)%sm(t)%totprecip, & + unit="m", vlevel=1, direction="DN", & +! unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%totprecip = & + prec_grid(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_TOTALPRECIP_SM, & + value=snowmodel_struc(n)%sm(t)%totprecip*1000., & + unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%totprecip = & + prec_grid(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_TOTALPRECIP_SM, & + value=snowmodel_struc(n)%sm(t)%totprecip*1000./dt, & + unit="kg m-2 s-1", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + + ! Liquid precipitation portion (units: m/time_step, for SnowModel) + snowmodel_struc(n)%sm(t)%rainf = & + rain(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_RAINF_SM, & + value=snowmodel_struc(n)%sm(t)%rainf, & + unit="m", vlevel=1, direction="DN", & +! unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%rainf = & + rain(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_RAINF_SM, & + value=snowmodel_struc(n)%sm(t)%rainf*1000., & + unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%rainf = & + rain(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_RAINF_SM, & + value=snowmodel_struc(n)%sm(t)%rainf*1000./dt, & + unit="kg m-2 s-1", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + + ! Solid precipitation portion (units: m/time_step, for SnowModel) + snowmodel_struc(n)%sm(t)%snowf = & + sprec(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWF_SM, & + value=snowmodel_struc(n)%sm(t)%snowf, & + unit="m", vlevel=1, direction="DN", & +! unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%snowf = & + sprec(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWF_SM, & + value=snowmodel_struc(n)%sm(t)%snowf*1000., & + unit="kg m-2", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + snowmodel_struc(n)%sm(t)%snowf = & + sprec(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWF_SM, & + value=snowmodel_struc(n)%sm(t)%snowf*1000./dt, & + unit="kg m-2 s-1", vlevel=1, direction="DN", & + surface_type=LIS_rc%lsm_index) + + + ! Albedo (units: -) + snowmodel_struc(n)%sm(t)%albedo = & + albedo(col,row) + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_ALBEDO_SM, & + value=snowmodel_struc(n)%sm(t)%albedo, & + unit="-", vlevel=1, direction="-", & + surface_type=LIS_rc%lsm_index) + + ! Parameter fields: + ! Topographic - elevation (m): + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_ELEVATION_SM, & +! value=snowmodel_struc(n)%sm(t)%smtopo, & + value=topo(col,row), & +! value=topo_land(col,row), & +! value=curvature(col,row), & +! value=slope_az(col,row), & +! value=terrain_slope(col,row), & + unit="m", vlevel=1, direction="-", & + surface_type=LIS_rc%lsm_index) + + ! Vegetation type: + call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_LANDCOVER_SM, & +! value=snowmodel_struc(n)%sm(t)%smvege, & + value=vegtype(col,row), & + unit="-", vlevel=1, direction="-", & + surface_type=LIS_rc%lsm_index) + +! .............................................................. +! +! Writing state values for writing out to restart files: + + snowmodel_struc(n)%sm(t)%snow_d = & + snow_d(col,row) + snowmodel_struc(n)%sm(t)%canopy_int = & + canopy_int(col,row) + snowmodel_struc(n)%sm(t)%soft_snow_d = & + soft_snow_d(col,row) + snowmodel_struc(n)%sm(t)%ro_snow_grid = & + ro_snow_grid(col,row) + snowmodel_struc(n)%sm(t)%ro_soft_snow_old = & + ro_soft_snow_old(col,row) + snowmodel_struc(n)%sm(t)%snow_d_init = & + snow_d_init(col,row) + snowmodel_struc(n)%sm(t)%swe_depth_old = & + swe_depth_old(col,row) + snowmodel_struc(n)%sm(t)%canopy_int_old = & + canopy_int_old(col,row) + snowmodel_struc(n)%sm(t)%topo = & + topo(col,row) + snowmodel_struc(n)%sm(t)%sum_sprec = & + sum_sprec(col,row) + +! +! FIELDS THAT LIS CAN SUPPORT AND MAYBE AVAILABLE BY SNOWMODEL +! BUT ARE NOT WRITTEN OUT ... + ! Latent hear flux +! snowmodel_struc(n)%sm%qe = 40.0 +! call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_QLE, & +! value=snowmodel_struc(n)%sm(t)%qe, & +! vlevel=1,unit="W m-2",direction="UP",surface_type=LIS_rc%lsm_index) + + ! Snowliq (unit=mm ). *** snow-layer liquid water +! do i=1, snowmodel_struc(n)%nsnow +! call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWLIQ, & +! value = NOAHMP36_struc(n)%noahmp36(t)%snowliq(i), & +! unit="mm", vlevel=i, direction="-", & +! surface_type = LIS_rc%lsm_index ) +! enddo + + ! Snowliq (unit=mm ). *** snow-layer ice +! do i=1, snowmodel_struc(n)%nsnow +! call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWICE, & +! value = NOAHMP36_struc(n)%noahmp36(t)%snowce(i), & +! unit="mm", vlevel=i, direction="-", & +! surface_type = LIS_rc%lsm_index ) +! enddo + + ! Snow_temp (unit=K). *** snow layer temperature +! do i=1, NOAHMP36_struc(n)%nsnow +! Test code to reset snow temperature to undefined +! when there is no corresponding snow layer - Mocko +! if ((i + abs(NOAHMP36_struc(n)%noahmp36(t)%isnow)) & +! .le.NOAHMP36_struc(n)%nsnow) then +! snow_temp(i) = LIS_rc%udef +! endif +! call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_SNOWTPROF, & +! value = snow_temp(i), & +! unit="K", vlevel=i, direction="-", & +! surface_type = LIS_rc%lsm_index) +! end do + + ! Snow density for each layer +! ! ro_layer or sdenz .. +! do i=1, NOAHMP36_struc(n)%nsnow +! call LIS_diagnoseSurfaceOutputVar(n, t, LIS_MOC_LAYERSNOWDENSITY, +! value = bdsno,& +! vlevel=i, unit="kg m-3", direction="-", & +! surface_type = LIS_rc%lsm_index) +! enddo +! +! ......................................................................... + + ! Reset forcing variables to 0 and counter: + snowmodel_struc(n)%forc_count = 0 + snowmodel_struc(n)%sm(t)%tair = 0 + snowmodel_struc(n)%sm(t)%qair = 0 + snowmodel_struc(n)%sm(t)%swdown = 0 + snowmodel_struc(n)%sm(t)%lwdown = 0 + snowmodel_struc(n)%sm(t)%uwind = 0 + snowmodel_struc(n)%sm(t)%vwind = 0 + snowmodel_struc(n)%sm(t)%psurf = 0 + snowmodel_struc(n)%sm(t)%rainf = 0 + snowmodel_struc(n)%sm(t)%snowf = 0 + + enddo ! End 1-d tile space loop + + ! For multi-year simulations, sometimes it is desirable to zero + ! out the snow cover arrays on a certain summer date, to prevent + ! glaciers from forming. + + if (imonth.eq.iclear_mn .and. iday.eq.iclear_dy .and.& + xhour.eq.xclear_hr) then + + if (seaice_run.eq.4.0) then + CALL ZERO_SNOW_SEAICE_4(LIS_rc%lnc(n),LIS_rc%lnr(n),snow_depth,ro_snow_grid,& + ro_snow,swe_depth,swe_depth_old,canopy_int_old,KK,& + sum_swemelt,tslsnowfall,snod_layer,swed_layer,& + ro_layer,T_old,sum_sprec,multilayer_snowpack,& + tsls_threshold,iyear,diam_layer,output_path_wo_assim) + else + CALL ZERO_SNOW(LIS_rc%lnc(n),LIS_rc%lnr(n),snow_depth,ro_snow_grid,ro_snow,& + swe_depth,swe_depth_old,canopy_int_old,KK,sum_swemelt,& + tslsnowfall,snod_layer,swed_layer,ro_layer,T_old,& + sum_sprec,multilayer_snowpack,tsls_threshold,& + sum_trans) + endif + + endif + + if( iter == max_iter ) then + write(LIS_logunit,*) "[INFO] Reached max iteration count: ",iter + endif + +end subroutine snowmodel_main diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 new file mode 100644 index 000000000..8c0e74032 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 @@ -0,0 +1,145 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +module snowmodel_module +!BOP +! +! !MODULE: snowmodel_module +! +! !DESCRIPTION: +! The code in this file provides a description of the +! data structure containing the SnowModel 1-d variables. +! The variables specified in the data structure include: +! +! \begin{description} +! \item[slopetype] +! slope type (integer index) +! \item[nroot] +! Number of root layers, depends on the vegetation type +! \end{description} +! +! !REVISION HISTORY: +! 14 Apr 2020: K. Arsenault; Added G. Liston's SnowModel +! 08 Aug 2022: K. Arsenault; Updated for implementing restart files +! +!EOP + implicit none + + PRIVATE + type, public :: snowmodeldec + + integer :: nroot + integer :: vegt + + real, allocatable :: lyrthk(:) !used only if distributed depths are defined + +!------------------------------------------------------------------------- +! SnowModel State Variables (HRESTART_READ; HRESTART_SAVE) +!------------------------------------------------------------------------- + ! States that can be 0'd out at the start of the next water year + real :: swe_depth ! swed: Snow water equivalent depth (m) + real :: snow_depth ! snod: snow depth (m) + real :: ro_snow_grid ! Snow grid density (kg/m3); initialized as ro_snow + real :: canopy_int ! Canopy interception store (m) + real :: canopy_int_old ! Former canopy interception store (m) + real :: swe_depth_old ! Former SWE depth (m) step + + ! Additional Restart file state list: + real :: soft_snow_d ! Soft snow layer depth (m) + real :: ro_soft_snow_old ! Density of former soft snow layer (kg/m3) + real :: snow_d_init ! Initial snow depth (m), density-layer and subgrid scale snow + real :: topo ! Snow-depth changing grid topography level (m) + real :: sum_sprec ! Summed snowfall (m) + + ! Multilayer states + real :: tslsnowfall ! Initialized with tsls_threshold + real :: snod_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + real :: swed_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + real :: ro_layer ! (i,j,k) = ro_snow, initialized + real :: T_old_layer ! (i,j,k) = 273.15, initialized + real :: KK ! (i,j) = 0; this is the total number of layers set to + +!------------------------------------------------------------------------- +! SnowModel Forcing Variables +!------------------------------------------------------------------------- + real :: tair ! tair_grid: Air temperature (K) + real :: rh ! rh_grid: Relative humidity (%) + real :: windspd ! windspd_grid, wspd: Wind speed (m/2) + real :: winddir ! winddir_grid, wdir: Wind direction (deg, true N) + real :: uwind ! uwind_grid + real :: vwind ! vwind_grid + real :: totprecip ! prec_grid: Water-equivalent precip (m/dt) + real :: rainf ! rpre or rain: Liquid precip, rain (m/dt) + real :: snowf ! spre or sprec: Solid precip, snowfall (m/dt) + real :: swdown ! Qsi_grid, qsin: incoming solar radiation (W/m2) + real :: lwdown ! Qli_grid, qlin: incoming lw radiation (W/m2) + real :: cloud_fraction ! cldf: cloud fraction (grid) (0-1) + real :: qair ! Specific humidity + real :: psurf + real :: fheight + +!------------------------------------------------------------------------- +! SnowModel Parameters +!------------------------------------------------------------------------- + real :: smtopo ! SnowModel topography field + real :: smvege ! SnowModel vegetation class map + +!----------------------------------------------------------------------- +! SnowModel Output variables +!----------------------------------------------------------------------- + ! EBal: + real :: tsfc ! tsfc: Surface (skin) temperature (deg C) + real :: qle ! qlem: Emitted longwave radiation (W/m2) + real :: qh ! Sensible heat flux (W/m2) + real :: qe ! Latent heat flux (W/m2) + real :: qc ! Conductive heat flux (W/m2) + real :: qm ! Melt energy flux (W/m2) + real :: albedo ! Albedo (0-1), albd + real :: e_balance ! Energy balance error (W/m2) + + real :: swnet ! Net shortwave (W/m2) + real :: lwnet ! Net longwave (W/m2) + + ! Snowpack: + real :: sden ! sden, xro_snow: snow density (kg/m3) + real :: runoff ! runoff, roff: runoff from snowpack base (m/dt) + real :: glmt ! glacier_melt, glmt: SWE melt from glacier ice (m) + real :: qcs ! qcs: Canopy sublimation (m/dt) + real :: snowcover + + real :: sublim ! swesublim, ssub: static-surface sublimation (m) + real :: swemelt ! swemelt, smlt: SWE melt (m) + + real :: sumsublim ! Summed static-surface sublimation (m) + real :: sumqcs ! Summed canopy sublim during year (m) + real :: sumprec ! Summed precipitation during year (m) + real :: sumsprec ! sspr, Summed snow precip during year (m) + real :: sumroff ! Summed runoff during the year (m) + real :: sumswemelt ! ssmt, Summed snow-water-equivalent melt (m) + real :: sumunload ! Sum_unload: Summed canopy unloading during the year (m) + real :: w_balance ! wbal: Summed water balance error durign year (m) + +! SnowTran: + real :: snow_d ! Snow depth (m), density-adjusted and used in subgrid-scale snow (HRESTART_READ) + real :: wbal_qsubl + real :: wbal_salt + real :: wbal_susp + real :: wbal_subgrid + real :: sum_qsubl + real :: sum_trans + +! Multi-layer snow fields: + real :: diam_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + real :: flux_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + real :: Told_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + real :: gamma_layer ! (i,j,k),i=1,nx),j=1,ny),k=1,nz_max) + + end type snowmodeldec + +end module snowmodel_module diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 new file mode 100644 index 000000000..4d7bcd934 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 @@ -0,0 +1,150 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: snowmodel_readconfig +! \label{snowmodel_readconfig} +! +! !REVISION HISTORY: +! 14 Apr 2020; Kristi Arsenault, Initial Code +! +! !INTERFACE: +subroutine snowmodel_readconfig() +! !USES: + use ESMF + + use LIS_coreMod, only : LIS_rc, LIS_config + use LIS_logMod, only : LIS_logunit, LIS_verify, LIS_endrun + use LIS_timeMgrMod, only : LIS_parseTimeString + use snowmodel_lsmMod, only : snowmodel_struc + +! +! !DESCRIPTION: +! +! This routine reads the options specific to SnowModel +! from the LIS configuration file. +! +!EOP + implicit none + + integer :: rc + integer :: n,i + character*10 :: time + +! LIS-related SnowModel input entries: + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel model timestep:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,time,rc=rc) + call LIS_verify(rc,'SnowModel model timestep: not defined') + + call LIS_parseTimeString(time,snowmodel_struc(n)%ts) + enddo + + if (LIS_rc%startcode== "restart" ) then + call ESMF_ConfigFindLabel(LIS_config,"SnowModel restart file:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%rfile,rc=rc) + call LIS_verify(rc,'SnowModel restart file: not defined') + enddo + endif + call ESMF_ConfigFindLabel(LIS_config,"SnowModel restart output interval:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,time,rc=rc) + call LIS_verify(rc,'SnowModel restart output interval: not defined') + + call LIS_parseTimeString(time, snowmodel_struc(n)%rstInterval) + enddo + + ! set default restart format to netcdf + do n=1,LIS_rc%nnest + snowmodel_struc(n)%rformat = "netcdf" + enddo + ! restart run, read restart file + if( trim(LIS_rc%startcode) == "restart" ) then + Call ESMF_ConfigFindLabel(LIS_config, "SnowModel restart file:", rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, snowmodel_struc(n)%rfile, rc=rc) + call LIS_verify(rc, "SnowModel restart file: not defined") + enddo + + Call ESMF_ConfigFindLabel(LIS_config, "SnowModel restart file format:", rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, snowmodel_struc(n)%rformat, rc=rc) + call LIS_verify(rc, "SnowModel restart file format: not defined") + enddo + + ! cold start run, read initial state variables +! else + endif + + ! SnowModel-specific parameters: + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel parameter file:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%parfile,rc=rc) + call LIS_verify(rc,'SnowModel parameter file: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"Write out SnowModel forcing file fields:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%write_sm_metfields,rc=rc) + call LIS_verify(rc,'Write out SnowModel forcing file fields: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel parameters source option:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%sm_params_opt,rc=rc) + call LIS_verify(rc,'SnowModel parameters source option: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel preprocess code option:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%call_sm_preproc,rc=rc) + call LIS_verify(rc,'SnowModel preprocess code option: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel MicroMet input source:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%sm_micromet_opt,rc=rc) + call LIS_verify(rc,'SnowModel MicroMet input source: not defined') + enddo + + + call ESMF_ConfigFindLabel(LIS_config,"SnowModel number of snow layers:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%nsnow,rc=rc) + call LIS_verify(rc,'SnowModel number of snow layers: not defined') + ! May move this allocate statement later .... + allocate(snowmodel_struc(n)%lyrthk(snowmodel_struc(n)%nsnow)) + enddo + + ! Initial values: + call ESMF_ConfigFindLabel(LIS_config,"SnowModel initial snow water equivalent:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%initsnowequiv,rc=rc) + call LIS_verify(rc,'SnowModel initial snow water equivalent: not defined') + enddo + +! Future expansion to include SnowModel snow layers ... +! Below is an example from soil layer thicknesses ... +! call ESMF_ConfigFindLabel(LIS_config,"SnowModel layer thicknesses: ",rc=rc) +! do n=1,LIS_rc%nnest +! allocate(snowmodel_struc(n)%lyrthk(snowmodel_struc(n)%nsnow)) +! do i = 1,snowmodel_struc(n)%nsnow +! call ESMF_ConfigGetAttribute(LIS_config,snowmodel_struc(n)%lyrthk(i),rc=rc) +! enddo +! call LIS_verify(rc,'SnowModel layer thicknesses: not defined') +! enddo + + + write(LIS_logunit,*) '[INFO] Running SnowModel (Liston):' + +end subroutine snowmodel_readconfig diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 new file mode 100644 index 000000000..03126dd51 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 @@ -0,0 +1,240 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: snowmodel_readrst +! \label{snowmodel_readrst} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! 05 Aug 2022: Kristi Arsenault; Updated SnowModel state restart reader +! +! !INTERFACE: +subroutine snowmodel_readrst() +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_masterproc, LIS_surface + use LIS_historyMod, only : LIS_readvar_restart + use LIS_logMod, only : LIS_logunit, LIS_endrun, & + LIS_getNextUnitNumber, & + LIS_releaseUnitNumber, & + LIS_verify + use snowmodel_lsmMod + use snowmodel_inc + use snowmodel_vars +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif +! +! !DESCRIPTION: +! This program reads restart files for SnowModel. This +! includes all relevant water/energy storages and tile information. +! The following is the list of variables specified in the SnowModel +! restart file: +! +! \begin{verbatim} +! nc, nr, ntiles - grid and tile space dimensions +! snow_d - Snow depth (m), density-adjusted and used in subgrid-scale snow +! snow_depth - Snow depth (m) +! canopy_int - Canopy interception store (m) +! soft_snow_d - Soft snow layer depth (m) +! ro_snow_grid - Snow grid density (kg/m3) +! swe_depth - Snow water equivalent depth (m) +! ro_soft_snow_old - Density of former soft snow layer (kg/m3) +! snow_d_init - Initial snow depth (m) +! swe_depth_old - Former SWE depth (m) step +! canopy_int_old - Former canopy interception store (m) +! topo - Snow-depth changing grid topography level (m) +! sum_sprec - Summed snowfall (m) +! \end{verbatim} +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_readvar\_restart](\ref{LIS_readvar_restart}) \newline +! reads a variable from the restart file +! \item[snowmodel\_coldstart](\ref{snowmodel_coldstart}) \newline +! initializes the SnowModel state variables +! \end{description} +!EOP + + implicit none + + integer :: t, l, col, row + integer :: nc, nr, npatch + integer :: n + integer :: ftn + integer :: status + logical :: file_exists + character*20 :: wformat +! ___________________________________ + + write(LIS_logunit,*) '[INFO] Call to the SnowModel Read restart routine ...' + + do n=1, LIS_rc%nnest + wformat = trim(snowmodel_struc(n)%rformat) + + ! Coldstart + if(LIS_rc%startcode .eq. "coldstart") then + call SnowModel_coldstart(LIS_rc%lsm_index) + ! Restart + elseif(LIS_rc%startcode .eq. "restart") then + + ! Check if MicroMet option is set to "SnwoModel"; + ! If so, alert user that this option currently + ! is not supported with reading in LIS restart files: + if( snowmodel_struc(n)%sm_micromet_opt == "SnowModel" ) then + write(LIS_logunit,*) "[ERR] SnowModel restart file read is not currently" + write(LIS_logunit,*) " supported with 'SnowModel' forcing-format option." + call LIS_endrun + endif + + ! check the existance of restart file + inquire(file=snowmodel_struc(n)%rfile, exist=file_exists) + if(.not. file_exists) then + write(LIS_logunit,*) "[ERR] SnowModel restart file ", & + snowmodel_struc(n)%rfile," does not exist " + write(LIS_logunit,*) " Program stopping ..." + call LIS_endrun + endif + write(LIS_logunit,*) "[INFO] SnowModel restart file used: ",& + trim(snowmodel_struc(n)%rfile) + + ! open restart file + if(wformat .eq. "binary") then + ftn = LIS_getNextUnitNumber() + open(ftn, file=snowmodel_struc(n)%rfile, form="unformatted") + read(ftn) nc, nr, npatch ! time, veg class, no. tiles + + ! check for grid space conflict + if((nc .ne. LIS_rc%gnc(n)) .or. (nr .ne. LIS_rc%gnr(n))) then + write(LIS_logunit,*) "[ERR] "//trim(snowmodel_struc(n)%rfile), & + ":: grid space mismatch - SnowModel run halted" + call LIS_endrun + endif + + if(npatch .ne. LIS_rc%glbnpatch_red(n, LIS_rc%lsm_index)) then + write(LIS_logunit,*) "[ERR] SnowModel restart tile space mismatch" + call LIS_endrun + endif + + elseif(wformat .eq. "netcdf") then +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + status = nf90_open(path=snowmodel_struc(n)%rfile, & + mode=NF90_NOWRITE, ncid=ftn) + call LIS_verify(status, "Error opening file "//snowmodel_struc(n)%rfile) +#endif + endif + + ! read(1): Snow depth (m), density-adjusted and used in subgrid-scale snow + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_d, & + varname="SNOWD", & + wformat=wformat) + + ! read(2): Snow depth (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_depth, & + varname="SNOWDEPTH", & + wformat=wformat) + + ! read(3): Canopy interception store (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%canopy_int, & + varname="CANOPYINT", & + wformat=wformat) + + ! read(4): Soft snow layer depth (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%soft_snow_d, & + varname="SOFTSNOWD", & + wformat=wformat) + + ! read(5): Snow grid density (kg/m3) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%ro_snow_grid, & + varname="ROSNOWGRID", & + wformat=wformat) + + ! read(6): SWE depth (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%swe_depth, & + varname="SWEDEPTH", & + wformat=wformat) + + ! read(7): Density of former soft snow layer (kg/m3) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%ro_soft_snow_old, & + varname="ROSOFTSNOWOLD", & + wformat=wformat) + + ! read(8): Initial snow depth, density-layer and subgrid scale snow (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_d_init, & + varname="SNOWDINIT", & + wformat=wformat) + + ! read(9): Former SWE depth, step (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%swe_depth_old, & + varname="SWEDEPTHOLD", & + wformat=wformat) + + ! read(10): Former canopy interception store (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%canopy_int_old, & + varname="CANOPYINTOLD", & + wformat=wformat) + + ! read(11): Snow-depth changing grid topography level (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%topo, & + varname="TOPO", & + wformat=wformat) + + ! read(12): Sum of snowfall, over time (m) + call LIS_readvar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%sum_sprec, & + varname="SUMSPREC", & + wformat=wformat) + + ! Close the restart file + if(wformat .eq. "binary") then + call LIS_releaseUnitNumber(ftn) + elseif(wformat .eq. "netcdf") then +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + status = nf90_close(ftn) + call LIS_verify(status, "Error in nf90_close in SnowModel_readrst") +#endif + endif + + ! Assign the read-in states to the SnowModel local states: + do t = 1,LIS_rc%npatch(n,LIS_rc%lsm_index) + col = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col + row = LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row + + snow_d(col,row) = snowmodel_struc(n)%sm(t)%snow_d + snow_depth(col,row) = snowmodel_struc(n)%sm(t)%snow_depth + canopy_int(col,row) = snowmodel_struc(n)%sm(t)%canopy_int + soft_snow_d(col,row) = snowmodel_struc(n)%sm(t)%soft_snow_d + ro_snow_grid(col,row) = snowmodel_struc(n)%sm(t)%ro_snow_grid + swe_depth(col,row) = snowmodel_struc(n)%sm(t)%swe_depth + ro_soft_snow_old(col,row) = snowmodel_struc(n)%sm(t)%ro_soft_snow_old + snow_d_init(col,row) = snowmodel_struc(n)%sm(t)%snow_d_init + swe_depth_old(col,row) = snowmodel_struc(n)%sm(t)%swe_depth_old + canopy_int_old(col,row)= snowmodel_struc(n)%sm(t)%canopy_int_old + topo(col,row) = snowmodel_struc(n)%sm(t)%topo + sum_sprec(col,row) = snowmodel_struc(n)%sm(t)%sum_sprec + enddo + + endif + enddo + +end subroutine snowmodel_readrst + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 new file mode 100644 index 000000000..ca87ae59e --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 @@ -0,0 +1,65 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: snowmodel_reset +! \label{snowmodel_reset} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_reset() +! !USES: + use LIS_coreMod, only : LIS_rc + use snowmodel_lsmMod + use LIS_surfaceModelDataMod, only : LIS_sfmodel_struc + use LIS_timeMgrMod, only : LIS_clock, LIS_calendar, & + LIS_update_timestep + use LIS_logMod, only : LIS_verify, LIS_logunit + use snowmodel_lsmMod +! +! !DESCRIPTION: +! +! This routine is the reset point for parameters and variables +! required for SnowModel. +! +! The routines invoked are: +! \begin{description} +! \item[snowmodel\_resetvegparms](\ref{snowmodel_resetvegparms}) \newline +! initializes the vegetation-related parameters in SnowModel +! \end{description} +!EOP + implicit none + integer :: i,n + + + do n=1,LIS_rc%nnest + write(LIS_logunit,*) & + '[INFO] SnowModel resetting' + write(LIS_logunit,*) "[INFO] Reset on:", LIS_rc%mo, LIS_rc%da, & + LIS_rc%hr, snowmodel_struc(n)%forc_count + + snowmodel_struc(n)%forc_count = 0 + do i=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + snowmodel_struc(n)%sm(i)%tair = 0 + snowmodel_struc(n)%sm(i)%qair = 0 + snowmodel_struc(n)%sm(i)%swdown = 0 + snowmodel_struc(n)%sm(i)%lwdown = 0 + snowmodel_struc(n)%sm(i)%uwind = 0 + snowmodel_struc(n)%sm(i)%vwind = 0 + snowmodel_struc(n)%sm(i)%psurf = 0 + snowmodel_struc(n)%sm(i)%rainf = 0 +! snowmodel_struc(n)%sm(i)%snowf = 0 + enddo + + enddo + +end subroutine snowmodel_reset diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 new file mode 100644 index 000000000..cc70febd6 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 @@ -0,0 +1,224 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: snowmodel_setup +! \label{snowmodel_setup} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! +! !INTERFACE: +subroutine snowmodel_setup() +! !USES: + use LIS_logMod, only : LIS_verify, LIS_logunit, LIS_endrun + use LIS_coreMod, only : LIS_rc, LIS_surface,& + LIS_localPet, LIS_ews_ind, LIS_ewe_ind,& + LIS_nss_ind, LIS_nse_ind, LIS_ews_halo_ind, LIS_ewe_halo_ind,& + LIS_nss_halo_ind, LIS_nse_halo_ind + use LIS_fileIOMod, only : LIS_read_param + use snowmodel_lsmMod + use snowmodel_module + use snowmodel_inc + use snowmodel_vars +! +! !DESCRIPTION: +! +! This routine is the entry point to set up the parameters +! required for Liston's SnowModel. These include vegetation +! topography, and initialization of state variables in SnowModel. +! +! The routines invoked are: +! \begin{description} +! \item[snowmodel\_setvegparms](\ref{snowmodel_setvegparms}) \newline +! initializes the vegetation-related parameters in SnowModel +! \end{description} +!EOP + + implicit none + integer :: n + integer :: mtype + integer :: t + integer :: col, row + integer :: ews, ewe, nss, nse + double precision :: xmn_part ! center x of local LL starting point + double precision :: ymn_part ! center y of local LL starting point + integer, allocatable :: global_kstn(:,:,:) + real, allocatable :: placeholder(:,:) + +! _______________________________________________________________ + + mtype = LIS_rc%lsm_index + + write(LIS_logunit,*)"[INFO] Reading in SnowModel vegetation and topography (snowmodel_setup)" + + ! Read in spatial SnowModel maps from LDT: + do n=1, LIS_rc%nnest + + ! Allocate memory for place holder for #n nest + allocate(placeholder(LIS_rc%lnc(n), LIS_rc%lnr(n))) + + ews = LIS_ews_halo_ind(n, LIS_localPet+1) + ewe = LIS_ewe_halo_ind(n, LIS_localPet+1) + nss = LIS_nss_halo_ind(n, LIS_localPet+1) + nse = LIS_nse_halo_ind(n, LIS_localPet+1) + + ! Initialize topography and landcover parameters: + snowmodel_struc(n)%sm(:)%smtopo = 0. + snowmodel_struc(n)%sm(:)%smvege = 0. + + ! Assign LDT-based landcover and topographic maps : + if( snowmodel_struc(n)%sm_params_opt == "LDT" ) then + write(LIS_logunit,*) "[INFO] Reading in SnowModel LSM parameters from LDT" + ascii_topoveg = 2.0 ! No file read in by SnowModel; use LDT input + else + write(LIS_logunit,*) "[INFO] Reading in SnowModel LSM parameters from snowmodel.par file " + endif + + if( ascii_topoveg == 2.0 ) then + write(LIS_logunit,*) "SnowModel: Reading parameter SMTOPO from: ",& + trim(LIS_rc%paramfile(n)) + call LIS_read_param(n, "SMTOPO", placeholder) + do t = 1, LIS_rc%npatch(n, mtype) + col = LIS_surface(n, mtype)%tile(t)%col + row = LIS_surface(n, mtype)%tile(t)%row + snowmodel_struc(n)%sm(t)%smtopo = placeholder(col, row) + ! Assign LDT-version of SnowModel topo map to topo_land ... + topo_land(col,row) = placeholder(col, row) + enddo + + write(LIS_logunit,*) "SnowModel: Reading parameter SMVEG from: ",& + trim(LIS_rc%paramfile(n)) + call LIS_read_param(n, "SMVEG", placeholder) + do t = 1, LIS_rc%npatch(n, mtype) + col = LIS_surface(n, mtype)%tile(t)%col + row = LIS_surface(n, mtype)%tile(t)%row + snowmodel_struc(n)%sm(t)%smvege = placeholder(col, row) + ! Assign LDT-version of SnowModel veg map to vegtype ... + vegtype(col,row) = placeholder(col, row) + enddo + + endif + + enddo + +! call snowmodel_setvegparms(LIS_rc%lsm_index) + + ! ------------------------------ + + ! SnowModel Main code calls and options for reading in and + ! preprocessing necessary inputs to the submodel components: + ! All below from the original snowmodel_main.f ... + + do n=1,LIS_rc%nnest + + write(LIS_logunit,*) "[INFO] SnowModel 'main' calls for preprocessing inputs" + + ! Using local parallel subdomain starting index values: + ! LIS_ews_halo_ind(n,LIS_localPet+1) -- defined in LIS_coreMod.F90 ... + xmn_part = xmn + deltax * ( real(LIS_ews_halo_ind(n,LIS_localPet+1)) - 1.0 ) + ymn_part = ymn + deltay * ( real(LIS_nss_halo_ind(n,LIS_localPet+1)) - 1.0 ) + + ! This loop runs the correction/data assimilation adjustment + ! iterations. + if (ihrestart_flag.ge.0) then + if (i_dataassim_loop.lt.0.0) then + i_corr_start = 2 + else + i_corr_start = 1 + endif + else + i_corr_start = 1 + endif + + do icorr_factor_loop=i_corr_start,irun_data_assim+1 + + ! Perform a variety of preprocessing and model setup steps, like + ! read in topography and vegetation arrays, open input and output + ! files, etc. + + if( snowmodel_struc(n)%call_sm_preproc == 1 ) then + + write(LIS_logunit,*) "[INFO] Calling original 'preprocess_code' routine " + + CALL PREPROCESS_CODE(topoveg_fname,const_veg_flag,& + vegtype,veg_z0,vegsnowdepth,fetch,xmu,C_z,h_const,& + wind_min,Up_const,dz_susp,ztop_susp,fall_vel,Ur_const,& + ro_water,ro_air,gravity,vonKarman,pi,twopio360,snow_z0,& + LIS_rc%lnc(n),LIS_rc%lnr(n),sum_sprec,sum_qsubl,sum_trans,sum_unload,topo,& ! KRA: nx,ny + topo_land,snow_d,topoflag,snow_d_init,snow_d_init_const,& + soft_snow_d,met_input_fname,igrads_metfile,deltax,deltay,& + snowtran_output_fname,micromet_output_fname,& + enbal_output_fname,snowpack_output_fname,print_micromet,& + print_enbal,print_snowpack,print_snowtran,run_micromet,& + run_enbal,run_snowpack,run_snowtran,ro_snow_grid,swe_depth,& + sum_runoff,sum_prec,ro_snow,twolayer_flag,sum_Qcs,& + canopy_int,ascii_topoveg,topo_ascii_fname,icorr_factor_loop,& + veg_ascii_fname,undef,isingle_stn_flag,max_iter,& + i_tair_flag,i_rh_flag,i_wind_flag,i_prec_flag,sum_glacmelt,& + snow_depth,sum_d_canopy_int,corr_factor,icorr_factor_index,& + sum_sfcsublim,barnes_lg_domain,n_stns_used,k_stn,xmn_part,ymn_part,& !KRA: xmn, ymn + ro_soft_snow_old,sum_swemelt,xlat,lat_solar_flag,xlat_grid,& + xlon_grid,UTC_flag,dt,swe_depth_old,canopy_int_old,& + vegsnowd_xy,iveg_ht_flag,ihrestart_flag,i_dataassim_loop,& + multilayer_snowpack,max_layers,multilayer_output_fname,& + print_multilayer,KK,tslsnowfall,tsls_threshold,& + irun_data_assim,izero_snow_date,iclear_mn,iclear_dy,& + xclear_hr,snod_layer,swed_layer,ro_layer,T_old,gamma,& + icond_flag,curve_lg_scale_flag,curve_wt_lg,check_met_data,& + seaice_run,snowmodel_line_flag,xg_line,yg_line,print_user,& + cf_precip_flag,cf_precip,print_inc,xhour_init,Tabler_1_flag,& + Tabler_2_flag,iyear_init,imonth_init,iday_init,print_var,& + output_path_wo_assim,output_path_wi_assim,nrecs_max,& + tabler_sfc_path_name,print_outvars,diam_layer) + + + ! Generate kstn arrays for MicroMet inputs (on SnowModel side): + if( snowmodel_struc(n)%sm_micromet_opt == "SnowModel" ) then + + allocate( global_kstn(LIS_rc%gnc(n),LIS_rc%gnr(n),9) ) + global_kstn = 0 + + ! If the large-domain barnes oi scheme is used, generate the + ! nearest-station indexing array. + if (barnes_lg_domain.eq.1.0) then + if (n_stns_used.gt.9 .or. n_stns_used.lt.1) then + print *,'invalid n_stns_used value' + stop + endif +! Original call from preprocess.f (which is commented now in that routine): +! call get_nearest_stns_1(nx,ny,xmn,ymn,deltax,deltay, & +! n_stns_used,k_stn,snowmodel_line_flag,xg_line,yg_line) +! Updated here to represent entire SnowModel run domain: + call get_nearest_stns_1( LIS_rc%gnc(n),LIS_rc%gnr(n),& + xmn, ymn, deltax, deltay,& + n_stns_used, global_kstn, & + snowmodel_line_flag, xg_line, yg_line) + + k_stn(:,:,:) = global_kstn(ews:ewe,nss:nse,:) + endif + deallocate(global_kstn) + + elseif( snowmodel_struc(n)%sm_micromet_opt == "LIS" ) then + call get_nearest_stns_1( LIS_rc%lnc(n),LIS_rc%lnr(n),& + xmn_part, ymn_part, deltax, deltay,& + n_stns_used, k_stn, & + snowmodel_line_flag, xg_line, yg_line) + + endif ! MM option: Snowmodel or LIS + endif + end do + + end do ! Nest loop + + +end subroutine snowmodel_setup + diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 new file mode 100644 index 000000000..56bbb8d93 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 @@ -0,0 +1,343 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: snowmodel_writerst +! \label{snowmodel_writerst} +! +! !REVISION HISTORY: +! 14 Apr 2020: Kristi Arsenault; Add G. Liston's SnowModel +! 05 Aug 2022: Kristi Arsenault; Updated SnowModel state restart writer +! +! !INTERFACE: +subroutine snowmodel_writerst(n) +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_masterproc + use LIS_timeMgrMod, only : LIS_isAlarmRinging + use LIS_logMod, only : LIS_logunit, LIS_getNextUnitNumber, & + LIS_releaseUnitNumber, LIS_verify + use LIS_fileIOMod, only : LIS_create_output_directory, & + LIS_create_restart_filename + use snowmodel_lsmMod +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n +! +! !DESCRIPTION: +! This program writes restart files for SnowModel. +! This includes all relevant water/energy storage and tile information. +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_create\_output\_directory](\ref{LIS_create_output_directory}) \newline +! creates a timestamped directory for the restart files +! \item[LIS\_create\_restart\_filename](\ref{LIS_create_restart_filename}) \newline +! generates a timestamped restart filename +! \item[snowmodel\_dump\_restart](\ref{snowmodel_dump_restart}) \newline +! writes the SnowModel variables into the restart file +! \end{description} +!EOP + character*200 :: filen + logical :: alarmCheck + integer :: ftn + integer :: status + character*20 :: wformat + character*3 :: fnest + + write(fnest,'(i3.3)') n + ! set restart alarm + alarmCheck = LIS_isAlarmRinging(LIS_rc,"SnowModel restart alarm "//trim(fnest)) + + write(LIS_logunit,*) '[INFO] Call to the SnowModel write restart routine ...' + + ! set restart file format (read from LIS configration file_ + wformat = trim(snowmodel_struc(n)%rformat) + + if(alarmCheck .or. (LIS_rc%endtime ==1)) then + if (LIS_masterproc) Then + call LIS_create_output_directory("SURFACEMODEL") + call LIS_create_restart_filename(n, filen, "SURFACEMODEL", & + "SNOWMODEL",wformat=wformat) + if(wformat .eq. "binary") then + ftn = LIS_getNextUnitNumber() + open(ftn,file=filen,status="unknown", form="unformatted") + elseif(wformat .eq. "netcdf") then +#if (defined USE_NETCDF4) + status = nf90_create(path=filen, cmode=nf90_hdf5, ncid = ftn) + call LIS_verify(status, & + "Error in nf90_open in snowmodel_writerst") +#endif +#if (defined USE_NETCDF3) + status = nf90_create(Path = filen, cmode = nf90_clobber, ncid = ftn) + call LIS_verify(status, & + "Error in nf90_open in snowmodel_writerst") +#endif + endif + endif + + ! Call routine to write out the model states to the file: + call SnowModel_dump_restart(n, ftn, wformat) + + if (LIS_masterproc) then + if(wformat .eq. "binary") then + call LIS_releaseUnitNumber(ftn) + elseif(wformat .eq. "netcdf") then +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + status = nf90_close(ftn) + call LIS_verify(status, & + "Error in nf90_close in snowmodel_writerst") +#endif + endif + write(LIS_logunit,*)& + "[INFO] SnowModel archive restart written: ",trim(filen) + endif + endif +end subroutine snowmodel_writerst + +!BOP +! +! !ROUTINE: SnowModel_dump_restart +! \label{SnowModel_dump_restart} +! +! !REVISION HISTORY: +! This subroutine is generated with the Model Implementation Toolkit developed +! by Shugong Wang for the NASA Land Information System Version 7. The initial +! specification of the subroutine is defined by Sujay Kumar. +! +! 05 Aug 2022: Kristi Arsenault; Updated SnowModel state restart writer +! +! !INTERFACE: +subroutine SnowModel_dump_restart(n, ftn, wformat) + +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_masterproc + use LIS_logMod, only : LIS_logunit + use LIS_historyMod + use snowmodel_lsmMod + + implicit none + + integer, intent(in) :: ftn + integer, intent(in) :: n + character(len=*), intent(in) :: wformat +! +! !DESCRIPTION: +! This routine gathers the necessary restart variables and performs +! the actual write statements to create the restart files. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[ftn] +! unit number for the restart file +! \item[wformat] +! restart file format (binary/netcdf) +! \end{description} +! +! The following is the list of variables written in the SnowModel +! restart file: +! +! \begin{verbatim} +! nc, nr, ntiles - grid and tile space dimensions +! snow_d - Snow depth (m), density-adjusted and used in subgrid-scale snow +! snow_depth - Snow depth (m) +! canopy_int - Canopy interception store (m) +! soft_snow_d - Soft snow layer depth (m) +! ro_snow_grid - Snow grid density (kg/m3) +! swe_depth - Snow water equivalent depth (m) +! ro_soft_snow_old - Density of former soft snow layer (kg/m3) +! snow_d_init - Initial snow depth (m) +! swe_depth_old - Former SWE depth (m) step +! canopy_int_old - Former canopy interception store (m) +! topo - Snow-depth changing grid topography level (m) +! sum_sprec - Summed snowfall (m) +! \end{verbatim} +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_writeGlobalHeader\_restart](\ref{LIS_writeGlobalHeader_restart})\\ +! writes the global header information +! \item[LIS\_writeHeader\_restart](\ref{LIS_writeHeader_restart})\\ +! writes the header information for a variable +! \item[LIS\_closeHeader\_restart](\ref{LIS_closeHeader_restart})\\ +! close the header +! \item[LIS\_writevar\_restart](\ref{LIS_writevar_restart})\\ +! writes a variable to the restart file +! \end{description} +! +!EOP + + integer :: l, t + real :: tmptilen(LIS_rc%npatch(n, LIS_rc%lsm_index)) + integer :: dimID(11) + + integer :: snow_d_ID ! 1 + integer :: snow_depth_ID ! 2 + integer :: canopy_int_ID ! 3 + integer :: softsnow_d_ID ! 4 + integer :: ro_snowgrid_ID ! 5 + integer :: swe_depth_ID ! 6 + integer :: ro_softsnow_old_ID ! 7 + integer :: snow_d_init_ID ! 8 + integer :: swe_depth_old_ID ! 9 + integer :: canopy_int_old_ID ! 10 + integer :: topo_ID ! 11 + integer :: sum_sprec_ID ! 12 + + +!- Write the header of the restart file + call LIS_writeGlobalHeader_restart(ftn, n, LIS_rc%lsm_index, & + "SNOWMODEL", & + dim1=snowmodel_struc(n)%nsnow, & ! Set as one for now + dimID=dimID, & + output_format = trim(wformat)) + + !TODO: replace -99999 and 99999 with correct values for valid_min and valid_max + +!- SnowModel states, based on preprocess_code: HRESTART_SAVE routine + + ! write header for Snow depth (m), density-adjusted and used in subgrid-scale snow (1) + call LIS_writeHeader_restart(ftn, n, dimID, snow_d_ID, "SNOWD", & + "Snow depth, density-adjusted and used in SnowTran subgrid-scale snow", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- snow depth (2) + call LIS_writeHeader_restart(ftn, n, dimID, snow_depth_ID, "SNOWDEPTH", & + "Snow depth", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- canopy interception store (3) + call LIS_writeHeader_restart(ftn, n, dimID, canopy_int_ID, "CANOPYINT", & + "Canopy interception storage term", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- soft snow depth layer (4) + call LIS_writeHeader_restart(ftn, n, dimID, softsnow_d_ID, "SOFTSNOWD", & + "Soft snow layer depth", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- snow grid density (5) + call LIS_writeHeader_restart(ftn, n, dimID, ro_snowgrid_ID, "ROSNOWGRID", & + "Snow grid density", & + "kg/m3", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- swe depth (6) + call LIS_writeHeader_restart(ftn, n, dimID, swe_depth_ID, "SWEDEPTH", & + "Snow water equivalent depth", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- density of former soft snow layer (7) + call LIS_writeHeader_restart(ftn, n, dimID, ro_softsnow_old_ID, "ROSOFTSNOWOLD", & + "Density of former soft snow layer", & + "kg/m3", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- Initial snow depth, density-layer and subgrid scale snow (8) + call LIS_writeHeader_restart(ftn, n, dimID, snow_d_init_ID, "SNOWDINIT", & + "Initial snow depth, density-layer and subgrid scale snow", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- former SWE depth step (9) + call LIS_writeHeader_restart(ftn, n, dimID, swe_depth_old_ID, "SWEDEPTHOLD", & + "Former SWE depth step", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- Former canopy interception store (10) + call LIS_writeHeader_restart(ftn, n, dimID, canopy_int_old_ID, "CANOPYINTOLD", & + "Former canopy interception store", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- Snow-depth changing grid topography level (11) + call LIS_writeHeader_restart(ftn, n, dimID, topo_ID, "TOPO", & + "Snow-depth changing grid topography level", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! write the header for state variable -- summed snowfall (12) + call LIS_writeHeader_restart(ftn, n, dimID, sum_sprec_ID, "SUMSPREC", & + "Sum of (frozen) snow precipitation", & + "m", vlevels=1, valid_min=-99999.0, valid_max=99999.0) + + ! close header of restart file + call LIS_closeHeader_restart(ftn, n, LIS_rc%lsm_index, dimID, snowmodel_struc(n)%rstInterval) + + +!- Write state variables into restart file: + + ! (1) Snow depth (m), density-adjusted and used in subgrid-scale snow + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_d, & + varid=snow_d_ID, dim=1, wformat=wformat) + + ! (2) Snow depth (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_depth, & + varid=snow_depth_ID, dim=1, wformat=wformat) + + ! (3) Canopy interception store (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%canopy_int, & + varid=canopy_int_ID, dim=1, wformat=wformat) + + ! (4) Soft snow depth layer (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%soft_snow_d, & + varid=softsnow_d_ID, dim=1, wformat=wformat) + + ! (5) Snowdepth grid density (kg/m3) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%ro_snow_grid, & + varid=ro_snowgrid_ID, dim=1, wformat=wformat) + + ! (6) SWE depth (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%swe_depth, & + varid=swe_depth_ID, dim=1, wformat=wformat) + + ! (7) Former soft snow density step (kg/m3) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%ro_soft_snow_old, & + varid=ro_softsnow_old_ID, dim=1, wformat=wformat) + + ! (8) Snowdepth init (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%snow_d_init, & + varid=snow_d_init_ID, dim=1, wformat=wformat) + + ! (9) Former SWE depth (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%swe_depth_old, & + varid=swe_depth_old_ID, dim=1, wformat=wformat) + + ! (10) Former canopy interception storage (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%canopy_int_old, & + varid=canopy_int_old_ID, dim=1, wformat=wformat) + + ! (11) Topographic grid (with snowdepth included) (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%topo, & + varid=topo_ID, dim=1, wformat=wformat) + + ! (12) Sum of snowfall (m) + call LIS_writevar_restart(ftn, n, LIS_rc%lsm_index, & + snowmodel_struc(n)%sm%sum_sprec, & + varid=sum_sprec_ID, dim=1, wformat=wformat) + + +end subroutine SnowModel_dump_restart + + + From ae5208fbf8442911601dc1d4c4e89a2979c5e203 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Thu, 25 Aug 2022 11:06:52 -0400 Subject: [PATCH 059/328] Minor updates to the LIS-SnowModel code Added a trim function to the WRF-Conus metforcing elevation file in LDT. Added one additional LIS config file line in the configs documentation. --- ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 | 2 +- lis/configs/lis.config.adoc | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 b/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 index 6dddd0d93..48381060b 100644 --- a/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 +++ b/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 @@ -109,7 +109,7 @@ subroutine read_wrfoutv2_elev( n, findex, wrfoutv2elev, elevdiff ) ! Open and Read-in Forcing Terrain Hght File - Bring to LIS run domain ! ------------------------------------------------------------------- write(LDT_logunit,*) "[INFO] Reading the WRFoutv2 terrain height file: ", & - wrfoutv2_struc(n)%file_wrfelev + trim(wrfoutv2_struc(n)%file_wrfelev) #if (defined USE_NETCDF4) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 7dc74d6a9..6e50939fa 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -9502,6 +9502,11 @@ Acceptable values are: |LIS | LIS-based meteorological forcing fields |==== +`SnowModel preprocess code option:` specifies the turning on +of the SnowModel built-in preprocess code module, which performs +initial preprocessing of gridded data for running the model. +Currently, only option supported is 1 (on). + `Write out SnowModel forcing file fields:` specifies if you want to write out SnowModel forcing fields generated by reading in SnowModel-specific forcing files. This option is mainly @@ -9531,6 +9536,7 @@ SnowModel parameter file: ./snowmodel.par SnowModel parameters source option: LDT SnowModel MicroMet input source: LIS Write out SnowModel forcing file fields: 1 +SnowModel preprocess code option: 1 SnowModel number of snow layers: 1 SnowModel initial snow water equivalent: 0.0 .... From 70be7743c9faa7328317bcb74acfb61d186115b9 Mon Sep 17 00:00:00 2001 From: Sarith Mahanama Date: Tue, 11 Oct 2022 10:35:04 -0400 Subject: [PATCH 060/328] removed RIVERBED parameter options from the config file and ensure RIVERBED is always less than HGT_M --- ldt/params/Noah/Noah_parmsMod.F90 | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index b2bf156db..46721ef74 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -537,11 +537,11 @@ subroutine NoahParms_init (flag) call ESMF_ConfigGetAttribute(LDT_config, MBR_RECH%water_value, label='RECHCLIM water value:', DEFAULT= 0., rc=rc) call LDT_verify(rc,"Suitable RECHCLIM parameter value in lakes/waterbodies not defined." ) - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:',rc=rc) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%filltype, label='RIVERBED fill option:', DEFAULT= "neighbor", rc=rc) call LDT_verify(rc,"RIVERBED fill option not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:',rc=rc) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillradius,label='RIVERBED fill radius:', DEFAULT= 0., rc=rc) call LDT_verify(rc,"RIVERBED fill radius not defined.") - call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' ,rc=rc) + call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%gap_fill%fillvalue, label='RIVERBED fill value:' , DEFAULT= 10000., rc=rc) call LDT_verify(rc,"RIVERBED fill value not defined." ) call ESMF_ConfigGetAttribute(LDT_config, MBR_RIVERBED%water_value, label='RIVERBED water value:', DEFAULT= -100., rc=rc) call LDT_verify(rc,"Suitable RIVERBED parameter value in lakes/waterbodies not defined." ) @@ -594,6 +594,11 @@ subroutine NoahParms_init (flag) where (Noah_struc(n)%riverbed%value == MBR_RIVERBED%water_value) Noah_struc(n)%riverbed%value = Noah_struc(n)%hgtm%value endwhere + + ! Ensure RIVERBED value <= MMF_HGTM + where (Noah_struc(n)%riverbed%value > Noah_struc(n)%hgtm%value) + Noah_struc(n)%riverbed%value = Noah_struc(n)%hgtm%value + endwhere ! write areaXY call cell_area (n,Noah_struc(n)%areaxy%value) From eccd3967d8f1eed3fcf22fdf0180c86652294ebb Mon Sep 17 00:00:00 2001 From: Sarith Mahanama <45108045+smahanam@users.noreply.github.com> Date: Tue, 11 Oct 2022 12:51:11 -0400 Subject: [PATCH 061/328] Update ldt.config.adoc removed RIVERBED parameter options from the config file --- ldt/configs/ldt.config.adoc | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 949b82410..7dd030bdc 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -2475,22 +2475,6 @@ RECHCLIM water value: -1. .... -`RIVERBED fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). - -`RIVERBED fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. - -`RIVERBED fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - -`RIVERBED water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable RIVERBED value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. Note that this will be overwritten by MMF_HGTM values at the location if an acceptable MMF_GHTM available at the location. - -.Example _ldt.config_ entry -.... -RIVERBED fill option: neighbor -RIVERBED fill radius: 0. -RIVERBED fill value: 0. -RIVERBED water value: 0. -.... - `EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). `EQWTD fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. From 7cd769264a0e3bbd065f73e79e8f79b038aa99cb Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 8 Dec 2022 15:54:33 -0500 Subject: [PATCH 062/328] Add note regarding compiling SnowModel The SnowModel/Micromet code requires the `-mcmodel=medium` compiler flag. --- docs/LIS_users_guide/plugins.adoc | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/docs/LIS_users_guide/plugins.adoc b/docs/LIS_users_guide/plugins.adoc index 8e9bb59c9..d0e28d367 100644 --- a/docs/LIS_users_guide/plugins.adoc +++ b/docs/LIS_users_guide/plugins.adoc @@ -41,5 +41,22 @@ After creating a _user.cfg_ file you must recompile the LIS source code. First % cd .. .... -Re-run the _configure_ script to process your _user.cfg_ file. Then compile the LIS source code accordingly. +//Re-run the _configure_ script to process your _user.cfg_ file. Then compile the LIS source code accordingly. + +Now you may recompile LIS. + +.... +% ./compile +.... + +[NOTE] +==== +If you enable the SnowModel by adding + +.... +SNOWMODEL: On +.... + +to your _user.cfg_ file, then you must modify the _make/configure.lis_ file by adding `-mcmodel=medium` to the `FFLAGS77` and `FFLAGS` variables. +==== From 0a6ba5cb19ba3e983e5cb4e783d32e12b84582d4 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Fri, 9 Dec 2022 11:13:55 -0500 Subject: [PATCH 063/328] Changed length of dir vars in Noah_parmsMod.F90 This commit is an edit to PR #1038. In the file /params/Noah/Noah_parmsMod.F90, directory variable character lenghts were edited to be be equal to the constant, LVT_CONST_PATH_LEN. --- ldt/params/Noah/Noah_parmsMod.F90 | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 4359ae35d..8a2ab6163 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -66,11 +66,11 @@ module Noah_parmsMod character*50 :: tbot_proj character*50 :: slopetype_proj - character*140 :: mmf_fdepth_dir - character*140 :: mmf_rechclim_dir - character*140 :: mmf_riverbed_dir - character*140 :: mmf_eqwtd_dir - character*140 :: mmf_hgtm_dir + character(len=LDT_CONST_PATH_LEN) :: mmf_fdepth_dir + character(len=LDT_CONST_PATH_LEN) :: mmf_rechclim_dir + character(len=LDT_CONST_PATH_LEN) :: mmf_riverbed_dir + character(len=LDT_CONST_PATH_LEN) :: mmf_eqwtd_dir + character(len=LDT_CONST_PATH_LEN) :: mmf_hgtm_dir character*50 :: mmf_transform real :: pblh_value From cde85f417e8fc41c8039083e634051a2a7df29da Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Fri, 9 Dec 2022 16:18:43 -0500 Subject: [PATCH 064/328] SnowModel default off and use LIS_CONST_PATH_LEN This commit sets SnowModel 'Off' by default and also uses the LIS_CONST_PATH_LEN to define the character length of some file name variables. --- lis/make/default.cfg | 2 +- .../subLSM/snowmodel/snowmodel_lsmMod.F90 | 46 +++++++++---------- .../subLSM/snowmodel/snowmodel_writerst.F90 | 3 +- 3 files changed, 26 insertions(+), 25 deletions(-) diff --git a/lis/make/default.cfg b/lis/make/default.cfg index b19cc9b65..e62461e53 100644 --- a/lis/make/default.cfg +++ b/lis/make/default.cfg @@ -1734,7 +1734,7 @@ path: surfacemodels/land/subLSM/crocus.8.1, surfacemodels/land/subLSM/crocus.8.1/cplLSM [SNOWMODEL] -enabled: True +enabled: False macro: SM_SNOWMODEL path: surfacemodels/land/subLSM/snowmodel, surfacemodels/land/subLSM/snowmodel/physics, diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 index fc01b019b..0f959ca7d 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 @@ -56,7 +56,7 @@ module snowmodel_lsmMod ! !USES: use snowmodel_module use snowmodel_vars - + use LIS_constantsMod, only : LIS_CONST_PATH_LEN implicit none PRIVATE @@ -72,30 +72,30 @@ module snowmodel_lsmMod type, public :: snowmodel_type_dec ! LIS related parameters: - real :: rstInterval - character(256) :: rfile - character(256) :: rformat + real :: rstInterval + character(len=LIS_CONST_PATH_LEN) :: rfile + character(20) :: rformat ! LIS-SnowModel related parameters: - character(256) :: parfile - character(256) :: vfile - real :: ht_windobs - real :: ht_rhobs - integer :: call_sm_preproc - integer :: write_sm_metfields - character(10) :: sm_params_opt - character(10) :: sm_micromet_opt - - integer :: nsnow - real, allocatable :: lyrthk(:) - real, allocatable :: inittemp(:) - real :: initsnowdepth - real :: initsnowequiv - - integer :: forc_count - - real :: ts - integer :: iter + character(len=LIS_CONST_PATH_LEN) :: parfile + character(len=LIS_CONST_PATH_LEN) :: vfile + real :: ht_windobs + real :: ht_rhobs + integer :: call_sm_preproc + integer :: write_sm_metfields + character(10) :: sm_params_opt + character(10) :: sm_micromet_opt + + integer :: nsnow + real, allocatable :: lyrthk(:) + real, allocatable :: inittemp(:) + real :: initsnowdepth + real :: initsnowequiv + + integer :: forc_count + + real :: ts + integer :: iter ! SnowModel parameter - snowmodel.h ! integer :: nx_max diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 index 56bbb8d93..e0cd86ea5 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 @@ -27,6 +27,7 @@ subroutine snowmodel_writerst(n) use LIS_fileIOMod, only : LIS_create_output_directory, & LIS_create_restart_filename use snowmodel_lsmMod + use LIS_constantsMod, only : LIS_CONST_PATH_LEN #if (defined USE_NETCDF3 || defined USE_NETCDF4) use netcdf #endif @@ -50,7 +51,7 @@ subroutine snowmodel_writerst(n) ! writes the SnowModel variables into the restart file ! \end{description} !EOP - character*200 :: filen + character(len=LIS_CONST_PATH_LEN) :: filen logical :: alarmCheck integer :: ftn integer :: status From 05b17847f9dcca8386f74909874e3e544f6e60fb Mon Sep 17 00:00:00 2001 From: Brendan McAndrew <19274445+bmcandr@users.noreply.github.com> Date: Fri, 16 Dec 2022 22:14:15 -0500 Subject: [PATCH 065/328] Fix release docs action and LIS User Guide formatting --- .github/workflows/build-release-docs.yaml | 15 ++++++++++----- lis/configs/lis.config.adoc | 4 +--- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/.github/workflows/build-release-docs.yaml b/.github/workflows/build-release-docs.yaml index 47af82907..cf12fffa9 100644 --- a/.github/workflows/build-release-docs.yaml +++ b/.github/workflows/build-release-docs.yaml @@ -19,21 +19,26 @@ jobs: - name: Install Ruby uses: ruby/setup-ruby@v1 with: - ruby-version: 2.7.6 # Not needed with a .ruby-version file - bundler-cache: true # runs 'bundle install' and caches installed gems automatically + ruby-version: 2.7 # Not needed with a .ruby-version file + + - name: Configure Bundler + run: bundle config --local path .bundle/gems - name: Install Asciidoctor-Mathematical dependencies run: | # below command from: https://github.com/asciidoctor/asciidoctor-mathematical/#installation - sudo apt-get -qq -y install bison flex libffi-dev libxml2-dev libgdk-pixbuf2.0-dev libcairo2-dev libpango1.0-dev fonts-lyx cmake + sudo apt-get update -y + sudo apt-get -qq -y install bison flex libffi-dev libxml2-dev libgdk-pixbuf2.0-dev libcairo2-dev libpango1.0-dev libwebp-dev fonts-lyx cmake - name: Install Asciidoctor-PDF run: | gem install asciidoctor-pdf - gem install asciidoctor-mathematical - asciidoctor-pdf --version + - name: Install asciidoctor-mathematical + run: | + gem install asciidoctor-mathematical + - name: Store tag in environment run : echo "RELEASE_TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 2caa3a5ea..68019b236 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -10392,7 +10392,6 @@ RAPID Muskingum parameter x file: ./rapid_params/x.csv RAPID namelist file: ./rapid_params/rapid_namelist .... -======= [[sssec_lsm_Crocus8.1, from SURFEX8.1]] ==== Crocus8.1 @@ -10549,7 +10548,6 @@ writing interval for Crocus8.1. The typical value is 1 month (1mo). `CROCUS81 initial SNOWMAK_dz:` Initial depth from snow making process - .Example _lis.config_ entry .... @@ -10611,6 +10609,7 @@ CROCUS81 initial CDSNOW: 0.0 CROCUS81 initial USTARSNOW: 0.0 CROCUS81 initial CHSNOW: 0.0 CROCUS81 initial SNOWMAK_dz: 0.0 +.... === Runoff @@ -10832,7 +10831,6 @@ sample MODEL_OUTPUT_LIST.TBL file for the complete specification. Model output attributes file: './MODEL_OUTPUT_LIST.TBL' .... - [[ssec_timeinterval,Defining a time interval]] === Defining a time interval From 8ac71019250e7b200750076e67030aa24b453540 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Wed, 11 Jan 2023 14:22:58 -0500 Subject: [PATCH 066/328] Added support for COAMPS meteorological forcing. --- .../COAMPSout/COAMPSout_dataMod.F90 | 91 +++++ .../COAMPSout/readCOAMPSoutdata.F90 | 333 ++++++++++++++++++ lvt/make/Filepath | 2 +- lvt/plugins/LVT_datastream_pluginMod.F90 | 9 +- lvt/plugins/LVT_pluginIndices.F90 | 2 + 5 files changed, 435 insertions(+), 2 deletions(-) create mode 100644 lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 create mode 100644 lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 diff --git a/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 b/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 new file mode 100644 index 000000000..cce030ec4 --- /dev/null +++ b/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 @@ -0,0 +1,91 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !MODULE: COAMPSout_dataMod +! \label(COAMPSout_dataMod) +! +! !INTERFACE: +module COAMPSout_dataMod + + ! Imports + use ESMF + + ! Defaults + implicit none + private + + ! REVISION HISTORY: + ! 09 Dec 2022: Mahdi Navari; Initial Specification in LVT + + ! Public routines + public :: COAMPSout_datainit + + ! Public types + public :: COAMPSoutdata + + type, public :: COAMPSoutdatadec + character*100 :: odir + integer :: COAMPSnest_id + real*8 :: changetime1 + real*8 :: changetime2 + real, allocatable :: rlat(:) + real, allocatable :: rlon(:) + integer :: nc + integer :: nr + type(ESMF_TimeInterval) :: ts + end type COAMPSoutdatadec + + type(COAMPSoutdatadec), allocatable :: COAMPSoutdata(:) + +contains + + !--------------------------------------------------------------------------- + subroutine COAMPSout_datainit(i) + + ! Imports + use LVT_coreMod + use LVT_logMod + use LVT_histDataMod + use LVT_timeMgrMod + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: i + + ! Local variables + integer :: status + !real :: gridDesci(50) + !integer :: updoy, yr1,mo1,da1,hr1,mn1,ss1 + !real :: upgmt + !character*10 :: time + !integer :: ts + + if(.not.allocated(COAMPSoutdata)) then + allocate(COAMPSoutdata(LVT_rc%nDataStreams)) + endif + + ! Get top level COAMPSout data directory + call ESMF_ConfigGetAttribute(LVT_Config, COAMPSoutdata(i)%odir, & + label='COAMPS output forcing directory:', rc=status) + call LVT_verify(status, 'COAMPS output forcing directory: not defined') + call ESMF_ConfigGetAttribute(LVT_Config, COAMPSoutdata(i)%COAMPSnest_id, & + label='COAMPS nest id:', rc=status) + call LVT_verify(status, 'COAMPS nest id: not defined') + + call ESMF_TimeIntervalSet(COAMPSoutdata(i)%ts, s = 3600, & + rc=status) + call LVT_verify(status) + + end subroutine COAMPSout_datainit + +end module COAMPSout_dataMod diff --git a/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 new file mode 100644 index 000000000..981ffbf47 --- /dev/null +++ b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 @@ -0,0 +1,333 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- + +#include "LVT_misc.h" + +!------------------------------------------------------------------------------ +! !REVISION HISTORY: +! 09 Dec 2022: Mahdi Navari; Initial Specification in LVT + +subroutine readCOAMPSoutdata(source) + +! Imports + use ESMF + use COAMPSout_dataMod + use LVT_coreMod + use LVT_histDataMod + use LVT_logMod + use LVT_timeMgrMod + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + +! Defaults + implicit none + +! Arguments + integer,intent(in) :: source + +! !DESCRIPTION: +! Opens and reads 1-hourly COAMPS output forcing. + +!EOP + +! Local variables + character*100 :: fname + integer :: fcsthr, yr, mo, da, hr, mn, ss + integer :: c,r,gindex + integer :: ftn, ios + logical :: file_exists, rainc_exists + integer :: t2Id, q2Id, swdownId, glwId + integer :: u10Id, v10Id, psfcId, rainncId + integer :: raincID + real :: gvar(LVT_rc%lnc,LVT_rc%lnr,1) + real :: t2(LVT_rc%lnc,LVT_rc%lnr) + real :: q2(LVT_rc%lnc,LVT_rc%lnr) + real :: swdown(LVT_rc%lnc,LVT_rc%lnr) + real :: glw(LVT_rc%lnc,LVT_rc%lnr) + real :: u10(LVT_rc%lnc,LVT_rc%lnr) + real :: v10(LVT_rc%lnc,LVT_rc%lnr) + real :: psfc(LVT_rc%lnc,LVT_rc%lnr) + real :: rainnc(LVT_rc%lnc,LVT_rc%lnr) + real :: rainc(LVT_rc%lnc,LVT_rc%lnr) + real :: t2scal,q2scal,u10scal,v10scal,swdscal,glwscal + real :: psfcscal,rainncscal + real :: t2offset,q2offset,u10offset,v10offset + real :: psfcoffset,rainncoffset,swdoffset,glwoffset + integer :: status + +gvar = 0.0 +t2 = 0.0 +q2 = 0.0 +swdown = 0.0 +glw = 0.0 +u10 = 0.0 +v10 = 0.0 +psfc = 0.0 +rainnc = 0.0 +rainc = 0.0 + +! read hourly forcing data +yr = LVT_rc%dyr(source) +mo = LVT_rc%dmo(source) +da = LVT_rc%dda(source) +hr = LVT_rc%dhr(source) +mn = 0 +ss = 0 + +fcsthr = (hr/6)*6 +call COAMPSoutfile(fname,COAMPSoutdata(source)%odir,COAMPSoutdata(source)%COAMPSnest_id,fcsthr,& + yr,mo,da,hr,mn,ss) + +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + inquire (file=trim(fname), exist=file_exists) + if (file_exists) then + !ferror = 1 + call LVT_verify(nf90_open(path=trim(fname),mode=NF90_NOWRITE, & + ncid = ftn), 'nf90_open failed in read_COAMPSout') + write(LVT_logunit,*) '[INFO] Reading COAMPSout ',trim(fname) + call LVT_verify(nf90_inq_varid(ftn,'air_temp_2m',t2Id),& + 'nf90_inq_varid failed for air_temp_2m in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,t2Id,"scale_factor",t2scal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,t2Id,"add_offset",t2offset),& + 'nf90_get_att failed for nf90_get_att') + + call LVT_verify(nf90_inq_varid(ftn,'spec_hum_2m',q2Id),& + 'nf90_inq_varid failed for spec_hum_2m in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,q2Id,"scale_factor",q2scal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,q2Id,"add_offset",q2offset),& + 'nf90_get_att failed for nf90_get_att') + + !call LVT_verify(nf90_inq_varid(ftn,'sw_rad_down',swdownId),& + ! 'nf90_inq_varid failed for sw_rad_down in read_COAMPSout') + ios = nf90_inq_varid(ftn,'sw_rad_down',swdownId) + if ( ios /= 0) then + ios = nf90_inq_varid(ftn,'sw_flux_dn',swdownId) + endif + call LVT_verify(ios,'nf90_inq_varid failed for sw_rad_down or sw_flux_dn in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,swdownId,"scale_factor",swdscal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,swdownId,"add_offset",swdoffset),& + 'nf90_get_att failed for nf90_get_att') + + !call LVT_verify(nf90_inq_varid(ftn,'lw_rad_down',glwId),& + ! 'nf90_inq_varid failed for lw_rad_down in read_COAMPSout') + ios = nf90_inq_varid(ftn,'lw_rad_down',glwId) + if ( ios /= 0) then + ios = nf90_inq_varid(ftn,'lw_flux_dn',glwId) + endif + call LVT_verify(ios,'nf90_inq_varid failed for lw_rad_down or lw_flux_dn in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,glwId,"scale_factor",glwscal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,glwId,"add_offset",glwoffset),& + 'nf90_get_att failed for nf90_get_att') + + call LVT_verify(nf90_inq_varid(ftn,'wind_10m_x',u10Id),& + 'nf90_inq_varid failed for wind_10m_x in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,u10Id,"scale_factor",u10scal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,u10Id,"add_offset",u10offset),& + 'nf90_get_att failed for nf90_get_att') + + call LVT_verify(nf90_inq_varid(ftn,'wind_10m_y',v10Id),& + 'nf90_inq_varid failed for wind_10m_y in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,v10Id,"scale_factor",v10scal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,v10Id,"add_offset",v10offset),& + 'nf90_get_att failed for nf90_get_att') + + call LVT_verify(nf90_inq_varid(ftn,'surf_atm_pres',psfcId),& + 'nf90_inq_varid failed for surf_atm_pres in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,psfcId,"scale_factor",psfcscal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,psfcId,"add_offset",psfcoffset),& + 'nf90_get_att failed for nf90_get_att') + + call LVT_verify(nf90_inq_varid(ftn,'ttl_prcp',rainncId),& + 'nf90_inq_varid failed for ttl_prcp in read_COAMPSout') + call LVT_verify(nf90_get_att(ftn,rainncId,"scale_factor",rainncscal),& + 'nf90_get_att failed for nf90_get_att') + call LVT_verify(nf90_get_att(ftn,rainncId,"add_offset",rainncoffset),& + 'nf90_get_att failed for nf90_get_att') + + rainc_exists = .false. + rainc = 0.0 ! initialize to 0 + call LVT_verify(nf90_get_var(ftn,t2id,gvar),& + 'nf90_get_var failed for t2 in read_COAMPSout') + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + t2(c,r) = gvar(c,r,1)*t2scal+t2offset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,q2id,gvar),& + 'nf90_get_var failed for q2 in read_COAMPSout') + + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + q2(c,r) = gvar(c,r,1)*q2scal+q2offset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,swdownid,gvar),& + 'nf90_get_var failed for swdown in read_COAMPSout') + + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + swdown(c,r) = gvar(c,r,1)*swdscal+swdoffset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,glwid,gvar),& + 'nf90_get_var failed for glw in read_COAMPSout') + + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + glw(c,r) = gvar(c,r,1)*glwscal+glwoffset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,u10id,gvar),& + 'nf90_get_var failed for u10 in read_COAMPSout') + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + u10(c,r) = gvar(c,r,1)*u10scal+u10offset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,v10id,gvar),& + 'nf90_get_var failed for v10 in read_COAMPSout') + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + v10(c,r) = gvar(c,r,1)*v10scal+v10offset + endif + enddo + enddo + + call LVT_verify(nf90_get_var(ftn,psfcid,gvar),& + 'nf90_get_var failed for psfc in read_COAMPSout') + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + psfc(c,r) = gvar(c,r,1)*psfcscal+psfcoffset + endif + enddo + enddo + call LVT_verify(nf90_get_var(ftn,rainncid,gvar),& + 'nf90_get_var failed for rainnc in read_COAMPSout') + do r=1,LVT_rc%lnr + do c=1,LVT_rc%lnc + if(gvar(c,r,1).gt.-32768) then + rainnc(c,r) = gvar(c,r,1)*rainncscal+rainncoffset + endif + enddo + enddo + + call LVT_verify(nf90_close(ftn), & + 'failed to close file in read_COAMPSout') + write(LVT_logunit,*) '[INFO] Successfully processed ',trim(fname) + + call LVT_logSingleDataStreamVar(LVT_MOC_swdownforc,source,swdown,vlevel=1,units="W/m2") + + call LVT_logSingleDataStreamVar(LVT_MOC_lwdownforc,source,glw,vlevel=1,units="W/m2") + + call LVT_logSingleDataStreamVar(LVT_MOC_totalprecip,source,rainnc,vlevel=1,units="kg/m2") + + call LVT_logSingleDataStreamVar(LVT_MOC_tairforc,source,t2,vlevel=1,units="K") + + call LVT_logSingleDataStreamVar(LVT_MOC_qairforc,source,q2,vlevel=1,& + units="kg/kg") + + call LVT_logSingleDataStreamVar(LVT_MOC_PSURFFORC,source,psfc, & + vlevel=1,units="Pa") + + call LVT_logSingleDataStreamVar(LVT_MOC_NWINDFORC,source,v10, & + vlevel=1,units="m/s") + + call LVT_logSingleDataStreamVar(LVT_MOC_EWINDFORC,source,u10, & + vlevel=1,units="m/s") + + else + write(LVT_logunit,*) '[ERR] Forcing file '//trim(fname)//' not found' + endif +#else + write(LVT_logunit,*) '[ERR] read_COAMPSout requires NetCDF' + write(LVT_logunit,*) '[ERR] please recompile LIS' + call LVT_endrun +#endif + + +end subroutine readCOAMPSoutdata + +!------------------------------------------------------------------------------ + +!------------------------------------------------------------------------------ +!BOP +! !ROUTINE: COAMPSoutfile +! \label{COAMPSoutfile} +! +! !INTERFACE: + subroutine COAMPSoutfile(filename,coampsdir,nest,fcsthr,& + yr,mo,da,hr,mn,ss) + + implicit none +! !ARGUMENTS: + character(len=*), intent(out) :: filename + character(len=*), intent(in) :: coampsdir + integer, intent(in) :: nest + integer, intent(in) :: fcsthr + integer, intent(in) :: yr,mo,da,hr,mn,ss + +! !DESCRIPTION: +! +!EOP + + integer :: hr1 + character*10 :: ftime1 + character*1 :: fnest + character*4 :: fyr + character*2 :: fmo + character*2 :: fda + character*2 :: fhr,fhr1 + character*2 :: fmn + character*2 :: fss + + hr1 = hr - fcsthr + write(unit=ftime1, fmt='(i4.4,i2.2,i2.2,i2.2)') yr,mo,da,hr + write(unit=fnest,fmt='(i1.1)') nest + write(unit=fyr,fmt='(i4.4)') yr + write(unit=fmo,fmt='(i2.2)') mo + write(unit=fda,fmt='(i2.2)') da + write(unit=fhr,fmt='(i2.2)') hr1 + write(unit=fhr1,fmt='(i2.2)') fcsthr + write(unit=fmn,fmt='(i2.2)') mn + write(unit=fss,fmt='(i2.2)') ss + + filename = trim(coampsdir)//'/'//& + trim(fyr)//trim(fmo)//trim(fda)//trim(fhr1)//& + '/coamps_'//trim(fnest)//'_'//trim(fyr)//trim(fmo)//& + trim(fda)//trim(fhr1)//'_00'//trim(fhr)//'0000.nc' + + end subroutine COAMPSoutfile + diff --git a/lvt/make/Filepath b/lvt/make/Filepath index 4668ac161..e5030ab44 100644 --- a/lvt/make/Filepath +++ b/lvt/make/Filepath @@ -1,4 +1,4 @@ -dirs := . ../main ../core ../metrics ../plugins ../interp ../lib/bil ../domains/UTM ../domains/lambert ../domains/latlon ../datastreams/template ../datastreams/LISout ../datastreams/LISDAobs ../datastreams/ISCCP_Tskin ../datastreams/CEOP ../datastreams/SCAN ../datastreams/SCANGMAO ../datastreams/NASMD ../datastreams/GHCN ../datastreams/SNOTEL ../datastreams/SURFRAD ../datastreams/WGPBMR ../datastreams/LSWG_Tb ../datastreams/FMI_SWE ../datastreams/FMI_SNWD ../datastreams/CMC_SNWD ../datastreams/SNODAS ../datastreams/NASA_AMSRE_sm ../datastreams/LPRM_AMSRE_sm ../datastreams/AMMA ../datastreams/Ameriflux ../datastreams/ARM ../datastreams/SMOSREX ../datastreams/AGRMET ../datastreams/GlobSnow ../datastreams/SNODEPmetobs ../datastreams/SNODEP ../datastreams/MOD10A1 ../datastreams/MODSCAG ../datastreams/MOD10A1V6 ../datastreams/ANSA_SNWD ../datastreams/ANSA_SWE ../datastreams/CPC_PRCP ../datastreams/USGS_streamflow_gridded ../datastreams/USGS_streamflow ../datastreams/Natural_streamflow ../datastreams/ISMN ../datastreams/FLUXNETmte ../datastreams/FLUXNET2015 ../datastreams/FLUXNET2015_NC ../datastreams/MOD16A2 ../datastreams/UWET ../datastreams/ARSsm ../datastreams/NLDAS2 ../datastreams/ALEXI ../datastreams/ALEXIesi ../datastreams/GRACE ../datastreams/simGRACE ../datastreams/USGS_GWwell ../datastreams/PBOH2O ../datastreams/SMOS_L2sm ../datastreams/SMOS_NESDIS ../datastreams/SMOS_L1TB ../datastreams/SMOS_CATDS_L3sm ../datastreams/GCOMW_AMSR2L3sm ../datastreams/GCOMW_AMSR2L3snd ../datastreams/SMOPS ../datastreams/MODIS_LST ../datastreams/GLERL_HydroData ../datastreams/JULESdata ../datastreams/JULES2Ddata ../datastreams/ESACCI_sm ../datastreams/GIMMS_AVHRR_NDVI ../datastreams/GIMMS_MODIS_NDVI ../datastreams/GLDAS1 ../datastreams/GLDAS2 ../datastreams/MERRA2 ../datastreams/MERRA2asm ../datastreams/MERRA-Land ../datastreams/SSEBop ../datastreams/GRDC ../datastreams/GOES_LST ../datastreams/ERAinterimLand ../datastreams/SMAPsm ../datastreams/SMAPvod ../datastreams/LPRMvod ../datastreams/SMAPvwc ../datastreams/SMAP_L3TB ../datastreams/SMAPTB ../datastreams/GOME2_SIF ../datastreams/LVTbenchmarkOUT ../datastreams/LIS6out ../datastreams/LISDAdiag ../datastreams/Daymet ../datastreams/CMORPH ../datastreams/CHIRPSv2 ../datastreams/3B42V7 ../datastreams/USCRNsm ../datastreams/GLEAM ../datastreams/USDM ../datastreams/LVTpercentile ../datastreams/IMD_PRCP ../datastreams/APHRO_PRCP ../datastreams/GLASSlai ../datastreams/MODISsportLAI ../datastreams/FLUXCOM ../datastreams/HAR ../datastreams/OCO2_SIF ../datastreams/ECMWFforc ../datastreams/GDASforc ../datastreams/ASO_SWE ../runmodes/DataComp ../runmodes/557post ../runmodes/LISpost ../runmodes/DAstats ../runmodes/optUE ../runmodes/Benchmarking ../runmodes/USAFSIpost ../training/LinearRegression/ ../datastreams/GLASSalbedo ../datastreams/IMERG ../datastreams/UA_SNOW ../datastreams/OzFlux ../datastreams/jasmin ../datastreams/MCD15A2H ../datastreams/ERA5 ../datastreams/FluxSat_GPP ../datastreams/THySM/ ../datastreams/GRUNrunoff ../datastreams/UASMAP/ +dirs := . ../main ../core ../metrics ../plugins ../interp ../lib/bil ../domains/UTM ../domains/lambert ../domains/latlon ../datastreams/template ../datastreams/LISout ../datastreams/LISDAobs ../datastreams/ISCCP_Tskin ../datastreams/CEOP ../datastreams/SCAN ../datastreams/SCANGMAO ../datastreams/NASMD ../datastreams/GHCN ../datastreams/SNOTEL ../datastreams/SURFRAD ../datastreams/WGPBMR ../datastreams/LSWG_Tb ../datastreams/FMI_SWE ../datastreams/FMI_SNWD ../datastreams/CMC_SNWD ../datastreams/SNODAS ../datastreams/NASA_AMSRE_sm ../datastreams/LPRM_AMSRE_sm ../datastreams/AMMA ../datastreams/Ameriflux ../datastreams/ARM ../datastreams/SMOSREX ../datastreams/AGRMET ../datastreams/GlobSnow ../datastreams/SNODEPmetobs ../datastreams/SNODEP ../datastreams/MOD10A1 ../datastreams/MODSCAG ../datastreams/MOD10A1V6 ../datastreams/ANSA_SNWD ../datastreams/ANSA_SWE ../datastreams/CPC_PRCP ../datastreams/USGS_streamflow_gridded ../datastreams/USGS_streamflow ../datastreams/Natural_streamflow ../datastreams/ISMN ../datastreams/FLUXNETmte ../datastreams/FLUXNET2015 ../datastreams/FLUXNET2015_NC ../datastreams/MOD16A2 ../datastreams/UWET ../datastreams/ARSsm ../datastreams/NLDAS2 ../datastreams/ALEXI ../datastreams/ALEXIesi ../datastreams/GRACE ../datastreams/simGRACE ../datastreams/USGS_GWwell ../datastreams/PBOH2O ../datastreams/SMOS_L2sm ../datastreams/SMOS_NESDIS ../datastreams/SMOS_L1TB ../datastreams/SMOS_CATDS_L3sm ../datastreams/GCOMW_AMSR2L3sm ../datastreams/GCOMW_AMSR2L3snd ../datastreams/SMOPS ../datastreams/MODIS_LST ../datastreams/GLERL_HydroData ../datastreams/JULESdata ../datastreams/JULES2Ddata ../datastreams/ESACCI_sm ../datastreams/GIMMS_AVHRR_NDVI ../datastreams/GIMMS_MODIS_NDVI ../datastreams/GLDAS1 ../datastreams/GLDAS2 ../datastreams/MERRA2 ../datastreams/MERRA2asm ../datastreams/MERRA-Land ../datastreams/SSEBop ../datastreams/GRDC ../datastreams/GOES_LST ../datastreams/ERAinterimLand ../datastreams/SMAPsm ../datastreams/SMAPvod ../datastreams/LPRMvod ../datastreams/SMAPvwc ../datastreams/SMAP_L3TB ../datastreams/SMAPTB ../datastreams/GOME2_SIF ../datastreams/LVTbenchmarkOUT ../datastreams/LIS6out ../datastreams/LISDAdiag ../datastreams/Daymet ../datastreams/CMORPH ../datastreams/CHIRPSv2 ../datastreams/3B42V7 ../datastreams/USCRNsm ../datastreams/GLEAM ../datastreams/USDM ../datastreams/LVTpercentile ../datastreams/IMD_PRCP ../datastreams/APHRO_PRCP ../datastreams/GLASSlai ../datastreams/MODISsportLAI ../datastreams/FLUXCOM ../datastreams/HAR ../datastreams/OCO2_SIF ../datastreams/ECMWFforc ../datastreams/GDASforc ../datastreams/ASO_SWE ../runmodes/DataComp ../runmodes/557post ../runmodes/LISpost ../runmodes/DAstats ../runmodes/optUE ../runmodes/Benchmarking ../runmodes/USAFSIpost ../training/LinearRegression/ ../datastreams/GLASSalbedo ../datastreams/IMERG ../datastreams/UA_SNOW ../datastreams/OzFlux ../datastreams/jasmin ../datastreams/MCD15A2H ../datastreams/ERA5 ../datastreams/FluxSat_GPP ../datastreams/THySM/ ../datastreams/GRUNrunoff ../datastreams/UASMAP/ ../datastreams/COAMPSout/ diff --git a/lvt/plugins/LVT_datastream_pluginMod.F90 b/lvt/plugins/LVT_datastream_pluginMod.F90 index 824a827b3..1e7d6046c 100644 --- a/lvt/plugins/LVT_datastream_pluginMod.F90 +++ b/lvt/plugins/LVT_datastream_pluginMod.F90 @@ -33,6 +33,7 @@ ! 17 Oct 2018 Mahdi Navari Enhanced the LVT reader to read the ! Veg. Water Content (VWC) from SMAP SM dataset ! ! 19 Nov 2018 Mahdi Navari added suport to read SMAP_L3 brightness temperature +! 10 Jan 2023 Mahdi Navari added suport for COAMPSout ! !EOP module LVT_datastream_pluginMod @@ -180,6 +181,7 @@ subroutine LVT_datastream_plugin use THySM_obsMod, only : THySM_obsinit use UASMAP_obsMod, only : UASMAP_obsinit use GRUNrunoff_obsMod, only : GRUNrunoffInit + use COAMPSout_dataMod, only : COAMPSout_datainit external readtemplateObs external readLISoutput @@ -290,6 +292,7 @@ subroutine LVT_datastream_plugin external readTHySMobs external readUASMAPobs external readGRUNrunoffobs + external readCOAMPSoutdata call registerobsread(trim(LVT_LVTbenchmarkobsId)//char(0),& readLVTbenchmarkOUTobs) @@ -737,7 +740,11 @@ subroutine LVT_datastream_plugin GRUNrunoffinit) call registerobsread(trim(LVT_GRUNobsId)//char(0),& readGRUNrunoffobs) - + + call registerobssetup(trim(LVT_COAMPSoutId)//char(0), & + COAMPSout_datainit) + call registerobsread(trim(LVT_COAMPSoutId)//char(0),& + readCOAMPSoutdata) end subroutine LVT_datastream_plugin end module LVT_datastream_pluginMod diff --git a/lvt/plugins/LVT_pluginIndices.F90 b/lvt/plugins/LVT_pluginIndices.F90 index 313100354..7817086ab 100644 --- a/lvt/plugins/LVT_pluginIndices.F90 +++ b/lvt/plugins/LVT_pluginIndices.F90 @@ -40,6 +40,7 @@ ! 17 Oct 2018 Mahdi Navari Enhanced the LVT reader to read the ! Veg. Water Content (VWC) from SMAP SM dataset ! ! 19 Nov 2018 Mahdi Navari added suport to read SMAP_L3 brightness temperature +! 10 Jan 2023 Mahdi Navari added suport for COAMPSout ! !EOP module LVT_pluginIndices @@ -270,6 +271,7 @@ module LVT_pluginIndices character*50, public, parameter :: LVT_THySMobsId = "THySM" character*50, public, parameter :: LVT_UASMAPobsId = "UA SMAP" character*50, public, parameter :: LVT_GRUNobsId = "GRUN runoff" + character*50, public, parameter :: LVT_COAMPSoutId = "COAMPSout" !------------------------------------------------------------------------- ! Training algorithms !------------------------------------------------------------------------- From 09e11562e9aac5e0c548c19b55fcc0de7f786ae2 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Thu, 12 Jan 2023 12:00:34 -0500 Subject: [PATCH 067/328] Added support to read the surface pressure and wind speed fields. Added support to instantaneous fields instead of time average fields. --- lvt/datastreams/AGRMET/readAGRMETdata.F90 | 70 +++++++++++++++++++++-- 1 file changed, 66 insertions(+), 4 deletions(-) diff --git a/lvt/datastreams/AGRMET/readAGRMETdata.F90 b/lvt/datastreams/AGRMET/readAGRMETdata.F90 index 64a677796..768ea3c21 100644 --- a/lvt/datastreams/AGRMET/readAGRMETdata.F90 +++ b/lvt/datastreams/AGRMET/readAGRMETdata.F90 @@ -61,6 +61,8 @@ subroutine readAGRMETdata(source) ! This greatly reduces run-time. ! 13 Nov 2017: Eric Kemp (SSAI). Added specific humidity forcing. ! 02 Nov 2018: Eric Kemp (SSAI). Added support for n1280e domain. +! 02 Jan 2023: Mahdi Navari. Modified to read instantaneous forcing variable. +! 04 Jan 2023: Mahdi Navari. Added surface pressure and wind forcing. ! !EOP @@ -144,6 +146,15 @@ subroutine readAGRMETdata(source) qair(agrmetdata(source)%nc*agrmetdata(source)%nr) ! EMK Specific humidity integer :: & nqair(agrmetdata(source)%nc*agrmetdata(source)%nr) + real :: & + psurf(agrmetdata(source)%nc*agrmetdata(source)%nr) ! MN surface pressure + integer :: & + npsurf(agrmetdata(source)%nc*agrmetdata(source)%nr) + real :: & + wind(agrmetdata(source)%nc*agrmetdata(source)%nr) ! MN wind speed + integer :: & + nwind(agrmetdata(source)%nc*agrmetdata(source)%nr) + logical*1 :: & lb(agrmetdata(source)%nc*agrmetdata(source)%nr) @@ -152,12 +163,16 @@ subroutine readAGRMETdata(source) integer :: swe_topt, snod_topt integer :: sm_topt,st_topt integer :: qair_topt ! EMK + integer :: psurf_topt ! MN + integer :: wind_topt ! MN integer :: swd_index, lwd_index,rainf_index, tair_index integer :: qle_index, qh_index, qg_index integer :: swe_index, snod_index integer :: sm_index, st_index integer :: qair_index ! EMK + integer :: psurf_index ! MN + integer :: wind_index ! MN real :: varfield(LVT_rc%lnc,LVT_rc%lnr) integer :: yr1, mo1, da1,hr1,mn1,ss1 @@ -181,10 +196,11 @@ subroutine readAGRMETdata(source) nr = agrmetdata(source)%nr !These are hardcoded for now. 1-instantaneous, 7-timeavged - swd_topt = 7 - lwd_topt = 7 +! MN I have changed the topt from 7 to 1 then LVT can read them. + swd_topt = 1 !7 + lwd_topt = 1 !7 rainf_topt =133 - tair_topt = 7 + tair_topt = 1 !7 qle_topt = 7 qh_topt = 7 qg_topt = 7 @@ -192,7 +208,9 @@ subroutine readAGRMETdata(source) snod_topt = 1 sm_topt = 7 st_topt = 7 - qair_topt = 7 ! EMK + qair_topt = 1 !7 ! EMK + psurf_topt = 1 !7 ! MN + wind_topt = 1 !7 ! MN !gribids swd_index = 145 @@ -208,6 +226,8 @@ subroutine readAGRMETdata(source) st_index = 85 ! tskin_index = 148 qair_index = 51 ! EMK + psurf_index = 1 ! MN + wind_index = 209 !180 ! MN yr1 = LVT_rc%dyr(source) mo1 = LVT_rc%dmo(source) @@ -263,6 +283,10 @@ subroutine readAGRMETdata(source) qair = 0 ! EMK nqair = 0 ! EMK + psurf = 0 !MN + npsurf = 0 !MN + wind = 0 !MN + nwind = 0 !MN call ESMF_TimeSet(time1,yy=yr1, mm=mo1, dd=da1, & h=hr1,m=mn1,s=ss1,calendar=LVT_calendar, rc=status) @@ -556,6 +580,34 @@ subroutine readAGRMETdata(source) enddo enddo + ! MN...Support surface pressure + elseif(pid.eq.psurf_index.and.tid.eq.psurf_topt) then + + call grib_get(igrib,"values",var,iret) + call LVT_verify(iret,'grib_get failed for values in readAgrmetdata') + do r=1,nr + do c=1,nc + if(var(c+(r-1)*nc).ne.9999.0) then + psurf(c+(r-1)*nc) = psurf(c+(r-1)*nc)+var(c+(r-1)*nc) + npsurf(c+(r-1)*nc) = npsurf(c+(r-1)*nc)+1 + endif + enddo + enddo + + ! MN...Support wind + elseif(pid.eq.wind_index.and.tid.eq.wind_topt) then + + call grib_get(igrib,"values",var,iret) + call LVT_verify(iret,'grib_get failed for values in readAgrmetdata') + do r=1,nr + do c=1,nc + if(var(c+(r-1)*nc).ne.9999.0) then + wind(c+(r-1)*nc) = wind(c+(r-1)*nc)+var(c+(r-1)*nc) + nwind(c+(r-1)*nc) = nwind(c+(r-1)*nc)+1 + endif + enddo + enddo + endif call grib_release(igrib,iret) @@ -634,6 +686,16 @@ subroutine readAGRMETdata(source) call LVT_logSingleDataStreamVar(LVT_MOC_qairforc,source,varfield,vlevel=1,& units="kg/kg") + ! MN...Support surface pressure + call interp_agrmetvar(source,nc,nr, psurf, npsurf, varfield) + call LVT_logSingleDataStreamVar(LVT_MOC_PSURFFORC,source,varfield,vlevel=1,& + units="Pa") + + ! MN...Support wind + call interp_agrmetvar(source,nc,nr, wind, nwind, varfield) + call LVT_logSingleDataStreamVar(LVT_MOC_WINDFORC,source,varfield,vlevel=1,& + units="m/s") + end subroutine readAGRMETdata !BOP From 6b888ed845694305f8cc9a64fb8cd2cbe986623e Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 18 Jan 2023 12:14:47 -0500 Subject: [PATCH 068/328] Documents the new COAMPS forcing data. --- lvt/configs/lvt.config.adoc | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/lvt/configs/lvt.config.adoc b/lvt/configs/lvt.config.adoc index 4ccae4c87..841a194ee 100644 --- a/lvt/configs/lvt.config.adoc +++ b/lvt/configs/lvt.config.adoc @@ -164,6 +164,7 @@ LVT output methodology: "2d gridspace" | "`THySM`" | Thermal Hydraulic disaggregation of Soil Moisture | "`MCD15A2H LAI`" | MODIS MCD15A2H LAI data | "`GRUN runoff`" | GRUN runoff data +| "`COAMPSout`" | COAMPS forcing data |=== .Example _lvt.config_ entry @@ -2315,10 +2316,32 @@ THySM data directory: ../THySM .Example _lvt.config_ entry .... + MCD15A2H data directory: ./MCD15A2H.006/2019 .... [[ssec-optue]] + +==== COAMPS forcing data + +`COAMPS output forcing directory:` specifies the location of the COAMPS output forcing data directory. + +.Example _lvt.config_ entry +.... +COAMPS output forcing directory: ../COAMPS/EU/COAMPS_forcing +.... + +`COAMPS nest id:` specifies the nest id. + +COAMPS forcing usually provides forcing for 2 nests. The first nest +is 15km resolution and the second nest is a smaller sub-domain with +a resolution of 5km. + +.Example _lvt.config_ entry +.... +COAMPS nest id: 1 +.... + === OptUE processing options This section of the config file specifies the details of the optimization and uncertainty estimation processing options, and the specicialized options to analyze outputs from the Optimization/Uncertainy Estimation algorithms. From aba41505426bd27f4a241cbd12723652c5621f0b Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 18 Jan 2023 12:19:50 -0500 Subject: [PATCH 069/328] Minor indentation fix --- lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 index 981ffbf47..ff9936914 100644 --- a/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 +++ b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 @@ -263,10 +263,10 @@ subroutine readCOAMPSoutdata(source) vlevel=1,units="Pa") call LVT_logSingleDataStreamVar(LVT_MOC_NWINDFORC,source,v10, & - vlevel=1,units="m/s") + vlevel=1,units="m/s") call LVT_logSingleDataStreamVar(LVT_MOC_EWINDFORC,source,u10, & - vlevel=1,units="m/s") + vlevel=1,units="m/s") else write(LVT_logunit,*) '[ERR] Forcing file '//trim(fname)//' not found' From fdb8624a1ef2792805c50115ae4935c3d083d2de Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Thu, 26 Jan 2023 13:47:39 -0500 Subject: [PATCH 070/328] Add MicroMet to met forcing readers Two of the LIS met forcing readers did not support the new MicroMet topographic downscaling option, which included: GDAS and MERRA2 This MicroMet option has been included and tested into those two readers. --- lis/metforcing/gdas/get_gdas.F90 | 66 +++++++++++++-------- lis/metforcing/gdas/read_gdas_elev.F90 | 12 ++-- lis/metforcing/merra2/merra2_forcingMod.F90 | 3 +- lis/metforcing/merra2/read_merra2_elev.F90 | 2 +- 4 files changed, 53 insertions(+), 30 deletions(-) diff --git a/lis/metforcing/gdas/get_gdas.F90 b/lis/metforcing/gdas/get_gdas.F90 index a242c9da9..0fc3a5cb8 100644 --- a/lis/metforcing/gdas/get_gdas.F90 +++ b/lis/metforcing/gdas/get_gdas.F90 @@ -224,10 +224,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 95 gridDesci(20) = 0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 1) endif @@ -260,10 +263,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 128 gridDesci(20) = 0.0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 2) endif @@ -296,10 +302,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 192 gridDesci(20) = 0.0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 3) endif @@ -332,10 +341,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 288 gridDesci(20) = 0.0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 4) endif @@ -368,10 +380,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 440 gridDesci(20) = 0.0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 5) endif @@ -403,10 +418,13 @@ subroutine get_gdas(n, findex) gridDesci(10) = 768.0 gridDesci(20) = 0.0 -! EMK Bug fix -! if(LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - Previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Including MicroMet downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_gdas_elev(n,findex, 6) endif diff --git a/lis/metforcing/gdas/read_gdas_elev.F90 b/lis/metforcing/gdas/read_gdas_elev.F90 index bece0d745..d998b6fc0 100644 --- a/lis/metforcing/gdas/read_gdas_elev.F90 +++ b/lis/metforcing/gdas/read_gdas_elev.F90 @@ -53,10 +53,14 @@ subroutine read_gdas_elev(n, findex, change) integer :: c,r real :: go(LIS_rc%lnc(n),LIS_rc%lnr(n)) -! EMK TEST -! if ( LIS_rc%met_ecor(findex).eq."lapse-rate") then - if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & - LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! KRA - previous: +! if(LIS_rc%met_ecor(findex).eq."lapse-rate" .or. & +! LIS_rc%met_ecor(findex) .eq. "lapse-rate and slope-aspect") then +! Addition of Micromet topographic downscaling: + if(LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then + write(LIS_logunit,*) 'Reading the GDAS elevation' if ( change == 0 ) then ! period 1980--1991 ! Note that for this time period we have a difference file diff --git a/lis/metforcing/merra2/merra2_forcingMod.F90 b/lis/metforcing/merra2/merra2_forcingMod.F90 index 8de40f393..62b62998e 100644 --- a/lis/metforcing/merra2/merra2_forcingMod.F90 +++ b/lis/metforcing/merra2/merra2_forcingMod.F90 @@ -330,7 +330,8 @@ subroutine init_merra2(findex) merra2_struc(n)%merraforc2 = LIS_rc%udef if ( LIS_rc%met_ecor(findex) == "lapse-rate" .or. & - LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" ) then + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then call read_merra2_elev(n,findex) endif diff --git a/lis/metforcing/merra2/read_merra2_elev.F90 b/lis/metforcing/merra2/read_merra2_elev.F90 index c8e6071a4..9dab0a2e2 100644 --- a/lis/metforcing/merra2/read_merra2_elev.F90 +++ b/lis/metforcing/merra2/read_merra2_elev.F90 @@ -59,7 +59,7 @@ subroutine read_merra2_elev(n,findex) if ( trim(LIS_rc%met_ecor(findex)) .ne. "none") then - write(LIS_logunit,*) 'Reading the MERRA2 elevation map ...' + write(LIS_logunit,*) '[INFO] Reading the MERRA2 elevation map ...' call LIS_read_param(n,"ELEV_MERRA2",go) From 2f15488f7827c9d5e4e0df108b25b5dd7e0991bc Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Thu, 26 Jan 2023 13:51:54 -0500 Subject: [PATCH 071/328] Change to MERRA2 reader for MicroMet add Implemented MicroMet option directly to this routine Addresses #1264 issue on GitHub LISF page. --- lis/metforcing/merra2/read_merra2_elev.F90 | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lis/metforcing/merra2/read_merra2_elev.F90 b/lis/metforcing/merra2/read_merra2_elev.F90 index 9dab0a2e2..a195818c9 100644 --- a/lis/metforcing/merra2/read_merra2_elev.F90 +++ b/lis/metforcing/merra2/read_merra2_elev.F90 @@ -57,9 +57,12 @@ subroutine read_merra2_elev(n,findex) integer :: c,r real :: go(LIS_rc%lnc(n),LIS_rc%lnr(n)) - if ( trim(LIS_rc%met_ecor(findex)) .ne. "none") then +! if ( trim(LIS_rc%met_ecor(findex)) .ne. "none") then + if ( LIS_rc%met_ecor(findex) == "lapse-rate" .or. & + LIS_rc%met_ecor(findex) == "lapse-rate and slope-aspect" .or. & + LIS_rc%met_ecor(findex) == "micromet" ) then - write(LIS_logunit,*) '[INFO] Reading the MERRA2 elevation map ...' + write(LIS_logunit,*) '[INFO] Reading the MERRA2 elevation map ' call LIS_read_param(n,"ELEV_MERRA2",go) From 16dcc6b2a1d9e6a5e23991808e76b0a861197634 Mon Sep 17 00:00:00 2001 From: Shahryar Khalique Ahmad Date: Thu, 2 Feb 2023 17:09:19 -0500 Subject: [PATCH 072/328] Update landcover options in doc to include MCD12Q1 --- ldt/configs/ldt.config.adoc | 92 +++++-------------------------------- 1 file changed, 11 insertions(+), 81 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8c0695d5e..6b3535e5e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -418,33 +418,19 @@ The default value is 0. Add buffer to parameter grid domain: 0 .... -`Buffer count in x-direction:` adds a set number of pixels that buffer -around a parameter file target domain in the x-direction. +`Buffer count in x-direction:` adds a set number of pixels that buffer +around a parameter file target domain, both in the x- and y-directions. Acceptable values are: [cols="<,<",] |=== |Value |Description -|0 |Results in no buffer added -|1 (or greater) |Buffer points included -|=== - -The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. - -`Buffer count in y-direction:` adds a set number of pixels that buffer -around a parameter file target domain in the y-direction. -Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|0 |Results in no buffer added -|1 (or greater) |Buffer points included +|"`0`" |No buffer added +|"`1`" (or greater) |Buffer points included |=== -The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. +The default value is 5, and only activated if buffer option is selected. .Example _ldt.config_ entry .... @@ -765,6 +751,7 @@ endif::devonly[] |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. |MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. +|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. |USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html @@ -806,6 +793,11 @@ Landcover classification: "UMD" `Landcover file:` specifies the location of the vegetation classification file. +.Example _ldt.config_ entry +.... +Landcover file: ./MODIS/MCD12Q1.006/2001/MCD12Q1.006_2001001.nc4 +.... + `Landcover map projection:` specifies the projection of the landcover map data. `Landcover spatial transform:` indicates which spatial transform (i.e., upscale or downscale) type is to be applied to the landcover map. Options include: @@ -1621,20 +1613,6 @@ Soil texture spatial transform: none `Soil texture fill value:` indicates which soil texture value to be used if an arbitrary value fill is needed. (For example, when the landmask indicates a land point but no existing soil texture value, a value of 6 could be assigned if no nearest neighbor values exists to fill). -`Soil texture fill value for Antarctica:` indicates which soil texture value to be used if an arbitrary value fill is needed south of 60S. If not specified, value of `Soil texture fill value:` will be used. - -`Soil texture force exclusion of water points during fill:` indicates whether to force exclusion of water points when filling soil texture. Required when using STATSGOFAO south of 60S (texture is set to all water) and multiple surface model types are used. - -[cols="<,<",] -|=== -|Value |Description - -|.false. |do not enable -|.true. |enable -|=== - -Defaults to `.false.`. - `Soil texture fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. .Example _ldt.config_ entry @@ -1642,8 +1620,6 @@ Defaults to `.false.`. Soil texture fill option: neighbor Soil texture fill radius: 3. Soil texture fill value: 6. -Soil texture fill value for Antarctica: 16 -Soil texture force exclusion of water points during fill: .true. .... If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. @@ -2865,7 +2841,6 @@ Climatology parameter maps |PRISM |PRISM US-only climate downscaled fields. For more info, see: http://www.prism.oregonstate.edu/ |WORLDCLIM |Global climate layers downscaled. For more info, see: http://www.worldclim.org/ -|NAFPA_BACK_GALWEM|US Air Force GALWEM NWP fields on 10-km NAFPA grid (Oct2017-May2022). |=== `PPT climatology maps:` specifies the source of the climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: @@ -2880,11 +2855,6 @@ WORLDCLIM: /..1gd4r * The file header can be prec_ * The tag should represent the month (such as 1, 2,..., 12). -NAFPA_BACK_GALWEM: /..d01.nc - -* The field header is SUM_TS -* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). - `PPT climatology interval:` specifies the frequency of the precipitation climatology in months. Current option is: "`monthly`" .Example _ldt.config_ entry @@ -2894,34 +2864,6 @@ PPT climatology maps: ../LS_PARAMETERS/climate_maps/ppt_1981_2010 PPT climatology interval: monthly .... -`PPT climatology data source 2:` specifies the second monthly precipitation (PPT) climatology fields, for calculating bias ratios. Current source options include: - -[cols="<,<",] -|=== -|Value |Description - -|NLDAS |NOAA NLDAS-2 fields -|NAFPA_BACK_GFS|NOAA GFS NWP fields on 10-km NAFPA grid (Oct2017-May2022). -|=== - -`PPT climatology maps 2:` specifies the source of the second group climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: - -NLDAS: /..txt - -* The file header can be anything (such as ppt_1931_2010). -* The tag should represent the month (such as jan, feb, mar, etc.). - -NAFPA_BACK_GFS: /..d01.nc - -* The field header is SUM_TS -* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). - -.Example _ldt.config_ entry -.... -PPT climatology data source 2: NAFPA_BACK_GFS -PPT climatology maps 2: ./METRICS_GFS/ -.... - `TMIN climatology maps:` specifies the source of the climatology based minimum temperature files. `TMAX climatology maps:` specifies the source of the climatology based maximum temperature files. @@ -3672,22 +3614,10 @@ NASA AMSRE soil moisture observation directory: ./NASA_AMSRE `ESA CCI soil moisture version of data:` specifies the version of the ESA CCI soil moisture dataset. -`ESA CCI soil moisture sensor type:` specifies the sensor type of the ESA CCI soil moisture dataset. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|"`passive`" | passive sensor type -|"`active`" | active sensor type -|"`combined`" | combined sensor type -|=== - .Example _ldt.config_ entry .... ESA CCI soil moisture observation directory: ./ECV ESA CCI soil moisture version of data: EXAMPLE -ESA CCI soil moisture sensor type: combined .... `GCOMW AMSR2 L3 soil moisture observation directory:` specifies the location of the data directory containing the GCOMW AMSR v2 L3 soil moisture data. From 4810fc8c4fc9be2c922e72b8bed60ebb95d8c680 Mon Sep 17 00:00:00 2001 From: Shahryar Khalique Ahmad Date: Thu, 2 Feb 2023 20:58:28 -0500 Subject: [PATCH 073/328] Update landcover options in doc --- ldt/configs/ldt.config.adoc | 505 +++++++++++++++++++++++++++++++++--- 1 file changed, 469 insertions(+), 36 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 6b3535e5e..5f9b04ee3 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -28,6 +28,7 @@ Not all options described here are available in the public version of LDT. |"`OPTUE parameter processing`" |Process the OPT/UE output to generate optimized parameters |"`USAFSI analysis`" |USAF Snow and Ice analysis |"`LISHydro preprocessing for WRFHydro`" |Preprocessing Option for WRFHydro +|"`OPL E SMAP soil moisture retrieval`" |Operational 9-km enhanced SMAP soil moisture retrieval |=== .Example _ldt.config_ entry @@ -35,7 +36,7 @@ Not all options described here are available in the public version of LDT. LDT running mode: "LSM parameter processing" .... -`Processed LSM parameter filename:` specifies the output filename (with netcdf extension) of the LSM parameters processed in LDT to go into LIS. See a sample _lis_input.d01.nc_ (Appendix <>) file for a complete specification description. +`Processed LSM parameter filename:` specifies the output filename (with netcdf extension) of the LSM parameters processed in LDT to go into LIS. See a sample _lis_input.d01.nc_ (Appendix <>) file for a complete specification description. .Example _ldt.config_ entry .... @@ -93,6 +94,7 @@ Surface model types: "LSM" |Mosaic |Mosaic |HySSIB |HySSIB |CLSMF2.5 |Catchment, Fortuna 2.5 +|SnowModel |SnowModel |SAC.3.5.6 |Sacramento |SNOW17 |Snow17 |RDHM.3.5.6 |Sacramento+snow17 @@ -365,7 +367,7 @@ Forcing climatology temporal frequency of data: "6hr" Bayesian merging seasonal stratification type: .... -`Forcing variables list file:` specifies the file containing the list of forcing variables to be used. (Please refer to Section "`Specification of Input Forcing Variables`" in the _LIS Users' Guide_ for a complete specification description of this file.) +`Forcing variables list file:` specifies the file containing the list of forcing variables to be used. (Please refer to Section "`Specification of Input Forcing Variables`" in the _LIS Users' Guide_ for a complete specification description of this file.) .Example _ldt.config_ entry .... @@ -418,19 +420,33 @@ The default value is 0. Add buffer to parameter grid domain: 0 .... -`Buffer count in x-direction:` adds a set number of pixels that buffer -around a parameter file target domain, both in the x- and y-directions. +`Buffer count in x-direction:` adds a set number of pixels that buffer +around a parameter file target domain in the x-direction. Acceptable values are: [cols="<,<",] |=== |Value |Description -|"`0`" |No buffer added -|"`1`" (or greater) |Buffer points included +|0 |Results in no buffer added +|1 (or greater) |Buffer points included |=== -The default value is 5, and only activated if buffer option is selected. +The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. + +`Buffer count in y-direction:` adds a set number of pixels that buffer +around a parameter file target domain in the y-direction. +Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|0 |Results in no buffer added +|1 (or greater) |Buffer points included +|=== + +The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. .Example _ldt.config_ entry .... @@ -602,7 +618,7 @@ Output naming style: "3 level hierarchy" [[ssec-domainspec]] === Domain specification -This section of the config file specifies the LIS running domain (domain over which the simulation is carried out). The specification of the LIS Run domain section depends on the type of LIS domain and projection used. Section <> lists the projections that LIS supports. +This section of the config file specifies the LIS running domain (domain over which the simulation is carried out). The specification of the LIS Run domain section depends on the type of LIS domain and projection used. Section <> lists the projections that LIS supports. `Map projection of the LIS domain:` specifies the output LIS domain grid to be used with LIS. Acceptable values are: @@ -630,7 +646,7 @@ Map projection of the LIS domain: latlon [[sssec-run_latlon]] ==== Cylindrical lat/lon -This section describes how to specify a cylindrical latitude/longitude projection. See Appendix <> for more details about setting these values. +This section describes how to specify a cylindrical latitude/longitude projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -645,7 +661,7 @@ Run domain resolution (dy): 0.25 [[sssec-run_lambert]] ==== Lambert conformal -This section describes how to specify a Lambert conformal projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Lambert conformal projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -662,7 +678,7 @@ Run domain y-dimension size: 30 [[sssec-run_gaussian]] ==== Gaussian -This section describes how to specify a Gaussian projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Gaussian projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -677,7 +693,7 @@ Run domain number of lat circles: 95 [[sssec-run_ps]] ==== Polar stereographic -This section describes how to specify a polar stereographic projection. See Appendix <> for more details about setting these values. +This section describes how to specify a polar stereographic projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -694,7 +710,7 @@ Run domain y-dimension size: 30 [[sssec-run_hrap]] ==== HRAP -This section describes how to specify a HRAP projection. See Appendix <> for more details about setting these values. +This section describes how to specify a HRAP projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -708,7 +724,7 @@ Run domain y-dimension size: 774 [[sssec-run_mercator]] ==== Mercator -This section describes how to specify a Mercator projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Mercator projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -725,7 +741,7 @@ ifdef::devonly[] [[sssec-run_utm]] ==== UTM -This section describes how to specify a UTM projection. See Appendix <> for more details about setting these values. +This section describes how to specify a UTM projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -751,7 +767,7 @@ endif::devonly[] |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. |MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. -|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. +|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. |USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html @@ -759,6 +775,8 @@ endif::devonly[] |VIC412 |Variable Infiltration Capacity model, v4.1.2, UMD land cover. |ISA |Impervious Surface Area (ISA) landcover dataset. |CLM45 |CLM-4.5 landcover dataset. +|NALCMS_SM |SnowModel-based NALCMS landcover dataset. +|NALCMS_SM_IGBPNCEP |SnowModel-based NALCMS landcover dataset with IGBPNCEP-mapped classes. |CONSTANT |Ability to set a constant landcover type for a set classification. |=== @@ -841,7 +859,7 @@ Landcover fill radius: 3. # Number of pixels to search for neighbor Landcover fill value: 5. # Static value to fill where missing .... -This section also outlines the domain specifications of the landcover (and for now landmask) data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying landcover data. Note: The Landcover grid domain inputs below are really only required for the "`_LIS`" data source options and that do not include "`_Native`" in the data source entries. All native parameters do not require the below inputs for LDT. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of the landcover (and for now landmask) data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying landcover data. Note: The Landcover grid domain inputs below are really only required for the "`_LIS`" data source options and that do not include "`_Native`" in the data source entries. All native parameters do not require the below inputs for LDT. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -910,7 +928,7 @@ Landmask map projection: latlon This section also outlines the domain specifications of the land water/mask data. The landmask map projection and extents are only needed if you specify "`readin`" for mask type and if the landmask data source is "`MOD44W`" or "`_LIS`". -If the map projection of parameter data is specified to be "`latlon`", the following extents and resolution configuration should be used for specifying landmask data. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be "`latlon`", the following extents and resolution configuration should be used for specifying landmask data. See Appendix <> for more details about setting these values. Future landmask data sets will have the projection, grid extents and resolution on the data reader side and not needed to be specified in the _ldt.config_ file, depending on the data source. @@ -1036,7 +1054,7 @@ Inland waterbody spatial transform: tile Regional mask data source: "none" .... -`Regional mask file:` specifies the location of a regional mask file. This file can be either an index-based state, country, basin, catchment, etc. map used to mask further beyond the main water/land mask. +`Regional mask file:` specifies the location of a regional mask file. This file can be either an index-based state, country, basin, catchment, etc. map used to mask further beyond the main water/land mask. .Example _ldt.config_ entry .... @@ -1075,7 +1093,7 @@ Regional mask spatial transform: mode This section also outlines the domain specifications of the regional-based land mask data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying regional mask data. -See Appendix <> for more details about setting these values. +See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1317,7 +1335,7 @@ Irrigation fraction map projection: latlon .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying irrigation data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying irrigation data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1489,7 +1507,7 @@ Soils fill value: 0.33 Porosity fill value: 0.30 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soils data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soils data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1613,6 +1631,20 @@ Soil texture spatial transform: none `Soil texture fill value:` indicates which soil texture value to be used if an arbitrary value fill is needed. (For example, when the landmask indicates a land point but no existing soil texture value, a value of 6 could be assigned if no nearest neighbor values exists to fill). +`Soil texture fill value for Antarctica:` indicates which soil texture value to be used if an arbitrary value fill is needed south of 60S. If not specified, value of `Soil texture fill value:` will be used. + +`Soil texture force exclusion of water points during fill:` indicates whether to force exclusion of water points when filling soil texture. Required when using STATSGOFAO south of 60S (texture is set to all water) and multiple surface model types are used. + +[cols="<,<",] +|=== +|Value |Description + +|.false. |do not enable +|.true. |enable +|=== + +Defaults to `.false.`. + `Soil texture fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. .Example _ldt.config_ entry @@ -1620,9 +1652,11 @@ Soil texture spatial transform: none Soil texture fill option: neighbor Soil texture fill radius: 3. Soil texture fill value: 6. +Soil texture fill value for Antarctica: 16 +Soil texture force exclusion of water points during fill: .true. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1659,7 +1693,7 @@ Soil color map: Soil color spatial transform: none .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil color data, data source option "`FAO`" or has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil color data, data source option "`FAO`" or has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1696,6 +1730,7 @@ Current options include: |SRTM_LIS |Similar dataset as to the above one but processed by LISF-team. |CONSTANT |User can set a constant elevation, slope or aspect class. |MERIT_1K |The MERIT elevation map, but processed by LISF-team to have a resolution '`0.008333`'. See: http://hydro.iis.u-tokyo.ac.jp/~yamadai/MERIT_DEM/index.html +|NED_SM | SnowModel-based National Elevation Dataset (NED) topographic fields. |=== .Example _ldt.config_ entry @@ -1824,7 +1859,7 @@ Aspect fill value: 2.0 Topography spatial transform: tile .... -This section should also specify the domain specifications of the topography data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying topography data, especially if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +This section should also specify the domain specifications of the topography data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying topography data, especially if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1923,7 +1958,7 @@ Albedo fill radius: 2. Albedo fill value: 0.12 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying albedo data where the albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying albedo data where the albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1994,7 +2029,7 @@ Max snow albedo fill radius: 3. Max snow albedo fill value: 0.42 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying max snow albedo data, where the max snow albedo albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying max snow albedo data, where the max snow albedo albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2095,7 +2130,7 @@ Greenness maximum fill value: 0.80 Greenness minimum fill value: 0.05 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying greenness data source, if the option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying greenness data source, if the option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2208,7 +2243,7 @@ LAI maximum fill value: 4 LAI minimum fill value: 1 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying LAI/SAI data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying LAI/SAI data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2276,7 +2311,7 @@ Slope type fill radius: 2. Slope type fill value: 1. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying slope type data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying slope type data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2362,7 +2397,7 @@ Bottom temperature fill value: 287.0 Bottom temperature topographic downscaling: none .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying bottom temperature parameter data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying bottom temperature parameter data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2382,6 +2417,136 @@ Bottom temperature resolution (dy): 0.2500 Noah-MP PBL Height Value: 900. # in meters .... +Miguez-Macho and Fan (MMF) Groundwater Parameters + +IMPORTANT: Currently, Noah-MP.4.0.1 is the only land surface model that supports the MMF groundwater scheme. + +`Process Noah-MP-4.0.1 MMF groundwater parameters:` specifies whether to process Noah-MP-4.0.1 MMF groundwater parameters. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|.false. | do not process (default) +|.true. | process +|=== + +.Example _ldt.config_ entry +.... +Process Noah-MP-4.0.1 MMF groundwater parameters: .true. +.... + +[NOTE] +==== +The Noah-MP-4.0.1 parameters are only needed when running option "5" for the following lis.config entry when running LIS: + +`Noah-MP.4.0.1 runoff and groundwater option: 5` + +// TODO: remove following admonition when MMF groundwater option 5 is implemented in LIS +IMPORTANT: The MMF groundwater option (option 5) is not yet supported in LIS. Work on this feature is currently in progress. +==== + +`MMF transmissivity dir:` specifies the location of the directory containing FDEPTH (transmissivity e-folding depth [m]) data on GEOGRID tiles. + +`MMF climatological recharge dir:` specifies the location of the directory containing RECHARGE (climatological recharge [mm]) data on GEOGRID tiles. + +`MMF riverbed elevation dir:` specifies the location of the directory containing RIVERBED (riverbed elevation [m]) data on GEOGRID tiles. + +`MMF equilibrium water table depth dir:` specifies the location of the directory containing EQWTD (equilibrium water table depth [m]) data on GEOGRID tiles. + +`MMF HGT_M dir:` specifies the location of the directory containing GMTED2010 (30-arc-second topography height [m from MSL]) data on GEOGRID tiles. + +.Example _ldt.config_ entry +.... +MMF transmissivity dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/f/ +MMF climatological recharge dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/recharge/ +MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed/ +MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/wtd/ +MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ +.... + +[NOTE] +==== +Spatial interpolation and gap filling parameters for each MMF variable are also required. See the config entries below. + +link:https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL[The WRF User's Guide, window=_blank] (and link:https://github.com/wrf-model/WPS/blob/master/geogrid/GEOGRID.TBL.ARW.noahmp[WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp, window=_blank]) describe WPS's MMF parameter preprocessing procedures from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native GEOGRID space makes it fundamentally different to LDT because LDT first aggregates input data from the native grid to the model grid and then fills gaps on the model grid space. The current LDT implementation of MMF parameter preprocessing does not attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. +==== + +`MMF map projection:` map projection parameter is always set to latlon for MMF parameters. + +`MMF spatial transform:` spatial transform parameter is always set to average for MMF parameters. + +.Example _ldt.config_ entry +.... +MMF map projection: latlon +MMF spatial transform: average +.... + +`FDEPTH fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`FDEPTH fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). + +`FDEPTH fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`FDEPTH water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable FDEPTH value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. + +.Example _ldt.config_ entry +.... +FDEPTH fill option: neighbor +FDEPTH fill radius: 0. +FDEPTH fill value: 100. +FDEPTH water value: 100. +.... + + +`RECHCLIM fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`RECHCLIM fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). + +`RECHCLIM fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`RECHCLIM water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable RECHCLIM value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. + +.Example _ldt.config_ entry +.... +RECHCLIM fill option: neighbor +RECHCLIM fill radius: 0. +RECHCLIM fill value: -1. +RECHCLIM water value: -1. +.... + + +`EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`EQWTD fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`EQWTD fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + +`EQWTD water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable EQWTD value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. + +.Example _ldt.config_ entry +.... +EQWTD fill option: neighbor +EQWTD fill radius: 0. +EQWTD fill value: 0. +EQWTD water value: 0. +.... + + +`HGT_M fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). + +`HGT_M fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. + +`HGT_M fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. + + +.Example _ldt.config_ entry +.... +HGT_M fill option: neighbor +HGT_M fill radius: 0. +HGT_M fill value: 0. +.... + If selecting the Community Land Model (4.5 version), the following config entires are also required. `CLM45 parameter mode:` specifies whether to "`readin`" the CLM-4.5 parameters from pre-processed files. Currently, only the "`readin`" option is available. @@ -2428,6 +2593,27 @@ CLM45 resolution (dx): 1.25 CLM45 resolution (dy): 0.9424060 .... +If selecting Glen Liston's SnowModel, the following config entires are required. + +`Snowmodel topo-veg data source:` specifies which pre-processed SnowModel parameters and file format type to be read in. Currently, only the "`Grads_binary`" option is available. + +`Snowmodel topo-veg map:` specifies the directory-file location of the pre-processed SnowModel topographic and vegetation class parameters. + +`Snowmodel topo-veg spatial transform:` specifies the type of grid transform for preprocessed SnowModel topographic and vegetation class parameters. Currently, this option is not yet supported and user option is only "`none`" at this time. + +`Snowmodel topo-veg map projection:` specifies the SnowModel parameter file projection. Currently, SnowModel parameter projection needs to be set to the same as the LIS domain projection, for now. SnowModel parameters are best provided either on a Lambert projection (in LIS) and supports some equal-area projection grids, like UTM, which is available in LIS. Future support for more options will be added. + +`Snowmodel topo-veg fill option:` specifies the type of fill option used with SnowModel parameters. Currently, this feature is not supported, and will be in future versions. + +.Example _ldt.config_ entry +.... +Snowmodel topo-veg data source: "Grads_binary" +Snowmodel topo-veg map: ../SnowModel_Inputs/uppertuo_100m/topo_vege.gdat +Snowmodel topo-veg spatial transform: "none" +Snowmodel topo-veg map projection: lambert +Snowmodel topo-veg fill option: none +.... + Potential Evapotranspiration (PET) maps `PET directory:` specifies the source of the monthly climatology based PET files. The climatology data files have the following naming convention: /..1gd4r. The tag should be represent the month (such as JAN, FEB, MAR, etc.). The file header can be anything (such as avhrr_pet_1KM). Currently, this parameter is used only with the RDHM-SAC model. @@ -2476,7 +2662,7 @@ PET fill radius: 3 PET fill value: 10. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying PET data. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying PET data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2548,7 +2734,7 @@ CLSMF25 top soil layer depth: 0.02 CLSMF25 spatial transform: none .... -This section also outlines the domain specifications of the Catchment LSM Fortuna 2.5 data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying CLSM data. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of the Catchment LSM Fortuna 2.5 data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying CLSM data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2841,6 +3027,7 @@ Climatology parameter maps |PRISM |PRISM US-only climate downscaled fields. For more info, see: http://www.prism.oregonstate.edu/ |WORLDCLIM |Global climate layers downscaled. For more info, see: http://www.worldclim.org/ +|NAFPA_BACK_GALWEM|US Air Force GALWEM NWP fields on 10-km NAFPA grid (Oct2017-May2022). |=== `PPT climatology maps:` specifies the source of the climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: @@ -2855,6 +3042,11 @@ WORLDCLIM: /..1gd4r * The file header can be prec_ * The tag should represent the month (such as 1, 2,..., 12). +NAFPA_BACK_GALWEM: /..d01.nc + +* The field header is SUM_TS +* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). + `PPT climatology interval:` specifies the frequency of the precipitation climatology in months. Current option is: "`monthly`" .Example _ldt.config_ entry @@ -2864,6 +3056,34 @@ PPT climatology maps: ../LS_PARAMETERS/climate_maps/ppt_1981_2010 PPT climatology interval: monthly .... +`PPT climatology data source 2:` specifies the second monthly precipitation (PPT) climatology fields, for calculating bias ratios. Current source options include: + +[cols="<,<",] +|=== +|Value |Description + +|NLDAS |NOAA NLDAS-2 fields +|NAFPA_BACK_GFS|NOAA GFS NWP fields on 10-km NAFPA grid (Oct2017-May2022). +|=== + +`PPT climatology maps 2:` specifies the source of the second group climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: + +NLDAS: /..txt + +* The file header can be anything (such as ppt_1931_2010). +* The tag should represent the month (such as jan, feb, mar, etc.). + +NAFPA_BACK_GFS: /..d01.nc + +* The field header is SUM_TS +* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). + +.Example _ldt.config_ entry +.... +PPT climatology data source 2: NAFPA_BACK_GFS +PPT climatology maps 2: ./METRICS_GFS/ +.... + `TMIN climatology maps:` specifies the source of the climatology based minimum temperature files. `TMAX climatology maps:` specifies the source of the climatology based maximum temperature files. @@ -2892,7 +3112,7 @@ TMAX climatology maps: Climate params spatial transform: average .... -This section also outlines the domain specifications of climatology-based parameters, like higher scaled monthly precipitation or min/max temperatures. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying climatology data. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of climatology-based parameters, like higher scaled monthly precipitation or min/max temperatures. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying climatology data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -3382,6 +3602,11 @@ LIS output timestep: 1da |"`NASA SMAP vegetation optical depth`" |NASA SMAP vegetation optical depth observations (units in "`-`") |"`SMOS NRT NN soil moisture`" | SMOS Level 2 Soil Moisture Near Real Time Neural Network |"`THySM soil moisture`" | Thermal Hydraulic disaggregation of Soil Moisture +|"`SMAP_E_OPL soil moisture`" | Operational 9-km enhanced SMAP soil moisture retrieval +|"`GEOS effective soil temperature`" | GEOS-FP effective soil temperature +|"`CDFS GVF`" | CDFS green vegetation fraction (GVF) +|"`VIIRS GVF`" | VIIRS green vegetation fraction (GVF) +|"`LIS LSM effective soil temperature`" | Soil temperature output from a LIS run |=== .Example _ldt.config_ entry @@ -3427,6 +3652,7 @@ Number of bins to use in the CDF: 100 |monthly |stratify for each calendar month |yearly |lump (considering all years and all seasons) +|half-monthly | stratify for each calendar half-month (for SMAP_E_OPL) |=== .Example _ldt.config_ entry @@ -3434,6 +3660,8 @@ Number of bins to use in the CDF: 100 Temporal resolution of CDFs: monthly .... +`Daily interpolation of mean and stddev:` specifies whether daily interpolation of mean and standrd deviation is conducted when 'Temporal resolution of CDFS:' is set to 'half-monthly'. This should be '1' to generate statistics of effective soil temperature (Teff), which are used to scale the LIS Teff during generating the SMAP_E_OPL soil moisture retrievals + `Enable spatial sampling for CDF calculations:` Normally CDFs are calculated (for a given grid cell) by using the data values available at that grid point only. If this option is enabled, then values around a specified radius will be used in the CDF calculations, effectively improving the sampling density at the risk of reduced geographic specificity. .Example _ldt.config_ entry @@ -3583,6 +3811,68 @@ LIS soil moisture area of data: LIS soil moisture write interval: .... +`LIS soil temperature output model name:` specifies the model name used to simulate soil temperature + +`LIS soil temperature output directory:` specifies the location of the LIS model output. + +`LIS soil temperature output format:` specifies the output format of the LIS model output. (binary/netcdf/grib1) + +`LIS soil temperature output methodology:` specifies the output methodology used in the LIS model output (1d tilespace/1d gridspace/2d gridspace). + +`LIS soil temperature output naming style:` specifies the output naming style used in the LIS model output (3 level hierarchy/4 level hierarchy, etc.). + +`LIS soil temperature output nest index:` specifies the index of the nest used in the LIS model output. + +`LIS soil temperature output map projection:` specifies the map projection used in the LIS model output. + +`LIS soil temperature domain lower left lat:` specifies the lower left latitude of the LIS model outpu. + +`LIS soil temperature domain upper right lat:` specifies the upper right latitude of the LIS model output. + +`LIS soil temperature domain lower left lon:` specifies the lower left longitude of the LIS model output. + +`LIS soil temperature domain upper right lon` specifies the upper right longitude of the LIS model output. + +`LIS soil temperature domain resolution (dx):` specifies the resolution (in degrees) along the latitude of the LIS model output. + +`LIS soil temperature domain resolution (dy):` specifies the resolution (in degrees) along the longitude of the LIS model output. + +For Lambert and polar projections: + +`LIS soil temperature domain lower left lat:` specifies the lower left latitude of the LIS model output + +`LIS soil temperature domain lower left lon:` specifies the lower left longitude of the LIS model output + +`LIS soil temperature domain true lat1:` specifies the true lat1 of the LIS model output + +`LIS soil temperature domain true lat2:` specifies the true lat2 of the LIS model output + +`LIS soil temperature domain standard lon:` specifies the standard longitude of the LIS model output + +`LIS soil temperature domain resolution:` specifies the resolution of the LIS model output + +`LIS soil temperature domain x-dimension size:` specifies the x-dimension size of the LIS model output + +`LIS soil temperature domain y-dimension size:` specifies the y-dimension size of the LIS model output + +.Example _ldt.config_ entry +.... +LIS soil temperature output model name: "Noah.3.9" +LIS soil temperature output directory: ../OL/OUTPUT +LIS soil temperature output format: "netcdf" +LIS soil temperature output methodology: "2d gridspace" +LIS soil temperature output naming style: "3 level hierarchy" +LIS soil temperature output nest index: 1 +LIS soil temperature output map projection: "latlon" + +LIS soil temperature domain lower left lat: -89.9531250 +LIS soil temperature domain upper right lat: 89.9531250 +LIS soil temperature domain lower left lon: -179.9296875 +LIS soil temperature domain upper right lon: 179.9296875 +LIS soil temperature domain resolution (dx): 0.1406250 +LIS soil temperature domain resolution (dy): 0.0937500 +.... + `Synthetic soil moisture observation directory:` specifies the location of the data directory containing the synthetic soil moisture data. `Synthetic soil moisture observation timestep:` specifies the timestep of the synthetic soil moisture observations. @@ -3614,10 +3904,22 @@ NASA AMSRE soil moisture observation directory: ./NASA_AMSRE `ESA CCI soil moisture version of data:` specifies the version of the ESA CCI soil moisture dataset. +`ESA CCI soil moisture sensor type:` specifies the sensor type of the ESA CCI soil moisture dataset. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|"`passive`" | passive sensor type +|"`active`" | active sensor type +|"`combined`" | combined sensor type +|=== + .Example _ldt.config_ entry .... ESA CCI soil moisture observation directory: ./ECV ESA CCI soil moisture version of data: EXAMPLE +ESA CCI soil moisture sensor type: combined .... `GCOMW AMSR2 L3 soil moisture observation directory:` specifies the location of the data directory containing the GCOMW AMSR v2 L3 soil moisture data. @@ -3988,7 +4290,7 @@ LPRM vegetation optical depth data designation: 'X-band' .Example _ldt.config_ entry .... -MOS NRT NN soil moisture observation directory: ./SMOS_NRT_NN +SMOS NRT NN soil moisture observation directory: ./SMOS_NRT_NN .... `SMOS NRT NN search radius for openwater proximity detection:` specifies the radius in which LDT search to detect open water. Then removes all pixels within the radius in the CDF calculations. @@ -4005,6 +4307,41 @@ SMOS NRT NN search radius for openwater proximity detection: 3 THySM observation directory: ../THySM .... +`SMAP_E_OPL soil moisture observation directory:` specifies the location of the data directory containing the SMAP_E_OPL soil moisture data + +.Example _ldt.config_ entry +.... +SMAP_E_OPL soil moisture observation directory: ../SMAP_E_OPL_noah39 +.... + +`SMAP_E_OPL search radius for openwater proximity detection:` specifies the radius in which LDT search to detect open water. Then removes all pixels within the radius in the CDF calculations + +.Example _ldt.config_ entry +.... +SMAP_E_OPL search radius for openwater proximity detection: 3 +.... + +`GEOS soil temperature data directory:` specifies the location of the data directory containing the GEOS-FP soil temperature data + +.Example _ldt.config_ entry +.... +GEOS soil temperature data directory: ./GEOS +.... + +`CDFS GVF data directory:` specifies the location of the data directory containing the CDFS GVF data + +.Example _ldt.config_ entry +.... +CDFS GVF data directory: ./CDFS_GVF +.... + +`VIIRS GVF data directory:` specifies the location of the data directory containing the VIIRS GVF data + +.Example _ldt.config_ entry +.... +VIIRS GVF data directory: ./VIIRS_GVF +.... + [[ssec-hymapopts]] === HYMAP routing options @@ -4079,7 +4416,7 @@ HYMAP river flow type map: ../HYMAP_parms/lis_rivflw_0125.bin This section also outlines the domain specifications of the HYMAP parameter data. For the HYMAP parameters spatial transform option, only "`none`" is supported at this time, and the user is required to input the HYMAP parameters at the grid and resolution of interest. -If the map projection of parameter data is specified to be "`latlon`", the following configuration should be used for specifying HYMAP parameters. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be "`latlon`", the following configuration should be used for specifying HYMAP parameters. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -4628,3 +4965,99 @@ Sentinel1A OSSE mask data resolution (km): 1 TSSM OSSE mask directory: ../Masks/TSSM/ TSSM OSSE mask data resolution (km): 1 .... + +[[ssec-smap_e_opl]] +=== Operational 9-km enhanced SMAP soil moisture retrieval + +`SMAP_E_OPL valid date (YYYYMMDDHH):` valid date and hour (UTC) of SMAP L1B data + +`SMAP_E_OPL soil moisture output directory:` specifies a directory where soil moisture retrieval outputs are saved + +`SMAP_E_OPL L1B data directory:` specifies a directory containing the SMAP L1B data + +`SMAP_E_OPL L1B data type:` specifies the L1B data type. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|1 |Near real time data +|2 |Historical data +|=== + +`SMAP_E_OPL write L1B resampled output:` specifies whether to write L1B resampled output or not. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|0 |Do not write L1B resampled output +|1 |Write L1B resampled output +|=== + +`SMAP_E_OPL L1B resampled output directory:` specifies a L1B resampled output directory when 'SMAP_E_OPL write L1B resampled output: 1' + +`SMAP_E_OPL LIS soil temperature directory:` specifies a directory containing LIS soil temperature outputs + +`SMAP_E_OPL apply soil temperature bias correction:` specifies whether soil temperature bias correction is applied or not. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|0 |Do not apply soil temperature bias correction +|1 |Apply soil temperature bias correction +|=== + +`SMAP_E_OPL reference Teff daily statistics file:` specifies a directory and filename of the reference effective soil temperature (Teff) daily statistics file + +`SMAP_E_OPL LIS Teff daily statistics file:` specifies a directory and filename of the LIS Teff daily statistics file + +`SMAP_E_OPL LIS snow directory:` specifies a directory containing LIS snow outputs + +`SMAP_E_OPL snow depth threshold:` specifies a snow depth threshold (unit: m). Soil moisture retrievals are not generate for grid cells with snow depth greater than the threshold. + +`SMAP_E_OPL TAU directory:` specifies a directory containing the pre-processed TAU data + +`SMAP_E_OPL OMEGA file:` specifies a directory and filename of the pre-processed OMEGA data + +`SMAP_E_OPL soil bulk density file:` specifies a directory and filename of the pre-processed soil bulk density data + +`SMAP_E_OPL soil clay fraction file:` specifies a directory and filename of the pre-processed soil clay fraction data + +`SMAP_E_OPL roughness file:` specifies a directory and filename of the pre-processed roughness data + +`SMAP_E_OPL landcover file:` specifies a directory and filename of the pre-processed land cover data + +.Example _ldt.config_ entry +.... +SMAP_E_OPL valid date (YYYYMMDDHH): 2015060312 +SMAP_E_OPL soil moisture output directory: ./SM_retrieval +SMAP_E_OPL L1B data directory: ../SMAP_L1B_TB +SMAP_E_OPL L1B data type: 1 +SMAP_E_OPL write L1B resampled output: 0 +SMAP_E_OPL L1B resampled output directory: ./ARFS_RESAMPLE +SMAP_E_OPL LIS soil temperature directory: ../Noah39_OL +SMAP_E_OPL apply soil temperature bias correction: 1 +SMAP_E_OPL reference Teff daily statistics file: ../geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: ../noah39_daily_statistics_15obs.nc +SMAP_E_OPL LIS snow directory: ../Noah39_snow +SMAP_E_OPL snow depth threshold: 0.05 +SMAP_E_OPL TAU directory: ../../data/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: ../../data/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: ../../data/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: ../../data/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: ../../data/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: ../../data/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin +.... + + + + + + + + + + + From 9d9c09742d69895cdba032cb619bc1f7101cc95d Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Fri, 3 Feb 2023 17:20:58 -0500 Subject: [PATCH 074/328] Reverts plugin files from accidental changes Work was done on a branch that was not up to date with master. This commit reverts two plugin files to master, then applied the needed updates for PR #1186 --- ldt/plugins/LDT_param_pluginMod.F90 | 18 ++++++++++++++++-- ldt/plugins/LDT_pluginIndices.F90 | 5 +++++ 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/ldt/plugins/LDT_param_pluginMod.F90 b/ldt/plugins/LDT_param_pluginMod.F90 index 39ff0fee6..8c6a9c6b9 100644 --- a/ldt/plugins/LDT_param_pluginMod.F90 +++ b/ldt/plugins/LDT_param_pluginMod.F90 @@ -25,7 +25,7 @@ module LDT_param_pluginMod ! 01 Mar 2020: Yeosang Yoon - Added MERIT DEM ! 29 Jun 2020: Mahdi Navari - Glacier fraction added ! 12 Apr 2021: Wanshu Nie - groundwater irrigation ratio added -! +! 28 Jun 2022: Eric Kemp - Added NAFPA background precipitation !EOP use LDT_pluginIndices @@ -77,8 +77,12 @@ subroutine LDT_LSMparam_plugin use Mosaic_parmsMod use RUC_parmsMod use JULES50_parmsMod - use Crocus_parmsMod + use Crocus_parmsMod + external :: registerlsmparamprocinit + external :: registerlsmparamprocwriteheader + external :: registerlsmparamprocwritedata + ! Noah 2.7.1 LSM: call registerlsmparamprocinit(trim(LDT_noah271Id)//char(0),& NoahParms_init) @@ -1181,10 +1185,14 @@ end subroutine LDT_alb_plugin ! !INTERFACE: subroutine LDT_climate_plugin !EOP + use LDT_NAFPA_back_climpptMod, only: LDT_read_NAFPA_back_gfs_climppt, & + LDT_read_NAFPA_back_galwem_climppt external read_PRISM_climppt external read_WorldClim_climppt external read_NLDAS_climppt + external :: registerreadclimppt + ! !USES: !- Precipitation downscaling: call registerreadclimppt(trim(LDT_prismpptId)//char(0),& @@ -1193,6 +1201,12 @@ subroutine LDT_climate_plugin call registerreadclimppt(trim(LDT_worldclimpptId)//char(0),& read_WorldClim_climppt) + call registerreadclimppt(trim(LDT_nafpabackgfspptId)//char(0),& + LDT_read_NAFPA_back_gfs_climppt) + + call registerreadclimppt(trim(LDT_nafpabackgalwempptId)//char(0),& + LDT_read_NAFPA_back_galwem_climppt) + !- Temperature downscaling: end subroutine LDT_climate_plugin diff --git a/ldt/plugins/LDT_pluginIndices.F90 b/ldt/plugins/LDT_pluginIndices.F90 index aff814f89..743b6ff61 100644 --- a/ldt/plugins/LDT_pluginIndices.F90 +++ b/ldt/plugins/LDT_pluginIndices.F90 @@ -25,6 +25,7 @@ module LDT_pluginIndices ! 23 Oct 2008: Sujay Kumar -- Initial Specification ! 17 Jul 2012: KR Arsenault -- Updated entries with capitalization rules ! 01 Mar 2020: Yeosang Yoon -- Added MERIT DEM +! 28 Jun 2022: Eric Kemp -- Added NAFPA background precipitation ! !EOP PRIVATE @@ -343,6 +344,10 @@ module LDT_pluginIndices !- PPT: character*50, public, parameter :: LDT_prismpptId = "PRISM" character*50, public, parameter :: LDT_worldclimpptId = "WORLDCLIM" + character*50, public, parameter :: LDT_nafpabackgfspptId = "NAFPA_BACK_GFS" + character*50, public, parameter :: LDT_nafpabackgalwempptId = & + "NAFPA_BACK_GALWEM" + !- TMIN: character*50, public, parameter :: LDT_prismtminId = "PRISM" character*50, public, parameter :: LDT_worldclimtminId = "WORLDCLIM" From e1540f73865815a9238cfd35a28653763857bfa2 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 3 Feb 2023 17:56:49 -0500 Subject: [PATCH 075/328] First attempt at writing SM retrievals in netCDF format. Code seems to work with SMAP L1B historical data, but so far encountering no retrievals with SMAP L1B NRT files. Also, have noticed LDT crashes when processing more than one SMAP L1B NRT file in the same execution, which is not observed (yet) with SMAP L1B historical files. Output of legacy binary format for retrievals is currently disabled. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 31 ++- ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 | 314 ++++++++++++++++++++++++ 2 files changed, 338 insertions(+), 7 deletions(-) create mode 100644 ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 137324b4f..6ed09186d 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -25,9 +25,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& USE invdist_temp2smap USE varsio_m USE algo_vpol_m + use LDT_ARFSSM_netcdfMod, only: LDT_ARFSSM_write_netcdf use LDT_logMod USE LDT_smap_e_oplMod - + IMPLICIT NONE ! !ARGUMENTS: CHARACTER (len=100) :: SMAPFILE @@ -55,6 +56,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& integer :: L1B_dir_len,L1B_fname_len real :: utc_check + ! EMK + character(8) :: yyyymmdd + character(6) :: hhmmss + nrow=2560 mcol=1920 @@ -121,7 +126,7 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& write (LDT_logunit,*) '[INFO] Finished reading landcover' !generate soil moisture retrievals - write (LDT_logunit,*) '[INFO] Generating soil moisture retrievals' + write (LDT_logunit,*) '[INFO] Generating soil moisture retrievals' ARFS_SM=-9999 ARFS_SM_FLAG=-1 DO i=1,nrow !ROW LON @@ -161,17 +166,29 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& L1B_fname_len = len_trim(SMAPFILE) if(SMAPeOPL%L1Btype.eq.1) then !NRT + !retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& + ! trim(SMAPFILE(L1B_dir_len+18:L1B_fname_len-3))//".dat" retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& - trim(SMAPFILE(L1B_dir_len+18:L1B_fname_len-3))//".dat" + trim(SMAPFILE(L1B_dir_len+18:L1B_fname_len-3))//".nc" + yyyymmdd = trim(SMAPFILE(L1B_fname_len-28:L1B_fname_len-20)) + hhmmss = trim(SMAPFILE(L1B_fname_len-19:L1B_fname_len-13)) elseif(SMAPeOPL%L1Btype.eq.2) then !Historical + !retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& + ! trim(SMAPFILE(L1B_dir_len+14:L1B_fname_len-3))//".dat" retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& - trim(SMAPFILE(L1B_dir_len+14:L1B_fname_len-3))//".dat" + trim(SMAPFILE(L1B_dir_len+14:L1B_fname_len-3))//".nc" + yyyymmdd = trim(SMAPFILE(L1B_fname_len-28:L1B_fname_len-20)) + hhmmss = trim(SMAPFILE(L1B_fname_len-19:L1B_fname_len-13)) endif write (LDT_logunit,*) '[INFO] Writing soil moisture retrieval file ', trim(retrieval_fname) - OPEN(UNIT=151, FILE=retrieval_fname,FORM='UNFORMATTED',ACCESS='DIRECT', RECL=nrow*mcol*4) - WRITE(UNIT=151, REC = 1) ARFS_SM - CLOSE(151) +! OPEN(UNIT=151, FILE=retrieval_fname,FORM='UNFORMATTED',ACCESS='DIRECT', RECL=nrow*mcol*4) +! WRITE(UNIT=151, REC = 1) ARFS_SM +! CLOSE(151) + ! NOTE: nrow is actually number of columns, mcol is actually number of + ! rows + call LDT_ARFSSM_write_netcdf(nrow, mcol, arfs_sm, retrieval_fname, & + yyyymmdd, hhmmss) write (LDT_logunit,*) '[INFO] Successfully wrote soil moisture retrieval file ', trim(retrieval_fname) write (LDT_logunit,*) '[INFO] Finished generating soil moisture retrievals' diff --git a/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 new file mode 100644 index 000000000..246d23981 --- /dev/null +++ b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 @@ -0,0 +1,314 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- + +#include "LDT_misc.h" +#include "LDT_NetCDF_inc.h" + +module LDT_ARFSSM_netcdfMod + + ! Defaults + implicit none + private + + ! Public routines + public :: LDT_ARFSSM_write_netcdf + +contains + +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + ! Subroutine for writing ARFS SM retrieval to netCDF + subroutine LDT_ARFSSM_write_netcdf(nc, nr, arfs_sm, retrieval_fname, & + yyyymmdd, hhmmss) + + ! Imports + use LDT_coreMod, only: LDT_rc, LDT_masterproc + use LDT_logMod, only: LDT_logunit, LDT_endrun, LDT_verify +#if ( defined SPMD) + use mpi +#endif +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + ! Arguments + integer, intent(in) :: nc + integer, intent(in) :: nr + real*4, intent(in) :: arfs_sm(nc,nr) + character(*), intent(in) :: retrieval_fname + character(8), intent(in) :: yyyymmdd + character(6), intent(in) :: hhmmss + + ! Locals + integer :: shuffle, deflate, deflate_level + integer :: iret + integer :: ncid + integer :: dim_ids(3) + real :: dlat, dlon + real :: swlat, swlon + real :: nelat, nelon + integer :: lon_varid, lat_varid, time_varid, sm_varid + character(120) :: time_units + character(8) :: date + character(10) :: time + character(5) :: zone + integer :: values(8) + real, allocatable :: lats(:) + real, allocatable :: lons(:) + integer :: ierr + integer :: i, j + + ! Only the master process handles the file output + if (LDT_masterproc) then + write(LDT_logunit,*)'[INFO] Creating NETCDF file ', & + trim(retrieval_fname) + + write(LDT_logunit,*)'EMK: nc = ', nc + write(LDT_logunit,*)'EMK: nr = ', nr + write(LDT_logunit,*)'EMK: yyyymmdd = ', yyyymmdd + write(LDT_logunit,*)'EMK: hhmmss = ', hhmmss + + ! Copy netCDF compression settings + shuffle = NETCDF_shuffle + deflate = NETCDF_deflate + deflate_level = NETCDF_deflate_level + + ! Create the output file +#if(defined USE_NETCDF3) + iret=nf90_create(path=trim(retrieval_fname),& + cmode=NF90_CLOBBER, ncid=ncid) + call LDT_verify(iret,& + '[ERR] nf90_create failed') +#endif +#if(defined USE_NETCDF4) + iret=nf90_create(path=trim(retrieval_fname),& + cmode=NF90_NETCDF4, ncid=ncid) + call LDT_verify(iret, & + '[ERR] nf90_create failed') +#endif + + ! Write out dimensions headers + call LDT_verify(nf90_def_dim(ncid, 'time', 1, dim_ids(3)), & + '[ERR] nf90_def_dim failed') + call LDT_verify(nf90_def_dim(ncid, 'lat', nr, dim_ids(2)), & + '[ERR] nf90_def_dim failed') + call LDT_verify(nf90_def_dim(ncid, 'lon', nc, dim_ids(1)), & + '[ERR] nf90_def_dim failed') + + ! Map projection + !FIXME: Allow map projections other than lat/lon + select case("latlon") + case ("latlon") + dlon = LDT_rc%gridDesc(1,9) + dlat = LDT_rc%gridDesc(1,10) + swlat = LDT_rc%gridDesc(1,4) + swlon = LDT_rc%gridDesc(1,5) + nelat = LDT_rc%gridDesc(1,7) + nelon = LDT_rc%gridDesc(1,8) + + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL,& + "MAP_PROJECTION", "EQUIDISTANT CYLINDRICAL"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL,& + "SOUTH_WEST_CORNER_LAT", swlat), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL,& + "SOUTH_WEST_CORNER_LON", swlon), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, & + "NORTH_EAST_CORNER_LAT", nelat), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, & + "NORTH_EAST_CORNER_LON", nelon), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, & + "DX", dlon),& + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, & + "DY", dlat), & + '[ERR] nf90_put_att failed') + + case default + write(LDT_logunit,*) & + '[ERR] Only latlon map projection supported for SMAP_E_OPL' + call LDT_endrun() + end select + + ! Include the water points + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, & + "INC_WATER_PTS", "true"), & + '[ERR] nf90_put_att failed') + + ! Construct the longitudes + ! FIXME: Add support for other map projections + call LDT_verify(nf90_def_var(ncid, "lon", NF90_FLOAT, dim_ids(1), & + lon_varid),'[ERR] nf90_def_var failed') +#if(defined USE_NETCDF4) + call LDT_verify(nf90_def_var_deflate(ncid, & + lon_varid, shuffle, deflate, deflate_level),& + '[ERR] nf90_def_var_deflate') +#endif + call LDT_verify(nf90_put_att(ncid, lon_varid, & + "units", "degrees_east"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, lon_varid, & + "long_name", "longitude"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, lon_varid, & + "standard_name", "longitude"), & + '[ERR] nf90_put_att failed') + + ! Construct the latitudes + ! FIXME: Add support for other map projections + call LDT_verify(nf90_def_var(ncid, "lat", NF90_FLOAT, dim_ids(2), & + lat_varid), '[ERR] nf90_def_var failed') +#if(defined USE_NETCDF4) + call LDT_verify(nf90_def_var_deflate(ncid, & + lat_varid, shuffle, deflate, deflate_level),& + '[ERR] nf90_def_var_deflate') + call LDT_verify(nf90_put_att(ncid, lat_varid, & + "units", "degrees_north"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, lat_varid, & + "long_name", "latitude"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, lat_varid, & + "standard_name", "latitude"), & + '[ERR] nf90_put_att failed') +#endif + + ! Define the time array. The valid time will be written as an + ! attribute. + call LDT_verify(nf90_def_var(ncid, 'time', NF90_DOUBLE, & + dimids=dim_ids(3), varid=time_varid), & + '[ERR] nf90_def_var failed') + write(time_units,'(A)') & + "seconds since "//yyyymmdd(1:4)//"-" & + //yyyymmdd(5:6)//"-" & + //yyyymmdd(7:8)//" " & + //hhmmss(1:2)//":"//hhmmss(3:4)//":"//hhmmss(5:6) + call LDT_verify(nf90_put_att(ncid, time_varid, & + "units", trim(time_units)), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, time_varid, & + "long_name", "time"), & + '[ERR] nf90_put_att failed') + + ! Define the soil moisture retrieval + call LDT_verify(nf90_def_var(ncid, "arfs_sm", NF90_FLOAT, & + dimids=dim_ids, & + varid=sm_varid), '[ERR] nf90_def_var failed') +#if (defined USE_NETCDF4) + call LDT_verify(nf90_def_var_deflate(ncid, & + sm_varid, shuffle, deflate, deflate_level), & + '[ERR] nf90_def_var_deflate failed') +#endif + call LDT_verify(nf90_put_att(ncid, sm_varid, & + "units", "m^3/m^3"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, sm_varid, & + "long_name","soil moisture"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, sm_varid, & + '_FillValue', -9999.), & + '[ERR] nf90_put_att failed') + + ! Miscellaneous header information + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "Conventions", & + "CF-1.10"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "title", & + "LDT SMAP_E_OPL retrieval"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "institution", & + "NASA GSFC Hydrological Sciences Laboratory"), & + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "source", & + "Land Data Toolkit (LDT)"), & + '[ERR] nf90_put_att failed') + call date_and_time(date, time, zone, values) +#ifndef LDT_SKIP_HISTORY + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "history", & + "created on date: "//date(1:4)//"-"//date(5:6)//"-"//& + date(7:8)//"T"//time(1:2)//":"//time(3:4)//":"//time(5:10)), & + '[ERR] nf90_put_att failed') +#endif + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "references", & + "Arsenault_etal_GMD_2018, Kumar_etal_EMS_2006"),& + '[ERR] nf90_put_att failed') + call LDT_verify(nf90_put_att(ncid, NF90_GLOBAL, "comment", & + "website: http://lis.gsfc.nasa.gov/"), & + '[ERR] nf90_put_att failed') + + ! We are ready to write the actual data. This requires taking NETCDF + ! out of define mode. + call LDT_verify(nf90_enddef(ncid), & + '[ERR] ncf90_enddef failed') + + ! Write the latitude data + allocate(lats(nr)) + do j = 1, nr + lats(j) = swlat + (j-1)*(dlat) + end do + call LDT_verify(nf90_put_var(ncid, lat_varid, & + lats(:), (/1/), (/nr/)), & + '[ERR] nf90_put_var failed for lats') + deallocate(lats) + + ! Write the longitude data + allocate(lons(nc)) + do i = 1, nc + lons(i) = swlon + (i-1)*(dlon) + end do + call LDT_verify(nf90_put_var(ncid, lon_varid, lons(:),& + (/1/), (/nc/)), & + '[ERR] nf90_put_var failed for lon') + deallocate(lons) + + ! Write the time data + call LDT_verify(nf90_put_var(ncid, time_varid, 0.0), & + '[ERR] nf90_put_var failed for time') + + ! Write the ARFS SM field + call LDT_verify(nf90_put_var(ncid, sm_varid, & + arfs_sm(:,:), & + (/1,1/), (/nc,nr/)), & + '[ERR] nf90_put_var failed for sm') + + ! Close the file and clean up + call LDT_verify(nf90_close(ncid), & + '[ERR] nf90_close failed!') + endif + + ierr = 0 +#if (defined SPMD) + call mpi_barrier(MPI_COMM_WORLD, ierr) +#endif + end subroutine LDT_ARFSSM_write_netcdf +#else + ! Dummy version + subroutine LDT_ARFSSM_write_netcdf(nc, nr, arfs_sm, retrieval_fname, & + yyyymmdd, hhmmss) + use LDT_logMod, only: LDT_logunit, LDT_endrun + implicit none + integer, intent(in) :: nc + integer, intent(in) :: nr + real*4, intent(in) :: arfs_sm(nc,nr) + character(*), intent(in) :: retrieval_fname + character(8), intent(in) :: yyyymmdd + character(6), intent(in) :: hhmmss + write(LDT_logunit,*)'[ERR] LDT not compiled with NETCDF support!' + write(LDT_logunit,*)'Cannot write ARFS SM retrieval in NETCDF format!' + write(LDT_logunit,*)'Recompile with NETCDF support and try again!' + call LDT_endrun() + end subroutine LDT_ARFSSM_write_netcdf +#endif + +end module LDT_ARFSSM_netcdfMod + From 21dab29da988d1f5bb6ccdb7803ba37d3d5201fb Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 8 Feb 2023 13:50:19 -0500 Subject: [PATCH 076/328] First attempt at adding fault tolerance to SMAP_E_OPL. --- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 | 31 +- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 455 ++++++++++++++++++++++++++- 2 files changed, 482 insertions(+), 4 deletions(-) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 index 8c2b2caad..b92f324ed 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 @@ -34,6 +34,7 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) character (len=1) :: Orbit integer :: var_i integer :: L1B_dir_len,L1B_fname_len + integer :: ierr REAL*4,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B REAL*4,DIMENSION(:,:),ALLOCATABLE :: NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, SCNANG_L1B @@ -55,8 +56,33 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) !Input (Path/filename, datatypes, lat, lon) Return(DATA,LAT,LON,length of row and col) ! READ SMAP_L1B DATA FROM HDF5 - CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) + ! EMK...Try fault tolerant NRT version. + !CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) + CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & + TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & + ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) + if (ierr == 1) then + if (nrow == 0 .and. mcol == 0) then + write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) + write(LDT_logunit,*)'[ERR] Aborting....' + call LDT_endrun() + else if (.not. allocated(TBV_COR_L1B)) then + write(LDT_logunit,*)'[WARN] Could not find TBV_COR_L1B in ', & + trim(SMAPFILE) + write(LDT_logunit,*)'[WARN] Substituting TBV_L1B...' + allocate(TBV_COR_L1B(nrow,mcol)) ; TBV_COR_L1B = TBV_L1B + allocate(TBH_COR_L1B(nrow,mcol)) ; TBH_COR_L1B = TBH_L1B + allocate(SURWAT_V_L1B(nrow,mcol)) ; SURWAT_V_L1B = -9999 + allocate(SURWAT_H_L1B(nrow,mcol)) ; SURWAT_H_L1B = -9999 + else + write(LDT_logunit,*)'[ERR] Unknown internal error!' + write(LDT_logunit,*)'[ERR] Aborting...' + call LDT_endrun() + end if + end if + write(LDT_logunit,*)'EMK: maxval(TBV_COR_L1B) = ', maxval(TBV_COR_L1B) !Input (DATA,LAT,LON,length of row and col); Return(TB in ARFS GRID) CALL L1BTB2ARFS_INVDIS(TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & @@ -64,6 +90,7 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) ARFS_LAT, ARFS_LON, ARFS_TIME, ARFS_COR_TBV, ARFS_COR_TBH, ARFS_TBV, ARFS_TBH, ARFS_NEDTV, ARFS_NEDTH, & ARFS_SURWAT_V, ARFS_SURWAT_H, ARFS_WTV, ARFS_WTH, ARFS_SAMPLE_V, ARFS_SAMPLE_H) + write(LDT_logunit,*)'EMK: maxval(ARFS_COR_TBV) = ', maxval(ARFS_COR_TBV) SMAPeOPL%ARFS_TBV_COR = ARFS_COR_TBV variable_name(1) = 'ARFS_TIME' diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 33bf25ce4..451053ed7 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -181,6 +181,8 @@ END SUBROUTINE GetSMAP_L2 SUBROUTINE GetSMAP_L1B(filename, data1_out, data2_out, data3_out, data4_out, data5_out, data6_out, data7_out, data8_out, & data9_out, data10_out, data11_out, data12_out, data13_out, data14_out, data15_out, n, m) + use LDT_logMod, only: LDT_logunit ! EMK + CHARACTER (len=100) :: filename, dataset1, dataset2, dataset3, dataset4, dataset5, dataset6, dataset7 CHARACTER (len=100) :: dataset8, dataset9, dataset10, dataset11, dataset12, dataset13, dataset14, dataset15 #if (defined USE_HDF5) @@ -216,24 +218,56 @@ SUBROUTINE GetSMAP_L1B(filename, data1_out, data2_out, data3_out, data4_out, dat #if (defined USE_HDF5) CALL h5open_f(hdferr) !Initialize hdf5 CALL h5fopen_f (trim(filename),H5F_ACC_RDONLY_F,file_id,hdferr) !Open file -! PRINT*, 'sd_id, hdferr', file_id, hdferr + write(ldt_logunit,*)'EMK: hdferr, filename = ', hdferr, trim(filename) + ! PRINT*, 'sd_id, hdferr', file_id, hdferr CALL h5dopen_f (file_id, trim(dataset1),dataset_id1, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset1 = ', hdferr, trim(dataset1) + call h5dget_space_f(dataset_id1,dspace_id,hdferr) + write(ldt_logunit,*)'EMK: hdferr, dspace = ', hdferr call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + write(ldt_logunit,*)'EMK: hdferr, dims = ', hdferr, maxdims, dims CALL h5dopen_f (file_id, trim(dataset2),dataset_id2, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset2 = ', hdferr, trim(dataset2) + CALL h5dopen_f (file_id, trim(dataset3),dataset_id3, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset3 = ', hdferr, trim(dataset3) + CALL h5dopen_f (file_id, trim(dataset4),dataset_id4, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset4 = ', hdferr, trim(dataset4) + CALL h5dopen_f (file_id, trim(dataset5),dataset_id5, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset5 = ', hdferr, trim(dataset5) + CALL h5dopen_f (file_id, trim(dataset6),dataset_id6, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset6 = ', hdferr, trim(dataset6) + CALL h5dopen_f (file_id, trim(dataset7),dataset_id7, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset7 = ', hdferr, trim(dataset7) + CALL h5dopen_f (file_id, trim(dataset8),dataset_id8, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset8 = ', hdferr, trim(dataset8) + CALL h5dopen_f (file_id, trim(dataset9),dataset_id9, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset9 = ', hdferr, trim(dataset9) + CALL h5dopen_f (file_id, trim(dataset10),dataset_id10, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset10 = ', hdferr, trim(dataset10) + CALL h5dopen_f (file_id, trim(dataset11),dataset_id11, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset11 = ', hdferr, trim(dataset11) + CALL h5dopen_f (file_id, trim(dataset12),dataset_id12, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset12 = ', hdferr, trim(dataset12) + CALL h5dopen_f (file_id, trim(dataset13),dataset_id13, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset13 = ', hdferr, trim(dataset13) + CALL h5dopen_f (file_id, trim(dataset14),dataset_id14, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset14 = ', hdferr, trim(dataset14) + CALL h5dopen_f (file_id, trim(dataset15),dataset_id15, hdferr) !Open dataset + write(ldt_logunit,*)'EMK: hdferr, dataset15 = ', hdferr, trim(dataset15) !PRINT*,'ds_id hdferr', dataset_id1, hdferr @@ -285,6 +319,421 @@ SUBROUTINE GetSMAP_L1B(filename, data1_out, data2_out, data3_out, data4_out, dat #endif END SUBROUTINE GetSMAP_L1B + ! Forked version of GetSMAP_L1B to SMAP files in operation, with + ! fault tolerance and some special logic for older NRT files missing + ! some variables. Eric Kemp/SSAI. + SUBROUTINE GetSMAP_L1B_NRT(filename, tb_time_seconds, & + tb_v_surface_corrected, tb_h_surface_corrected, & + tb_v, tb_h, & + surface_water_fraction_mb_v, surface_water_fraction_mb_h, & + nedt_v, nedt_h, tb_lat, tb_lon, & + tb_qual_flag_v, tb_qual_flag_h, sc_nadir_angle, & + antenna_scan_angle, n, m, ierr) + + ! Imports + use LDT_logMod, only: LDT_logunit, LDT_endrun ! EMK + + ! Arguments + character(*), intent(in) :: filename + real*4, allocatable, intent(out) :: tb_time_seconds(:,:) + real*4, allocatable, intent(out) :: tb_v_surface_corrected(:,:) + real*4, allocatable, intent(out) :: tb_h_surface_corrected(:,:) + real*4, allocatable, intent(out) :: tb_v(:,:), tb_h(:,:) + real*4, allocatable, intent(out) :: surface_water_fraction_mb_v(:,:) + real*4, allocatable, intent(out) :: surface_water_fraction_mb_h(:,:) + real*4, allocatable, intent(out) :: nedt_v(:,:), nedt_h(:,:) + real*4, allocatable, intent(out) :: tb_lat(:,:), tb_lon(:,:) + integer*4, allocatable, intent(out) :: tb_qual_flag_v(:,:) + integer*4, allocatable, intent(out) :: tb_qual_flag_h(:,:) + real*4, allocatable, intent(out) :: sc_nadir_angle(:) + real*4, allocatable, intent(out) :: antenna_scan_angle(:,:) + integer, intent(out) :: m, n + integer, intent(out) :: ierr + +#if (defined USE_HDF5) + + ! Locals + character(100) :: dataset + integer(HID_T) :: file_id, dataset_id, dspace_id + integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: hdferr + + ierr = 0 + m = 0 + n = 0 + + ! Initialize HDF5 + call h5open_f(hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot initialize HDF5 Fortran interface!' + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Open the file + call h5fopen_f(trim(filename), H5F_ACC_RDONLY_F, file_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open ', trim(filename) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Open tb_time_seconds and get dimensions + dataset = "/Brightness_Temperature/tb_time_seconds/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! We have the dimensions for the arrays, so let's allocate here. + n = dims(1) + m = dims(2) + allocate(tb_time_seconds(n,m)) ; tb_time_seconds = 0 + allocate(tb_v_surface_corrected(n,m)); tb_v_surface_corrected = 0 + allocate(tb_h_surface_corrected(n,m)); tb_h_surface_corrected = 0 + allocate(tb_v(n,m)) ; tb_v = 0 + allocate(tb_h(n,m)) ; tb_h = 0 + allocate(surface_water_fraction_mb_v(n,m)) + surface_water_fraction_mb_v = 0 + allocate(surface_water_fraction_mb_h(n,m)) + surface_water_fraction_mb_h = 0 + allocate(nedt_v(n,m)) ; nedt_v = 0 + allocate(nedt_h(n,m)) ; nedt_h = 0 + allocate(tb_lat(n,m)) ; tb_lat = 0 + allocate(tb_lon(n,m)) ; tb_lon = 0 + allocate(tb_qual_flag_v(n,m)) ; tb_qual_flag_v = 0 + allocate(tb_qual_flag_h(n,m)) ; tb_qual_flag_h = 0 + allocate(sc_nadir_angle(n)) ; sc_nadir_angle = 0 + allocate(antenna_scan_angle(n,m)) ; antenna_scan_angle = 0 + + ! Read tb_time_seconds + call read_dataset_real(file_id, dataset, dataset_id, tb_time_seconds, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_v + dataset = "/Brightness_Temperature/tb_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_v, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_h + dataset = "/Brightness_Temperature/tb_h/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_h, & + dims, ierr) + if (ierr == 1) return + + ! Get nedt_v + dataset = "/Brightness_Temperature/nedt_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, nedt_v, & + dims, ierr) + if (ierr == 1) return + + ! Get nedt_h + dataset = "/Brightness_Temperature/nedt_h/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, nedt_h, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_lat + dataset = "/Brightness_Temperature/tb_lat/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_lat, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_lon + dataset = "/Brightness_Temperature/tb_lon/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_lon, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_qual_flag_v + dataset = "/Brightness_Temperature/tb_qual_flag_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_v, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_qual_flag_h + dataset = "/Brightness_Temperature/tb_qual_flag_h/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_h, & + dims, ierr) + if (ierr == 1) return + + ! Get sc_nadir_angle + dataset = "/Spacecraft_Data/sc_nadir_angle/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real_1d(file_id, dataset, dataset_id, sc_nadir_angle, & + dims, ierr) + if (ierr == 1) return + + ! Get antenna_scan_angle + dataset = "/Brightness_Temperature/antenna_scan_angle/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + antenna_scan_angle, dims, ierr) + if (ierr == 1) return + + ! The final four fields are missing in old NRT files. So we have + ! extra logic (via the handle_missing_nrt_field flag) to only + ! deallocate these four arrays if a field is found to be missing at this + ! point. The "uncorrected" fields will be sent back to the caller + ! for potential use, along with the error flag indicating an error + ! was encountered by the HDF5 library. + ! NOTE: If a *read* error occurs, the file will assumed to be + ! corrupt all arrays will be nuked. + ! Get tb_v_surface_corrected + dataset = "/Brightness_Temperature/tb_v_surface_corrected/" + call get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field=.true.) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + tb_v_surface_corrected, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_h_surface_corrected + dataset = "/Brightness_Temperature/tb_h_surface_corrected/" + call get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field=.true.) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + tb_h_surface_corrected, & + dims, ierr) + if (ierr == 1) return + + ! Get surface_water_fraction_mb_v + dataset = "/Brightness_Temperature/surface_water_fraction_mb_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field=.true.) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + surface_water_fraction_mb_v, & + dims, ierr) + if (ierr == 1) return + + ! Get surface_water_fraction_mb_h + dataset = "/Brightness_Temperature/surface_water_fraction_mb_h/" + call get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field=.true.) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + surface_water_fraction_mb_h, & + dims, ierr) + if (ierr == 1) return + + ! Clean up + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 0 + + return + + contains + + ! Internal subroutine + subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(out) :: dataset_id + integer, intent(out) :: ierr + logical, optional, intent(in) :: handle_missing_nrt_field + integer :: hdferr + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot use dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + if (present(handle_missing_nrt_field)) then + call freeall(ierr, handle_missing_nrt_field) + else + call freeall(ierr) + endif + end if + return + end subroutine get_dataset_id + + ! Internal subroutine + subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + real*4, intent(inout) :: buf(:,:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_real + + ! Internal subroutine + subroutine read_dataset_real_1d(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + real*4, intent(inout) :: buf(:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_real_1d + + ! Internal subroutine + subroutine read_dataset_integer(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + integer*4, intent(inout) :: buf(:,:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_integer + + ! Internal subroutine. Warning -- deallocates memory in + ! parent subroutine and resets two variables. This is intended + ! for gracefully handling errors returned from HDF5. + subroutine freeall(ierr, handle_missing_nrt_field) + implicit none + integer, intent(out) :: ierr + logical, optional, intent(in) :: handle_missing_nrt_field + if (allocated(tb_v_surface_corrected)) & + deallocate(tb_v_surface_corrected) + if (allocated(tb_h_surface_corrected)) & + deallocate(tb_h_surface_corrected) + if (allocated(surface_water_fraction_mb_v)) & + deallocate(surface_water_fraction_mb_v) + if (allocated(surface_water_fraction_mb_h)) & + deallocate(surface_water_fraction_mb_h) + ! If special flag is present and set to .true., we will use the + ! "uncorrected" data in the retrieval, and other fields. + if (present(handle_missing_nrt_field)) then + if (handle_missing_nrt_field) then + ierr = 1 + return + end if + end if + if (allocated(tb_time_seconds)) deallocate(tb_time_seconds) + if (allocated(tb_v)) deallocate(tb_v) + if (allocated(tb_h)) deallocate(tb_h) + if (allocated(nedt_v)) deallocate(nedt_v) + if (allocated(nedt_h)) deallocate(nedt_h) + if (allocated(tb_lat)) deallocate(tb_lat) + if (allocated(tb_lon)) deallocate(tb_lon) + if (allocated(tb_qual_flag_v)) deallocate(tb_qual_flag_v) + if (allocated(tb_qual_flag_h)) deallocate(tb_qual_flag_h) + if (allocated(sc_nadir_angle))deallocate(sc_nadir_angle) + if (allocated(antenna_scan_angle)) deallocate(antenna_scan_angle) + m = 0 + n = 0 + ierr = 1 + return + end subroutine freeall +#else + ! Dummy version if LDT was compiled w/o HDF5 support. + write(LDT_logunit,*) & + '[ERR] GetSMAP_L1B_NRT called without HDF5 support!' + write(LDT_logunit,*) & + '[ERR] Recompile LDT with HDF5 support and try again!' + call LDE_endrun() +#endif + end subroutine GetSMAP_L1B_NRT + SUBROUTINE NEAREST_1d ( nd, xd, yd, ni, xi, yi ) IMPLICIT NONE INTEGER :: i, j, k, nd, ni @@ -397,5 +846,7 @@ SUBROUTINE LSQ_Linear(n, x, y, a, b, r, rmse) !PRINT*, " y-intercept b = ", b !PRINT*, " Correlation r = ", r END SUBROUTINE LSQ_Linear - + + + END MODULE TOOLSUBS From 5b62ab334f3835e140b804c46d85735cfc264c7b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 8 Feb 2023 15:16:57 -0500 Subject: [PATCH 077/328] Added checks for if file exists, and if it is HDF5 file. --- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 451053ed7..13fcc3fc4 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -357,11 +357,20 @@ SUBROUTINE GetSMAP_L1B_NRT(filename, tb_time_seconds, & integer(HID_T) :: file_id, dataset_id, dspace_id integer(HSIZE_T) :: dims(2), maxdims(2) integer :: hdferr + logical :: exists, ishdf5 ierr = 0 m = 0 n = 0 + ! Make sure file exists + inquire(file=trim(filename), exist=exists) + if (.not. exists) then + write(LDT_logunit,*)'[ERR] Cannot find file ', trim(filename) + ierr = 1 + return + end if + ! Initialize HDF5 call h5open_f(hdferr) if (hdferr == -1) then @@ -371,6 +380,22 @@ SUBROUTINE GetSMAP_L1B_NRT(filename, tb_time_seconds, & return end if + ! Make sure the file is HDF5 + call h5fis_hdf5_f(trim(filename), ishdf5, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem checking if ', trim(filename), & + ' is HDF5' + call h5close_f(hdferr) + ierr = 1 + return + end if + if (.not. ishdf5) then + write(LDT_logunit,*)'[ERR] File ', trim(filename), ' is not HDF5!' + call h5close_f(hdferr) + ierr = 1 + return + end if + ! Open the file call h5fopen_f(trim(filename), H5F_ACC_RDONLY_F, file_id, hdferr) if (hdferr == -1) then From dd3a0d313902aa765ce65023f26950a02cc70340 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 8 Feb 2023 15:41:45 -0500 Subject: [PATCH 078/328] Improved fault tolerance. If a serious error occurs in processing one HDF5 file, LDT will gracefully move on to the next one. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 23 +++++++++++++++++------ ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 | 12 ++++++++---- 2 files changed, 25 insertions(+), 10 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index d32c497fe..507c69253 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -223,6 +223,7 @@ subroutine LDT_smap_e_oplRun(n) real :: UTChr(LDT_rc%lnc(n),LDT_rc%lnr(n)) integer :: L1B_dir_len integer :: doy_pre, doy_curr + integer :: rc ! Resample SMAP L1B to L1C call search_SMAPL1B_files(SMAPeOPL%L1Bdir,SMAPeOPL%date_curr,& @@ -268,15 +269,25 @@ subroutine LDT_smap_e_oplRun(n) if(i == fi) then write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) - call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec) - write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) - read_L1Bdata = .true. + call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + + if (rc == 0) then + write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) + read_L1Bdata = .true. + else + deallocate(SMAPeOPL%ARFS_TBV_COR) + end if elseif(hhmmss(i) /= hhmmss(i+1)) then write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) - call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec) - write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) - read_L1Bdata = .true. + call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + + if (rc == 0) then + write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) + read_L1Bdata = .true. + else + deallocate(SMAPeOPL%ARFS_TBV_COR) + end if endif if(read_L1Bdata) then diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 index b92f324ed..fd513ff35 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 @@ -13,8 +13,8 @@ ! OUTPUT: SMAPTB_ARFSGRIDE_ddmmyyy.dat ! NOTES : Inverse Distance Squared with 0.4 deg serching window !------------------------------------------------------------------------- - -subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) + +subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) USE VARIABLES USE DATADOMAIN @@ -35,6 +35,7 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) integer :: var_i integer :: L1B_dir_len,L1B_fname_len integer :: ierr + integer :: rc REAL*4,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B REAL*4,DIMENSION(:,:),ALLOCATABLE :: NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, SCNANG_L1B @@ -48,6 +49,9 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) REAL*4,DIMENSION(2560,1920) :: ARFS_SURWAT_V, ARFS_SURWAT_H, ARFS_WTV, ARFS_WTH REAL :: T1, T2 + + rc = 0 + CALL ARFS_GEO ALLOCATE(ARFS_LAT(arfs_nrow_lat),ARFS_LON(arfs_mcol_lon)) ARFS_LAT = LAT(arfs_geo_lat_lo,arfs_geo_lat_up,-arfs_lat_space) @@ -66,8 +70,8 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) if (ierr == 1) then if (nrow == 0 .and. mcol == 0) then write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) - write(LDT_logunit,*)'[ERR] Aborting....' - call LDT_endrun() + rc = 1 + return else if (.not. allocated(TBV_COR_L1B)) then write(LDT_logunit,*)'[WARN] Could not find TBV_COR_L1B in ', & trim(SMAPFILE) From 8b80a647bc60dceb5237daf021db5711e8bfe937 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 9 Feb 2023 16:31:43 -0500 Subject: [PATCH 079/328] Changed code to process subset of SMAP L1B fields. Also removed writing out of fields to binary sample files. (Old code is still available, just commented out). --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 15 +- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 114 ++++++ ldt/SMAP_E_OPL/TOOLSUBS.F90 | 365 +++++++++++++++++++- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 104 +++++- 4 files changed, 592 insertions(+), 6 deletions(-) create mode 100644 ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 507c69253..b8599c571 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -15,6 +15,7 @@ ! ! !REVISION HISTORY: ! 14 Dec 2021: Yonghwan Kwon, Initial Specification +! 06 Feb 2023: Eric Kemp, now process subset of SMAP fields. ! #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -269,7 +270,10 @@ subroutine LDT_smap_e_oplRun(n) if(i == fi) then write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) - call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + ! EMK...Process subset of fields. + !call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + call SMAPL1BRESAMPLE_subset(smap_L1B_filename(i), & + SMAPeOPL%L1Bdir, Orbit, TIMEsec, rc) if (rc == 0) then write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) @@ -280,7 +284,10 @@ subroutine LDT_smap_e_oplRun(n) elseif(hhmmss(i) /= hhmmss(i+1)) then write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) - call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + !EMK Process subset of fields. + !call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) + call SMAPL1BRESAMPLE_subset(smap_L1B_filename(i), & + SMAPeOPL%L1Bdir, Orbit, TIMEsec, rc) if (rc == 0) then write (LDT_logunit,*) '[INFO] Finished resampling ', trim(smap_L1B_filename(i)) @@ -296,7 +303,7 @@ subroutine LDT_smap_e_oplRun(n) ! use LIS outputs from previous day read(yyyy,*,iostat=ierr) yr read(mm,*,iostat=ierr) mo - read(dd,*,iostat=ierr) da + read(dd,*,iostat=ierr) da read(hh,*,iostat=ierr) hr yr_pre = yr @@ -441,7 +448,7 @@ subroutine LDT_smap_e_oplRun(n) call get_doy(mo,da,doy_curr) ! get UTC - call get_UTC(n,TIMEsec,UTChr) + call get_UTC(n,TIMEsec,UTChr) ! retrieve ierr = LDT_create_subdirs(len_trim(SMAPeOPL%SMoutdir), & diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 new file mode 100644 index 000000000..e4e370dbd --- /dev/null +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -0,0 +1,114 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA GSFC Land Data Toolkit (LDT) +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +! +! SUBROUTINE: SMAPL1BRESAMPLE +! +! REVISION HISTORY: +! 22 Oct 2021: P.W.LIU; Initial implemetation +! 18 Dec 2021: Yonghwan Kwon; modified for LDT +! 09 Feb 2023: Eric Kemp; now processes subset of fields, no output of +! data to separate binary files. +! +! DESCRIPTION: RESAMPLE SMAPL1B TB TO AIR FORCE GRID +! INPUT : SMAP - L1B Brightness Temperature +! OUTPUT: SMAPTB_ARFSGRIDE_ddmmyyy.dat +! NOTES : Inverse Distance Squared with 0.4 deg serching window +!------------------------------------------------------------------------- + +subroutine SMAPL1BRESAMPLE_SUBSET(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) + + USE VARIABLES + USE DATADOMAIN + USE FUNCTIONS + USE TOOLSUBS + USE invdist_l1b2arfs + USE LDT_logMod + USE LDT_smap_e_oplMod + + IMPLICIT NONE + + INTEGER :: i, j, nrow, mcol + CHARACTER (len=100) :: SMAPFILE + character (len=100) :: L1B_dir + character (len=20) :: variable_name(13) + character (len=100) :: resample_filename(13) + character (len=1) :: Orbit + integer :: var_i + integer :: L1B_dir_len,L1B_fname_len + integer :: ierr + integer :: rc + + REAL*4,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B, TBV_COR_L1B + REAL*4,DIMENSION(:,:),ALLOCATABLE :: LAT_L1B, LON_L1B, SCNANG_L1B + REAL*4,DIMENSION(:),ALLOCATABLE :: ANTSCN_L1B + INTEGER*4,DIMENSION(:,:),ALLOCATABLE :: TBVFLAG_L1B, TBHFLAG_L1B + REAL*8,DIMENSION(:), ALLOCATABLE :: ARFS_LAT, ARFS_LON + REAL*4,DIMENSION(2560,1920) :: ARFS_TIME, ARFS_COR_TBV + + REAL :: T1, T2 + + rc = 0 + + CALL ARFS_GEO + ALLOCATE(ARFS_LAT(arfs_nrow_lat),ARFS_LON(arfs_mcol_lon)) + ARFS_LAT = LAT(arfs_geo_lat_lo,arfs_geo_lat_up,-arfs_lat_space) + ARFS_LON = LON(arfs_geo_lon_lf,arfs_geo_lon_rt,arfs_lon_space) + + !Input (Path/filename, datatypes, lat, lon) Return(DATA,LAT,LON,length of row and col) + ! READ SMAP_L1B DATA FROM HDF5 + + ! EMK...Try fault tolerant NRT version. + !CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) + !CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & + ! TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & + ! ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) + CALL GetSMAP_L1B_NRT_SUBSET(SMAPFILE, TIME_L1B, TBV_COR_L1B, & + LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & + ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) + if (ierr == 1) then + if (nrow == 0 .and. mcol == 0) then + write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) + rc = 1 + return + else + write(LDT_logunit,*)'[ERR] Unknown internal error!' + write(LDT_logunit,*)'[ERR] Aborting...' + call LDT_endrun() + end if + end if + + !Input (DATA,LAT,LON,length of row and col); Return(TB in ARFS GRID) + !CALL L1BTB2ARFS_INVDIS(TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow, mcol, & + ! ARFS_LAT, ARFS_LON, ARFS_TIME, ARFS_COR_TBV, ARFS_COR_TBH, ARFS_TBV, ARFS_TBH, ARFS_NEDTV, ARFS_NEDTH, & + ! ARFS_SURWAT_V, ARFS_SURWAT_H, ARFS_WTV, ARFS_WTH, ARFS_SAMPLE_V, ARFS_SAMPLE_H) + CALL L1BTB2ARFS_INVDIS_SUBSET(TIME_L1B, TBV_COR_L1B, & + LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, & + nrow, mcol, & + ARFS_LAT, ARFS_LON, ARFS_TIME, ARFS_COR_TBV) + SMAPeOPL%ARFS_TBV_COR = ARFS_COR_TBV + + L1B_dir_len = len_trim(L1B_dir) + L1B_fname_len = len_trim(SMAPFILE) + + if(SMAPeOPL%L1Btype.eq.1) then !NRT + Orbit = trim(SMAPFILE(L1B_dir_len+24:L1B_dir_len+24)) + elseif(SMAPeOPL%L1Btype.eq.2) then !Historical + Orbit = trim(SMAPFILE(L1B_dir_len+20:L1B_dir_len+20)) + endif + + ! Cleanup + deallocate(TBV_COR_L1B) + deallocate(LAT_L1B) + deallocate(LON_L1B) + deallocate(SCNANG_L1B) + deallocate(ANTSCN_L1B) + deallocate(TBVFLAG_L1B) + deallocate(TBHFLAG_L1B) + deallocate(ARFS_LAT) + deallocate(ARFS_LON) + +end subroutine SMAPL1BRESAMPLE_SUBSET diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 13fcc3fc4..8837eb1d1 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -758,7 +758,370 @@ end subroutine freeall call LDE_endrun() #endif end subroutine GetSMAP_L1B_NRT - + + ! Forked version of GetSMAP_L1B to SMAP files in operations, processing + ! a subset of the fields. Also with fault tolerance and some special + ! logic for older NRT files missing the tb_v_surface_corrected field. + ! Eric Kemp/SSAI. + SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & + tb_v_surface_corrected, & + tb_lat, tb_lon, tb_qual_flag_v, tb_qual_flag_h, sc_nadir_angle, & + antenna_scan_angle, n, m, ierr) + + ! Imports + use LDT_logMod, only: LDT_logunit, LDT_endrun ! EMK + + ! Arguments + character(*), intent(in) :: filename + real*4, allocatable, intent(out) :: tb_time_seconds(:,:) + real*4, allocatable, intent(out) :: tb_v_surface_corrected(:,:) + real*4, allocatable, intent(out) :: tb_lat(:,:), tb_lon(:,:) + integer*4, allocatable, intent(out) :: tb_qual_flag_v(:,:) + integer*4, allocatable, intent(out) :: tb_qual_flag_h(:,:) + real*4, allocatable, intent(out) :: sc_nadir_angle(:) + real*4, allocatable, intent(out) :: antenna_scan_angle(:,:) + integer, intent(out) :: m, n + integer, intent(out) :: ierr + +#if (defined USE_HDF5) + + ! Locals + character(100) :: dataset + integer(HID_T) :: file_id, dataset_id, dspace_id + integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: hdferr + logical :: exists, ishdf5 + + ierr = 0 + m = 0 + n = 0 + + ! Make sure file exists + inquire(file=trim(filename), exist=exists) + if (.not. exists) then + write(LDT_logunit,*)'[ERR] Cannot find file ', trim(filename) + ierr = 1 + return + end if + + ! Initialize HDF5 + call h5open_f(hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot initialize HDF5 Fortran interface!' + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Make sure the file is HDF5 + call h5fis_hdf5_f(trim(filename), ishdf5, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem checking if ', trim(filename), & + ' is HDF5' + call h5close_f(hdferr) + ierr = 1 + return + end if + if (.not. ishdf5) then + write(LDT_logunit,*)'[ERR] File ', trim(filename), ' is not HDF5!' + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Open the file + call h5fopen_f(trim(filename), H5F_ACC_RDONLY_F, file_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open ', trim(filename) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Find Tb_lat, plus dimensions + dataset = "/Brightness_Temperature/tb_lat/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! We have the dimensions for the arrays, so let's allocate here. + n = dims(1) + m = dims(2) + allocate(tb_v_surface_corrected(n,m)); tb_v_surface_corrected = 0 + allocate(tb_time_seconds(n,m)); tb_time_seconds = 0 + allocate(tb_lat(n,m)) ; tb_lat = 0 + allocate(tb_lon(n,m)) ; tb_lon = 0 + allocate(tb_qual_flag_v(n,m)) ; tb_qual_flag_v = 0 + allocate(tb_qual_flag_h(n,m)) ; tb_qual_flag_h = 0 + allocate(sc_nadir_angle(n)) ; sc_nadir_angle = 0 + allocate(antenna_scan_angle(n,m)) ; antenna_scan_angle = 0 + + ! Get Tb_lat + call read_dataset_real(file_id, dataset, dataset_id, tb_lat, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_lon + dataset = "/Brightness_Temperature/tb_lon/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_lon, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_time_seconds + dataset = "/Brightness_Temperature/tb_time_seconds/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, tb_time_seconds, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_qual_flag_v + dataset = "/Brightness_Temperature/tb_qual_flag_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_v, & + dims, ierr) + if (ierr == 1) return + + ! Get tb_qual_flag_h + dataset = "/Brightness_Temperature/tb_qual_flag_h/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_h, & + dims, ierr) + if (ierr == 1) return + + ! Get sc_nadir_angle + dataset = "/Spacecraft_Data/sc_nadir_angle/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real_1d(file_id, dataset, dataset_id, sc_nadir_angle, & + dims, ierr) + if (ierr == 1) return + + ! Get antenna_scan_angle + dataset = "/Brightness_Temperature/antenna_scan_angle/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + call read_dataset_real(file_id, dataset, dataset_id, & + antenna_scan_angle, dims, ierr) + if (ierr == 1) return + + ! We will try to get tb_v_surface_corrected, but this is missing + ! in older NRT files. If absent, we will substitute tb_v. + ! NOTE: If a *read* error occurs, the file will assumed to be + ! corrupt all arrays will be nuked. + ! Get tb_v_surface_corrected + dataset = "/Brightness_Temperature/tb_v_surface_corrected/" + call get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field=.true.) + if (ierr == 1) then + ierr = 0 + dataset = "/Brightness_Temperature/tb_v/" + call get_dataset_id(file_id, dataset, dataset_id, ierr) + if (ierr == 1) return + end if + call read_dataset_real(file_id, dataset, dataset_id, & + tb_v_surface_corrected, & + dims, ierr) + if (ierr == 1) return + + ! Clean up + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 0 + + return + + contains + + ! Internal subroutine + subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & + handle_missing_nrt_field) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(out) :: dataset_id + integer, intent(out) :: ierr + logical, optional, intent(in) :: handle_missing_nrt_field + logical :: link_exists + integer :: hdferr + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + write(LDT_logunit,*)'EMK: HERE!!!' + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) + ierr = 1 + if (handle_missing_nrt_field) return + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + if (.not. link_exists) then + write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) + ierr = 1 + if (handle_missing_nrt_field) return + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) + ierr = 1 + if (handle_missing_nrt_field) return + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine get_dataset_id + + ! Internal subroutine + subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + real*4, intent(inout) :: buf(:,:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_real + + ! Internal subroutine + subroutine read_dataset_real_1d(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + real*4, intent(inout) :: buf(:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_real_1d + + ! Internal subroutine + subroutine read_dataset_integer(file_id, dataset, dataset_id, buf, & + dims, ierr) + implicit none + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer(HID_T), intent(in) :: dataset_id + integer*4, intent(inout) :: buf(:,:) + integer(HSIZE_T), intent(in) :: dims(:) + integer, intent(out) :: ierr + integer :: hdferr + call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, buf, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + endif + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + end subroutine read_dataset_integer + + ! Internal subroutine. Warning -- deallocates memory in + ! parent subroutine and resets two variables. This is intended + ! for gracefully handling errors returned from HDF5. + subroutine freeall(ierr) + implicit none + integer, intent(out) :: ierr + if (allocated(tb_v_surface_corrected)) & + deallocate(tb_v_surface_corrected) + if (allocated(tb_lat)) deallocate(tb_lat) + if (allocated(tb_lon)) deallocate(tb_lon) + if (allocated(tb_time_seconds)) deallocate(tb_time_seconds) + if (allocated(tb_qual_flag_v)) deallocate(tb_qual_flag_v) + if (allocated(tb_qual_flag_h)) deallocate(tb_qual_flag_h) + if (allocated(sc_nadir_angle))deallocate(sc_nadir_angle) + if (allocated(antenna_scan_angle)) deallocate(antenna_scan_angle) + m = 0 + n = 0 + ierr = 1 + return + end subroutine freeall +#else + ! Dummy version if LDT was compiled w/o HDF5 support. + write(LDT_logunit,*) & + '[ERR] GetSMAP_L1B_NRT called without HDF5 support!' + write(LDT_logunit,*) & + '[ERR] Recompile LDT with HDF5 support and try again!' + call LDE_endrun() +#endif + end subroutine GetSMAP_L1B_NRT_Subset + SUBROUTINE NEAREST_1d ( nd, xd, yd, ni, xi, yi ) IMPLICIT NONE INTEGER :: i, j, k, nd, ni diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 07f09bac5..39bcb487a 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -201,4 +201,106 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat END WHERE END SUBROUTINE L1BTB2ARFS_INVDIS - END MODULE invdist_l1b2arfs + + ! EMK...Only process subset of SMAP L1B fields for NRT operations. + SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & + lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, & + sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & + ref_lat, ref_lon, arfs_tim, arfs_tbv_cor) + + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb + INTEGER(4), PARAMETER :: qualitybit = 0 + REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 + REAL(8) :: gcdist, lat1, lon1, lat2, lon2 + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle + REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle + INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag + INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag + REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon + REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor + REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv + INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv + + ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) + !INITIAL THE OUTPUT VARIABLES + arfs_tim=0.0 + arfs_tbv_cor=0.0 + arfs_wt_tim=0.0 + arfs_wt_cor_tbv=0.0 + arfs_samplenumv=0.0 + + DO ii = 1,ncols_l1btb + IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN + DO jj = 1,nrows_l1btb + IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN + ! FIND ARFS_GRID (r,c) + c = MINLOC(ABS(lat_l1b(jj,ii)-ref_lat(:)),1) !Lat Direction + r = MINLOC(ABS(lon_l1b(jj,ii)-ref_lon(:)),1) !Lon Direction + rmin=r-5 ; IF (rmin < 1) rmin=1 + rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) + cmin=c-5 ; IF (cmin < 1) cmin=1 + cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) + IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY + k=0 + DO rr = rmin,rmax !Lon direction + DO cc =cmin,cmax !Lat direction + lat1 = DBLE (lat_l1b(jj,ii)*d2r) + lon1 = DBLE (lon_l1b(jj,ii)*d2r) + lat2 = DBLE (ref_lat(cc)*d2r) + lon2 = DBLE (ref_lon(rr)*d2r) + + if(lat1.eq.lat2.and.lon1.eq.lon2) then + gcdist = 0. + else + gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) + endif + + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE + IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center + zerodistflag (rr,cc) = 1 + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 + arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb + k=k+1; + END IF + ELSE + IF (zerodistflag (rr,cc).EQ.0) THEN + + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb + k=k+1; + END IF + + END IF !(zerodistflag (rr,cc) = 0) + END IF !(gcdist < 0.0001D0)! + END IF !(gcdist < search_radius) + END DO !cc =cmin,cmax + END DO !rr = rmin,rmax + END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) + END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) + END DO !jj=1,2 + END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) + END DO !ii=1,2 + + !APPLY WEIGHTING FUNCTION FOR RESAMPLING + WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) + arfs_tim = arfs_tim / arfs_wt_tim + END WHERE + WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) + arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv + END WHERE + + deallocate(zerodistflag) ! EMK cleanup memory + END SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET + + END MODULE invdist_l1b2arfs From 60e22a579cf7a36d54f3bb47777d0b384a49c46b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Feb 2023 10:22:52 -0500 Subject: [PATCH 080/328] Code cleanup. --- ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 | 14 +- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 | 53 ++- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 474 +----------------------- 3 files changed, 35 insertions(+), 506 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 index 246d23981..5163841cf 100644 --- a/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 @@ -7,6 +7,15 @@ ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- +! +! MODULE: LDT_ARFSSM_netcdfMod +! +! REVISION HISTORY: +! 10 Feb 2023: Eric Kemp. Initial implementation. +! +! DESCRIPTION: Outputs SMAP based soil moisture retrieval in netCDF format. +! +!------------------------------------------------------------------------------ #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -69,11 +78,6 @@ subroutine LDT_ARFSSM_write_netcdf(nc, nr, arfs_sm, retrieval_fname, & write(LDT_logunit,*)'[INFO] Creating NETCDF file ', & trim(retrieval_fname) - write(LDT_logunit,*)'EMK: nc = ', nc - write(LDT_logunit,*)'EMK: nr = ', nr - write(LDT_logunit,*)'EMK: yyyymmdd = ', yyyymmdd - write(LDT_logunit,*)'EMK: hhmmss = ', hhmmss - ! Copy netCDF compression settings shuffle = NETCDF_shuffle deflate = NETCDF_deflate diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 index fd513ff35..8201645d2 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 @@ -60,33 +60,31 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) !Input (Path/filename, datatypes, lat, lon) Return(DATA,LAT,LON,length of row and col) ! READ SMAP_L1B DATA FROM HDF5 - ! EMK...Try fault tolerant NRT version. - !CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) - CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & - TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & - ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) - if (ierr == 1) then - if (nrow == 0 .and. mcol == 0) then - write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) - rc = 1 - return - else if (.not. allocated(TBV_COR_L1B)) then - write(LDT_logunit,*)'[WARN] Could not find TBV_COR_L1B in ', & - trim(SMAPFILE) - write(LDT_logunit,*)'[WARN] Substituting TBV_L1B...' - allocate(TBV_COR_L1B(nrow,mcol)) ; TBV_COR_L1B = TBV_L1B - allocate(TBH_COR_L1B(nrow,mcol)) ; TBH_COR_L1B = TBH_L1B - allocate(SURWAT_V_L1B(nrow,mcol)) ; SURWAT_V_L1B = -9999 - allocate(SURWAT_H_L1B(nrow,mcol)) ; SURWAT_H_L1B = -9999 - else - write(LDT_logunit,*)'[ERR] Unknown internal error!' - write(LDT_logunit,*)'[ERR] Aborting...' - call LDT_endrun() - end if - end if - write(LDT_logunit,*)'EMK: maxval(TBV_COR_L1B) = ', maxval(TBV_COR_L1B) + CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) + ! CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & + ! TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & + ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & + ! ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) + ! if (ierr == 1) then + ! if (nrow == 0 .and. mcol == 0) then + ! write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) + ! rc = 1 + ! return + ! else if (.not. allocated(TBV_COR_L1B)) then + ! write(LDT_logunit,*)'[WARN] Could not find TBV_COR_L1B in ', & + ! trim(SMAPFILE) + ! write(LDT_logunit,*)'[WARN] Substituting TBV_L1B...' + ! allocate(TBV_COR_L1B(nrow,mcol)) ; TBV_COR_L1B = TBV_L1B + ! allocate(TBH_COR_L1B(nrow,mcol)) ; TBH_COR_L1B = TBH_L1B + ! allocate(SURWAT_V_L1B(nrow,mcol)) ; SURWAT_V_L1B = -9999 + ! allocate(SURWAT_H_L1B(nrow,mcol)) ; SURWAT_H_L1B = -9999 + ! else + ! write(LDT_logunit,*)'[ERR] Unknown internal error!' + ! write(LDT_logunit,*)'[ERR] Aborting...' + ! call LDT_endrun() + ! end if + ! end if !Input (DATA,LAT,LON,length of row and col); Return(TB in ARFS GRID) CALL L1BTB2ARFS_INVDIS(TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & @@ -94,7 +92,6 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) ARFS_LAT, ARFS_LON, ARFS_TIME, ARFS_COR_TBV, ARFS_COR_TBH, ARFS_TBV, ARFS_TBH, ARFS_NEDTV, ARFS_NEDTH, & ARFS_SURWAT_V, ARFS_SURWAT_H, ARFS_WTV, ARFS_WTH, ARFS_SAMPLE_V, ARFS_SAMPLE_H) - write(LDT_logunit,*)'EMK: maxval(ARFS_COR_TBV) = ', maxval(ARFS_COR_TBV) SMAPeOPL%ARFS_TBV_COR = ARFS_COR_TBV variable_name(1) = 'ARFS_TIME' diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 8837eb1d1..2a31460f8 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -218,57 +218,25 @@ SUBROUTINE GetSMAP_L1B(filename, data1_out, data2_out, data3_out, data4_out, dat #if (defined USE_HDF5) CALL h5open_f(hdferr) !Initialize hdf5 CALL h5fopen_f (trim(filename),H5F_ACC_RDONLY_F,file_id,hdferr) !Open file - write(ldt_logunit,*)'EMK: hdferr, filename = ', hdferr, trim(filename) ! PRINT*, 'sd_id, hdferr', file_id, hdferr CALL h5dopen_f (file_id, trim(dataset1),dataset_id1, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset1 = ', hdferr, trim(dataset1) call h5dget_space_f(dataset_id1,dspace_id,hdferr) - write(ldt_logunit,*)'EMK: hdferr, dspace = ', hdferr call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) - write(ldt_logunit,*)'EMK: hdferr, dims = ', hdferr, maxdims, dims CALL h5dopen_f (file_id, trim(dataset2),dataset_id2, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset2 = ', hdferr, trim(dataset2) - CALL h5dopen_f (file_id, trim(dataset3),dataset_id3, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset3 = ', hdferr, trim(dataset3) - CALL h5dopen_f (file_id, trim(dataset4),dataset_id4, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset4 = ', hdferr, trim(dataset4) - CALL h5dopen_f (file_id, trim(dataset5),dataset_id5, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset5 = ', hdferr, trim(dataset5) - CALL h5dopen_f (file_id, trim(dataset6),dataset_id6, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset6 = ', hdferr, trim(dataset6) - CALL h5dopen_f (file_id, trim(dataset7),dataset_id7, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset7 = ', hdferr, trim(dataset7) - CALL h5dopen_f (file_id, trim(dataset8),dataset_id8, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset8 = ', hdferr, trim(dataset8) - CALL h5dopen_f (file_id, trim(dataset9),dataset_id9, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset9 = ', hdferr, trim(dataset9) - CALL h5dopen_f (file_id, trim(dataset10),dataset_id10, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset10 = ', hdferr, trim(dataset10) - CALL h5dopen_f (file_id, trim(dataset11),dataset_id11, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset11 = ', hdferr, trim(dataset11) - CALL h5dopen_f (file_id, trim(dataset12),dataset_id12, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset12 = ', hdferr, trim(dataset12) - CALL h5dopen_f (file_id, trim(dataset13),dataset_id13, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset13 = ', hdferr, trim(dataset13) - CALL h5dopen_f (file_id, trim(dataset14),dataset_id14, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset14 = ', hdferr, trim(dataset14) - CALL h5dopen_f (file_id, trim(dataset15),dataset_id15, hdferr) !Open dataset - write(ldt_logunit,*)'EMK: hdferr, dataset15 = ', hdferr, trim(dataset15) - !PRINT*,'ds_id hdferr', dataset_id1, hdferr !PRINT*,'dims maxdims', dims, maxdims @@ -319,446 +287,6 @@ SUBROUTINE GetSMAP_L1B(filename, data1_out, data2_out, data3_out, data4_out, dat #endif END SUBROUTINE GetSMAP_L1B - ! Forked version of GetSMAP_L1B to SMAP files in operation, with - ! fault tolerance and some special logic for older NRT files missing - ! some variables. Eric Kemp/SSAI. - SUBROUTINE GetSMAP_L1B_NRT(filename, tb_time_seconds, & - tb_v_surface_corrected, tb_h_surface_corrected, & - tb_v, tb_h, & - surface_water_fraction_mb_v, surface_water_fraction_mb_h, & - nedt_v, nedt_h, tb_lat, tb_lon, & - tb_qual_flag_v, tb_qual_flag_h, sc_nadir_angle, & - antenna_scan_angle, n, m, ierr) - - ! Imports - use LDT_logMod, only: LDT_logunit, LDT_endrun ! EMK - - ! Arguments - character(*), intent(in) :: filename - real*4, allocatable, intent(out) :: tb_time_seconds(:,:) - real*4, allocatable, intent(out) :: tb_v_surface_corrected(:,:) - real*4, allocatable, intent(out) :: tb_h_surface_corrected(:,:) - real*4, allocatable, intent(out) :: tb_v(:,:), tb_h(:,:) - real*4, allocatable, intent(out) :: surface_water_fraction_mb_v(:,:) - real*4, allocatable, intent(out) :: surface_water_fraction_mb_h(:,:) - real*4, allocatable, intent(out) :: nedt_v(:,:), nedt_h(:,:) - real*4, allocatable, intent(out) :: tb_lat(:,:), tb_lon(:,:) - integer*4, allocatable, intent(out) :: tb_qual_flag_v(:,:) - integer*4, allocatable, intent(out) :: tb_qual_flag_h(:,:) - real*4, allocatable, intent(out) :: sc_nadir_angle(:) - real*4, allocatable, intent(out) :: antenna_scan_angle(:,:) - integer, intent(out) :: m, n - integer, intent(out) :: ierr - -#if (defined USE_HDF5) - - ! Locals - character(100) :: dataset - integer(HID_T) :: file_id, dataset_id, dspace_id - integer(HSIZE_T) :: dims(2), maxdims(2) - integer :: hdferr - logical :: exists, ishdf5 - - ierr = 0 - m = 0 - n = 0 - - ! Make sure file exists - inquire(file=trim(filename), exist=exists) - if (.not. exists) then - write(LDT_logunit,*)'[ERR] Cannot find file ', trim(filename) - ierr = 1 - return - end if - - ! Initialize HDF5 - call h5open_f(hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot initialize HDF5 Fortran interface!' - call h5close_f(hdferr) - ierr = 1 - return - end if - - ! Make sure the file is HDF5 - call h5fis_hdf5_f(trim(filename), ishdf5, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Problem checking if ', trim(filename), & - ' is HDF5' - call h5close_f(hdferr) - ierr = 1 - return - end if - if (.not. ishdf5) then - write(LDT_logunit,*)'[ERR] File ', trim(filename), ' is not HDF5!' - call h5close_f(hdferr) - ierr = 1 - return - end if - - ! Open the file - call h5fopen_f(trim(filename), H5F_ACC_RDONLY_F, file_id, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot open ', trim(filename) - call h5close_f(hdferr) - ierr = 1 - return - end if - - ! Open tb_time_seconds and get dimensions - dataset = "/Brightness_Temperature/tb_time_seconds/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call h5dget_space_f(dataset_id, dspace_id, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & - trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - ierr = 1 - return - end if - call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & - trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - ierr = 1 - return - end if - - ! We have the dimensions for the arrays, so let's allocate here. - n = dims(1) - m = dims(2) - allocate(tb_time_seconds(n,m)) ; tb_time_seconds = 0 - allocate(tb_v_surface_corrected(n,m)); tb_v_surface_corrected = 0 - allocate(tb_h_surface_corrected(n,m)); tb_h_surface_corrected = 0 - allocate(tb_v(n,m)) ; tb_v = 0 - allocate(tb_h(n,m)) ; tb_h = 0 - allocate(surface_water_fraction_mb_v(n,m)) - surface_water_fraction_mb_v = 0 - allocate(surface_water_fraction_mb_h(n,m)) - surface_water_fraction_mb_h = 0 - allocate(nedt_v(n,m)) ; nedt_v = 0 - allocate(nedt_h(n,m)) ; nedt_h = 0 - allocate(tb_lat(n,m)) ; tb_lat = 0 - allocate(tb_lon(n,m)) ; tb_lon = 0 - allocate(tb_qual_flag_v(n,m)) ; tb_qual_flag_v = 0 - allocate(tb_qual_flag_h(n,m)) ; tb_qual_flag_h = 0 - allocate(sc_nadir_angle(n)) ; sc_nadir_angle = 0 - allocate(antenna_scan_angle(n,m)) ; antenna_scan_angle = 0 - - ! Read tb_time_seconds - call read_dataset_real(file_id, dataset, dataset_id, tb_time_seconds, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_v - dataset = "/Brightness_Temperature/tb_v/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_v, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_h - dataset = "/Brightness_Temperature/tb_h/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_h, & - dims, ierr) - if (ierr == 1) return - - ! Get nedt_v - dataset = "/Brightness_Temperature/nedt_v/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, nedt_v, & - dims, ierr) - if (ierr == 1) return - - ! Get nedt_h - dataset = "/Brightness_Temperature/nedt_h/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, nedt_h, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_lat - dataset = "/Brightness_Temperature/tb_lat/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_lat, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_lon - dataset = "/Brightness_Temperature/tb_lon/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_lon, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_qual_flag_v - dataset = "/Brightness_Temperature/tb_qual_flag_v/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_v, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_qual_flag_h - dataset = "/Brightness_Temperature/tb_qual_flag_h/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_h, & - dims, ierr) - if (ierr == 1) return - - ! Get sc_nadir_angle - dataset = "/Spacecraft_Data/sc_nadir_angle/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real_1d(file_id, dataset, dataset_id, sc_nadir_angle, & - dims, ierr) - if (ierr == 1) return - - ! Get antenna_scan_angle - dataset = "/Brightness_Temperature/antenna_scan_angle/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - antenna_scan_angle, dims, ierr) - if (ierr == 1) return - - ! The final four fields are missing in old NRT files. So we have - ! extra logic (via the handle_missing_nrt_field flag) to only - ! deallocate these four arrays if a field is found to be missing at this - ! point. The "uncorrected" fields will be sent back to the caller - ! for potential use, along with the error flag indicating an error - ! was encountered by the HDF5 library. - ! NOTE: If a *read* error occurs, the file will assumed to be - ! corrupt all arrays will be nuked. - ! Get tb_v_surface_corrected - dataset = "/Brightness_Temperature/tb_v_surface_corrected/" - call get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field=.true.) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - tb_v_surface_corrected, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_h_surface_corrected - dataset = "/Brightness_Temperature/tb_h_surface_corrected/" - call get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field=.true.) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - tb_h_surface_corrected, & - dims, ierr) - if (ierr == 1) return - - ! Get surface_water_fraction_mb_v - dataset = "/Brightness_Temperature/surface_water_fraction_mb_v/" - call get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field=.true.) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - surface_water_fraction_mb_v, & - dims, ierr) - if (ierr == 1) return - - ! Get surface_water_fraction_mb_h - dataset = "/Brightness_Temperature/surface_water_fraction_mb_h/" - call get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field=.true.) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - surface_water_fraction_mb_h, & - dims, ierr) - if (ierr == 1) return - - ! Clean up - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - ierr = 0 - - return - - contains - - ! Internal subroutine - subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(out) :: dataset_id - integer, intent(out) :: ierr - logical, optional, intent(in) :: handle_missing_nrt_field - integer :: hdferr - call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot use dataset ', trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - if (present(handle_missing_nrt_field)) then - call freeall(ierr, handle_missing_nrt_field) - else - call freeall(ierr) - endif - end if - return - end subroutine get_dataset_id - - ! Internal subroutine - subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - real*4, intent(inout) :: buf(:,:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine read_dataset_real - - ! Internal subroutine - subroutine read_dataset_real_1d(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - real*4, intent(inout) :: buf(:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine read_dataset_real_1d - - ! Internal subroutine - subroutine read_dataset_integer(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - integer*4, intent(inout) :: buf(:,:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, buf, dims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine read_dataset_integer - - ! Internal subroutine. Warning -- deallocates memory in - ! parent subroutine and resets two variables. This is intended - ! for gracefully handling errors returned from HDF5. - subroutine freeall(ierr, handle_missing_nrt_field) - implicit none - integer, intent(out) :: ierr - logical, optional, intent(in) :: handle_missing_nrt_field - if (allocated(tb_v_surface_corrected)) & - deallocate(tb_v_surface_corrected) - if (allocated(tb_h_surface_corrected)) & - deallocate(tb_h_surface_corrected) - if (allocated(surface_water_fraction_mb_v)) & - deallocate(surface_water_fraction_mb_v) - if (allocated(surface_water_fraction_mb_h)) & - deallocate(surface_water_fraction_mb_h) - ! If special flag is present and set to .true., we will use the - ! "uncorrected" data in the retrieval, and other fields. - if (present(handle_missing_nrt_field)) then - if (handle_missing_nrt_field) then - ierr = 1 - return - end if - end if - if (allocated(tb_time_seconds)) deallocate(tb_time_seconds) - if (allocated(tb_v)) deallocate(tb_v) - if (allocated(tb_h)) deallocate(tb_h) - if (allocated(nedt_v)) deallocate(nedt_v) - if (allocated(nedt_h)) deallocate(nedt_h) - if (allocated(tb_lat)) deallocate(tb_lat) - if (allocated(tb_lon)) deallocate(tb_lon) - if (allocated(tb_qual_flag_v)) deallocate(tb_qual_flag_v) - if (allocated(tb_qual_flag_h)) deallocate(tb_qual_flag_h) - if (allocated(sc_nadir_angle))deallocate(sc_nadir_angle) - if (allocated(antenna_scan_angle)) deallocate(antenna_scan_angle) - m = 0 - n = 0 - ierr = 1 - return - end subroutine freeall -#else - ! Dummy version if LDT was compiled w/o HDF5 support. - write(LDT_logunit,*) & - '[ERR] GetSMAP_L1B_NRT called without HDF5 support!' - write(LDT_logunit,*) & - '[ERR] Recompile LDT with HDF5 support and try again!' - call LDE_endrun() -#endif - end subroutine GetSMAP_L1B_NRT - ! Forked version of GetSMAP_L1B to SMAP files in operations, processing ! a subset of the fields. Also with fault tolerance and some special ! logic for older NRT files missing the tb_v_surface_corrected field. @@ -939,6 +467,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & if (ierr == 1) then ierr = 0 dataset = "/Brightness_Temperature/tb_v/" + write(LDT_logunit,*)'[WARN] Will try substituting ', trim(dataset) call get_dataset_id(file_id, dataset, dataset_id, ierr) if (ierr == 1) return end if @@ -968,7 +497,6 @@ subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & logical :: link_exists integer :: hdferr call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) - write(LDT_logunit,*)'EMK: HERE!!!' if (hdferr == -1) then write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) ierr = 1 From 63f98ff96177b12ab4067485f9ddee276de938a8 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Feb 2023 10:27:53 -0500 Subject: [PATCH 081/328] Updated comments. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 1 + ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 1 + 2 files changed, 2 insertions(+) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 6ed09186d..415c81fd7 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -7,6 +7,7 @@ ! REVISION HISTORY: ! 22 Feb 2022: P.W.LIU; Initial implemetation ! 22 Feb 2022: Yonghwan Kwon; modified for LDT +! 10 Feb 2023: Eric Kemp, modified to output retrievals in netCDF. ! ! DESCRIPTION: RETRIEVE SMAP SM FOR ARFS ! INPUT : SMAP - L1B Brightness Temperature diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 39bcb487a..392727c7b 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -8,6 +8,7 @@ ! 26 Oct 2021: P.W.LIU; Initial implemetation ! 28 Jan 2022: P.W.LIU; CHNAGE OUTPUT COORDINATE TO COMPLY LIS OUTPUT ! 22 Feb 2022: Yonghwan Kwon; modified for LDT +! 10 Feb 2023: Eric Kemp; Added code to resample subset of variables. ! ! DESCRIPTION: SUBROUTINE TO RESAMPLE L1B TB ONTO AIR FORCE GRID !------------------------------------------------------------------------- From cfd7a84357304f205b7e1a59752e607d868bca2f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Feb 2023 11:11:50 -0500 Subject: [PATCH 082/328] Restored original version of SMAPL1BTOL1C_ARFS.F90. Subset version for Air Force is in separate file. --- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 | 32 ++-------------------------- 1 file changed, 2 insertions(+), 30 deletions(-) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 index 8201645d2..8c2b2caad 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 @@ -13,8 +13,8 @@ ! OUTPUT: SMAPTB_ARFSGRIDE_ddmmyyy.dat ! NOTES : Inverse Distance Squared with 0.4 deg serching window !------------------------------------------------------------------------- - -subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) + +subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME) USE VARIABLES USE DATADOMAIN @@ -34,8 +34,6 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) character (len=1) :: Orbit integer :: var_i integer :: L1B_dir_len,L1B_fname_len - integer :: ierr - integer :: rc REAL*4,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B REAL*4,DIMENSION(:,:),ALLOCATABLE :: NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, SCNANG_L1B @@ -49,9 +47,6 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) REAL*4,DIMENSION(2560,1920) :: ARFS_SURWAT_V, ARFS_SURWAT_H, ARFS_WTV, ARFS_WTH REAL :: T1, T2 - - rc = 0 - CALL ARFS_GEO ALLOCATE(ARFS_LAT(arfs_nrow_lat),ARFS_LON(arfs_mcol_lon)) ARFS_LAT = LAT(arfs_geo_lat_lo,arfs_geo_lat_up,-arfs_lat_space) @@ -62,29 +57,6 @@ subroutine SMAPL1BRESAMPLE(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) - ! CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & - ! TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & - ! ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) - ! if (ierr == 1) then - ! if (nrow == 0 .and. mcol == 0) then - ! write(LDT_logunit,*)'[ERR] Problem reading ', trim(SMAPFILE) - ! rc = 1 - ! return - ! else if (.not. allocated(TBV_COR_L1B)) then - ! write(LDT_logunit,*)'[WARN] Could not find TBV_COR_L1B in ', & - ! trim(SMAPFILE) - ! write(LDT_logunit,*)'[WARN] Substituting TBV_L1B...' - ! allocate(TBV_COR_L1B(nrow,mcol)) ; TBV_COR_L1B = TBV_L1B - ! allocate(TBH_COR_L1B(nrow,mcol)) ; TBH_COR_L1B = TBH_L1B - ! allocate(SURWAT_V_L1B(nrow,mcol)) ; SURWAT_V_L1B = -9999 - ! allocate(SURWAT_H_L1B(nrow,mcol)) ; SURWAT_H_L1B = -9999 - ! else - ! write(LDT_logunit,*)'[ERR] Unknown internal error!' - ! write(LDT_logunit,*)'[ERR] Aborting...' - ! call LDT_endrun() - ! end if - ! end if !Input (DATA,LAT,LON,length of row and col); Return(TB in ARFS GRID) CALL L1BTB2ARFS_INVDIS(TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & From e292b68964721aab0ec11e482d704b6c0412b92f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Feb 2023 13:43:25 -0500 Subject: [PATCH 083/328] Some by-hand optimizations, and improvements to indentation. A lot more could be done here with indentations, but I'm leaving this for future work. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 13 +- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 6 - ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 579 ++++++++++---------- ldt/SMAP_E_OPL/invdist_temp2smap.F90 | 208 +++---- 4 files changed, 408 insertions(+), 398 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 415c81fd7..3bc2996b1 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -130,8 +130,11 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& write (LDT_logunit,*) '[INFO] Generating soil moisture retrievals' ARFS_SM=-9999 ARFS_SM_FLAG=-1 - DO i=1,nrow !ROW LON - DO j=1,mcol !COL LAT +! DO i=1,nrow !ROW LON +! DO j=1,mcol !COL LAT + DO j=1,mcol !COL LAT + DO i=1,nrow !ROW LON + tbv = ARFS_TB(i,j) if(UTChr(i,j).ge.0) then @@ -159,8 +162,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& ELSE !PRINT*,i, j, "NO RETRIEVAL" END IF - END DO !jj=1,mcol !COL LAT - END DO !ii=1,nrow !ROW LON +! END DO !jj=1,mcol !COL LAT +! END DO !ii=1,nrow !ROW LON + END DO !ii=1,nrow !ROW LON + END DO !jj=1,mcol !COL LAT !write soil moisture retrieval outputs L1B_dir_len = len_trim(SMAPeOPL%L1Bdir) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index e4e370dbd..8f00d7d36 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -59,12 +59,6 @@ subroutine SMAPL1BRESAMPLE_SUBSET(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) ! READ SMAP_L1B DATA FROM HDF5 ! EMK...Try fault tolerant NRT version. - !CALL GetSMAP_L1B(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, ANTSCN_L1B, SCNANG_L1B, nrow,mcol) - !CALL GetSMAP_L1B_NRT(SMAPFILE, TIME_L1B, TBV_COR_L1B, TBH_COR_L1B, & - ! TBV_L1B, TBH_L1B, SURWAT_V_L1B, SURWAT_H_L1B, & - ! NETD_V_L1B, NETD_H_L1B, LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & - ! ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) CALL GetSMAP_L1B_NRT_SUBSET(SMAPFILE, TIME_L1B, TBV_COR_L1B, & LAT_L1B, LON_L1B, TBVFLAG_L1B, TBHFLAG_L1B, & ANTSCN_L1B, SCNANG_L1B, nrow, mcol, ierr) diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 392727c7b..ee5aa1eee 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -14,294 +14,299 @@ !------------------------------------------------------------------------- MODULE invdist_l1b2arfs - IMPLICIT NONE - - CONTAINS - SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, & - netd_v_l1b, netd_h_l1b, lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & - ref_lat, ref_lon, arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, & - arfs_surwatv, arfs_surwath, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_samplenumv, arfs_samplenumh) + IMPLICIT NONE + CONTAINS + SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, & + netd_v_l1b, netd_h_l1b, lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & + ref_lat, ref_lon, arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, & + arfs_surwatv, arfs_surwath, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_samplenumv, arfs_samplenumh) - INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb - INTEGER(4), PARAMETER :: qualitybit = 0 - REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 - REAL(8) :: gcdist, lat1, lon1, lat2, lon2 - REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, netd_v_l1b, netd_h_l1b - REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle - REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle - INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag - INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag - REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon - REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, arfs_surwatv, arfs_surwath - REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_wt_tbv, arfs_wt_tbh, arfs_wt_nedtv, arfs_wt_nedth, arfs_wt_surwatv, arfs_wt_surwath - INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv, arfs_samplenumh - - !ALLOCATE(zerodistflag(size(ref_lat),size(ref_lon))) - ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) - !INITIAL THE OUTPUT VARIABLES - arfs_tim=0.0 - arfs_tbv_cor=0.0 - arfs_tbh_cor=0.0 - arfs_tbv=0.0 - arfs_tbh=0.0 - arfs_nedtv=0.0 - arfs_nedth=0.0 - arfs_surwatv=0.0 - arfs_surwath=0.0 - arfs_wt_tim=0.0 - arfs_wt_cor_tbv=0.0 - arfs_wt_cor_tbh=0.0 - arfs_wt_tbv=0.0 - arfs_wt_tbh=0.0 - arfs_wt_nedtv=0.0 - arfs_wt_nedth=0.0 - arfs_wt_surwatv=0.0 - arfs_wt_surwath=0.0 - arfs_samplenumv=0.0 - - DO ii = 1,ncols_l1btb - IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN - DO jj = 1,nrows_l1btb - IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN - ! FIND ARFS_GRID (r,c) - c = MINLOC(ABS(lat_l1b(jj,ii)-ref_lat(:)),1) !Lat Direction - r = MINLOC(ABS(lon_l1b(jj,ii)-ref_lon(:)),1) !Lon Direction - rmin=r-5 ; IF (rmin < 1) rmin=1 - rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) - cmin=c-5 ; IF (cmin < 1) cmin=1 - cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) - IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY - k=0 - DO rr = rmin,rmax !Lon direction - DO cc =cmin,cmax !Lat direction - lat1 = DBLE (lat_l1b(jj,ii)*d2r) - lon1 = DBLE (lon_l1b(jj,ii)*d2r) - lat2 = DBLE (ref_lat(cc)*d2r) - lon2 = DBLE (ref_lon(rr)*d2r) - - if(lat1.eq.lat2.and.lon1.eq.lon2) then - gcdist = 0. - else - gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) - endif - - IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE - IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center - zerodistflag (rr,cc) = 1 - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 - END IF - IF ((ABS (surwat_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwatv(rr,cc) = surwat_v_l1b(jj,ii) ; arfs_wt_surwatv(rr,cc) = 1.0 - END IF - IF ((ABS (surwat_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwath(rr,cc) = surwat_h_l1b(jj,ii) ; arfs_wt_surwath(rr,cc) = 1.0 - END IF - IF ((ABS (netd_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedtv(rr,cc) = netd_v_l1b(jj,ii) ; arfs_wt_nedtv(rr,cc) = 1.0 - END IF - IF ((ABS (netd_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedth(rr,cc) = netd_h_l1b(jj,ii) ; arfs_wt_nedth(rr,cc) = 1.0 - END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 - arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb - k=k+1; - END IF - IF ((ABS (tbhl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbh_cor(rr,cc) = tbhl1b_cor(jj,ii) ; arfs_wt_cor_tbh(rr,cc) = 1.0 - arfs_samplenumh(rr,cc)=1 !Sample number only calculate for correct tb - END IF - IF ((ABS (tbvl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv(rr,cc) = tbvl1b(jj,ii) ; arfs_wt_tbv(rr,cc) = 1.0 - END IF - IF ((ABS (tbhl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbh(rr,cc) = tbhl1b(jj,ii) ; arfs_wt_tbh(rr,cc) = 1.0 - END IF - ELSE - IF (zerodistflag (rr,cc).EQ.0) THEN - - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (surwat_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwatv(rr,cc) = arfs_surwatv(rr,cc) + surwat_v_l1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_surwatv(rr,cc) = arfs_wt_surwatv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (surwat_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwath(rr,cc) = arfs_surwath(rr,cc) + surwat_h_l1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_surwath(rr,cc) = arfs_wt_surwath(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (netd_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedtv(rr,cc) = arfs_nedtv(rr,cc) + netd_v_l1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_nedtv(rr,cc) = arfs_wt_nedtv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (netd_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedth(rr,cc) = arfs_nedth(rr,cc) + netd_h_l1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_nedth(rr,cc) = arfs_wt_nedth(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb - k=k+1; - END IF - IF ((ABS (tbhl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbh_cor(rr,cc) = arfs_tbh_cor(rr,cc) + tbhl1b_cor(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_cor_tbh(rr,cc) = arfs_wt_cor_tbh(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - arfs_samplenumh(rr,cc)=arfs_samplenumh(rr,cc)+1.0 !Sample number only calculate for correct tb - END IF - IF ((ABS (tbvl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv(rr,cc) = arfs_tbv(rr,cc) + tbvl1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_tbv(rr,cc) = arfs_wt_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (tbhl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbh(rr,cc) = arfs_tbh(rr,cc) + tbhl1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_tbh(rr,cc) = arfs_wt_tbh(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - END IF !(zerodistflag (rr,cc) = 0) - END IF !(gcdist < 0.0001D0)! - END IF !(gcdist < search_radius) - END DO !cc =cmin,cmax - END DO !rr = rmin,rmax - END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) - END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) - END DO !jj=1,2 - END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) - END DO !ii=1,2 - - !APPLY WEIGHTING FUNCTION FOR RESAMPLING - WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) - arfs_tim = arfs_tim / arfs_wt_tim - END WHERE - WHERE(arfs_surwatv.NE.0.0.AND.arfs_wt_surwatv.NE.0.0) - arfs_surwatv = arfs_surwatv / arfs_wt_surwatv - END WHERE - WHERE(arfs_surwath.NE.0.0.AND.arfs_wt_surwath.NE.0.0) - arfs_surwath = arfs_surwath / arfs_wt_surwath - END WHERE - WHERE(arfs_nedtv.NE.0.0.AND.arfs_wt_nedtv.NE.0.0) - arfs_nedtv = arfs_nedtv / arfs_wt_nedtv - END WHERE - WHERE(arfs_nedth.NE.0.0.AND.arfs_wt_nedth.NE.0.0) - arfs_nedth = arfs_nedth / arfs_wt_nedth - END WHERE - WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) - arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv - END WHERE - WHERE(arfs_tbh_cor.NE.0.0.AND.arfs_wt_cor_tbh.NE.0.0) - arfs_tbh_cor = arfs_tbh_cor / arfs_wt_cor_tbh - END WHERE - WHERE(arfs_tbv.NE.0.0.AND.arfs_wt_tbv.NE.0.0) - arfs_tbv = arfs_tbv / arfs_wt_tbv - END WHERE - WHERE(arfs_tbh.NE.0.0.AND.arfs_wt_tbh.NE.0.0) - arfs_tbh = arfs_tbh / arfs_wt_tbh - END WHERE - - END SUBROUTINE L1BTB2ARFS_INVDIS - - ! EMK...Only process subset of SMAP L1B fields for NRT operations. - SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & - lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, & - sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & - ref_lat, ref_lon, arfs_tim, arfs_tbv_cor) - - INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb - INTEGER(4), PARAMETER :: qualitybit = 0 - REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 - REAL(8) :: gcdist, lat1, lon1, lat2, lon2 - REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor - REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle - REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle - INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag - INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag - REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon - REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor - REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv - INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv - - ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) - !INITIAL THE OUTPUT VARIABLES - arfs_tim=0.0 - arfs_tbv_cor=0.0 - arfs_wt_tim=0.0 - arfs_wt_cor_tbv=0.0 - arfs_samplenumv=0.0 - - DO ii = 1,ncols_l1btb - IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN - DO jj = 1,nrows_l1btb - IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN - ! FIND ARFS_GRID (r,c) - c = MINLOC(ABS(lat_l1b(jj,ii)-ref_lat(:)),1) !Lat Direction - r = MINLOC(ABS(lon_l1b(jj,ii)-ref_lon(:)),1) !Lon Direction - rmin=r-5 ; IF (rmin < 1) rmin=1 - rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) - cmin=c-5 ; IF (cmin < 1) cmin=1 - cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) - IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY - k=0 - DO rr = rmin,rmax !Lon direction - DO cc =cmin,cmax !Lat direction - lat1 = DBLE (lat_l1b(jj,ii)*d2r) - lon1 = DBLE (lon_l1b(jj,ii)*d2r) - lat2 = DBLE (ref_lat(cc)*d2r) - lon2 = DBLE (ref_lon(rr)*d2r) - - if(lat1.eq.lat2.and.lon1.eq.lon2) then - gcdist = 0. - else - gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) - endif - - IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE - IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center - zerodistflag (rr,cc) = 1 - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 - END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 - arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb - k=k+1; - END IF - ELSE - IF (zerodistflag (rr,cc).EQ.0) THEN - - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) - arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb - k=k+1; - END IF - END IF !(zerodistflag (rr,cc) = 0) - END IF !(gcdist < 0.0001D0)! - END IF !(gcdist < search_radius) - END DO !cc =cmin,cmax - END DO !rr = rmin,rmax - END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) - END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) - END DO !jj=1,2 - END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) - END DO !ii=1,2 - - !APPLY WEIGHTING FUNCTION FOR RESAMPLING - WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) - arfs_tim = arfs_tim / arfs_wt_tim - END WHERE - WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) - arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv - END WHERE - - deallocate(zerodistflag) ! EMK cleanup memory - END SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb + INTEGER(4), PARAMETER :: qualitybit = 0 + REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 + REAL(8) :: gcdist, lat1, lon1, lat2, lon2 + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, netd_v_l1b, netd_h_l1b + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle + REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle + INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag + INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag + REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon + REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, arfs_surwatv, arfs_surwath + REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_wt_tbv, arfs_wt_tbh, arfs_wt_nedtv, arfs_wt_nedth, arfs_wt_surwatv, arfs_wt_surwath + INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv, arfs_samplenumh + + !ALLOCATE(zerodistflag(size(ref_lat),size(ref_lon))) + ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) + !INITIAL THE OUTPUT VARIABLES + arfs_tim=0.0 + arfs_tbv_cor=0.0 + arfs_tbh_cor=0.0 + arfs_tbv=0.0 + arfs_tbh=0.0 + arfs_nedtv=0.0 + arfs_nedth=0.0 + arfs_surwatv=0.0 + arfs_surwath=0.0 + arfs_wt_tim=0.0 + arfs_wt_cor_tbv=0.0 + arfs_wt_cor_tbh=0.0 + arfs_wt_tbv=0.0 + arfs_wt_tbh=0.0 + arfs_wt_nedtv=0.0 + arfs_wt_nedth=0.0 + arfs_wt_surwatv=0.0 + arfs_wt_surwath=0.0 + arfs_samplenumv=0.0 + + DO ii = 1,ncols_l1btb + IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN + DO jj = 1,nrows_l1btb + IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN + ! FIND ARFS_GRID (r,c) + c = MINLOC(ABS(lat_l1b(jj,ii)-ref_lat(:)),1) !Lat Direction + r = MINLOC(ABS(lon_l1b(jj,ii)-ref_lon(:)),1) !Lon Direction + rmin=r-5 ; IF (rmin < 1) rmin=1 + rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) + cmin=c-5 ; IF (cmin < 1) cmin=1 + cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) + IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY + k=0 + DO rr = rmin,rmax !Lon direction + DO cc =cmin,cmax !Lat direction + lat1 = DBLE (lat_l1b(jj,ii)*d2r) + lon1 = DBLE (lon_l1b(jj,ii)*d2r) + lat2 = DBLE (ref_lat(cc)*d2r) + lon2 = DBLE (ref_lon(rr)*d2r) - END MODULE invdist_l1b2arfs + if(lat1.eq.lat2.and.lon1.eq.lon2) then + gcdist = 0. + else + gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) + endif + + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE + IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center + zerodistflag (rr,cc) = 1 + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 + END IF + IF ((ABS (surwat_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_surwatv(rr,cc) = surwat_v_l1b(jj,ii) ; arfs_wt_surwatv(rr,cc) = 1.0 + END IF + IF ((ABS (surwat_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_surwath(rr,cc) = surwat_h_l1b(jj,ii) ; arfs_wt_surwath(rr,cc) = 1.0 + END IF + IF ((ABS (netd_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_nedtv(rr,cc) = netd_v_l1b(jj,ii) ; arfs_wt_nedtv(rr,cc) = 1.0 + END IF + IF ((ABS (netd_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_nedth(rr,cc) = netd_h_l1b(jj,ii) ; arfs_wt_nedth(rr,cc) = 1.0 + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 + arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb + k=k+1; + END IF + IF ((ABS (tbhl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbh_cor(rr,cc) = tbhl1b_cor(jj,ii) ; arfs_wt_cor_tbh(rr,cc) = 1.0 + arfs_samplenumh(rr,cc)=1 !Sample number only calculate for correct tb + END IF + IF ((ABS (tbvl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv(rr,cc) = tbvl1b(jj,ii) ; arfs_wt_tbv(rr,cc) = 1.0 + END IF + IF ((ABS (tbhl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbh(rr,cc) = tbhl1b(jj,ii) ; arfs_wt_tbh(rr,cc) = 1.0 + END IF + ELSE + IF (zerodistflag (rr,cc).EQ.0) THEN + + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (surwat_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_surwatv(rr,cc) = arfs_surwatv(rr,cc) + surwat_v_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_surwatv(rr,cc) = arfs_wt_surwatv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (surwat_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_surwath(rr,cc) = arfs_surwath(rr,cc) + surwat_h_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_surwath(rr,cc) = arfs_wt_surwath(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (netd_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_nedtv(rr,cc) = arfs_nedtv(rr,cc) + netd_v_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_nedtv(rr,cc) = arfs_wt_nedtv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (netd_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_nedth(rr,cc) = arfs_nedth(rr,cc) + netd_h_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_nedth(rr,cc) = arfs_wt_nedth(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb + k=k+1; + END IF + IF ((ABS (tbhl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbh_cor(rr,cc) = arfs_tbh_cor(rr,cc) + tbhl1b_cor(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_cor_tbh(rr,cc) = arfs_wt_cor_tbh(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_samplenumh(rr,cc)=arfs_samplenumh(rr,cc)+1.0 !Sample number only calculate for correct tb + END IF + IF ((ABS (tbvl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv(rr,cc) = arfs_tbv(rr,cc) + tbvl1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_tbv(rr,cc) = arfs_wt_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (tbhl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbh(rr,cc) = arfs_tbh(rr,cc) + tbhl1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_tbh(rr,cc) = arfs_wt_tbh(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + END IF !(zerodistflag (rr,cc) = 0) + END IF !(gcdist < 0.0001D0)! + END IF !(gcdist < search_radius) + END DO !cc =cmin,cmax + END DO !rr = rmin,rmax + END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) + END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) + END DO !jj=1,2 + END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) + END DO !ii=1,2 + + !APPLY WEIGHTING FUNCTION FOR RESAMPLING + WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) + arfs_tim = arfs_tim / arfs_wt_tim + END WHERE + WHERE(arfs_surwatv.NE.0.0.AND.arfs_wt_surwatv.NE.0.0) + arfs_surwatv = arfs_surwatv / arfs_wt_surwatv + END WHERE + WHERE(arfs_surwath.NE.0.0.AND.arfs_wt_surwath.NE.0.0) + arfs_surwath = arfs_surwath / arfs_wt_surwath + END WHERE + WHERE(arfs_nedtv.NE.0.0.AND.arfs_wt_nedtv.NE.0.0) + arfs_nedtv = arfs_nedtv / arfs_wt_nedtv + END WHERE + WHERE(arfs_nedth.NE.0.0.AND.arfs_wt_nedth.NE.0.0) + arfs_nedth = arfs_nedth / arfs_wt_nedth + END WHERE + WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) + arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv + END WHERE + WHERE(arfs_tbh_cor.NE.0.0.AND.arfs_wt_cor_tbh.NE.0.0) + arfs_tbh_cor = arfs_tbh_cor / arfs_wt_cor_tbh + END WHERE + WHERE(arfs_tbv.NE.0.0.AND.arfs_wt_tbv.NE.0.0) + arfs_tbv = arfs_tbv / arfs_wt_tbv + END WHERE + WHERE(arfs_tbh.NE.0.0.AND.arfs_wt_tbh.NE.0.0) + arfs_tbh = arfs_tbh / arfs_wt_tbh + END WHERE + + END SUBROUTINE L1BTB2ARFS_INVDIS + + ! EMK...Only process subset of SMAP L1B fields for NRT operations. + SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & + lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, & + sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & + ref_lat, ref_lon, arfs_tim, arfs_tbv_cor) + + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb + INTEGER(4), PARAMETER :: qualitybit = 0 + REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 + REAL(8) :: gcdist, lat1, lon1, lat2, lon2 + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle + REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle + INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag + INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag + REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon + REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor + REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv + INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv + + ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) + !INITIAL THE OUTPUT VARIABLES + arfs_tim=0.0 + arfs_tbv_cor=0.0 + arfs_wt_tim=0.0 + arfs_wt_cor_tbv=0.0 + arfs_samplenumv=0.0 + + DO ii = 1,ncols_l1btb + IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN + DO jj = 1,nrows_l1btb + IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN + lat1 = DBLE (lat_l1b(jj,ii)*d2r) + lon1 = DBLE (lon_l1b(jj,ii)*d2r) + ! FIND ARFS_GRID (r,c) + c = MINLOC(ABS(lat_l1b(jj,ii)-ref_lat(:)),1) !Lat Direction + r = MINLOC(ABS(lon_l1b(jj,ii)-ref_lon(:)),1) !Lon Direction + rmin=r-5 ; IF (rmin < 1) rmin=1 + rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) + cmin=c-5 ; IF (cmin < 1) cmin=1 + cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) + IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY + k=0 + ! DO rr = rmin,rmax !Lon direction + ! DO cc =cmin,cmax !Lat direction + DO cc =cmin,cmax !Lat direction + lat2 = DBLE (ref_lat(cc)*d2r) + DO rr = rmin,rmax !Lon direction + lon2 = DBLE (ref_lon(rr)*d2r) + + if(lat1.eq.lat2.and.lon1.eq.lon2) then + gcdist = 0. + else + gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) + endif + + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE + IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center + zerodistflag (rr,cc) = 1 + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 + arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb + k=k+1; + END IF + ELSE + IF (zerodistflag (rr,cc).EQ.0) THEN + + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + END IF + IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb + k=k+1; + END IF + + END IF !(zerodistflag (rr,cc) = 0) + END IF !(gcdist < 0.0001D0)! + END IF !(gcdist < search_radius) + ! END DO !cc =cmin,cmax + ! END DO !rr = rmin,rmax + END DO !rr = rmin,rmax + END DO !cc =cmin,cmax + + END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) + END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) + END DO !jj=1,2 + END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) + END DO !ii=1,2 + + !APPLY WEIGHTING FUNCTION FOR RESAMPLING + WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) + arfs_tim = arfs_tim / arfs_wt_tim + END WHERE + WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) + arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv + END WHERE + + deallocate(zerodistflag) ! EMK cleanup memory + END SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET + + END MODULE invdist_l1b2arfs diff --git a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 index 0f7e9be14..9bb418404 100644 --- a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 +++ b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 @@ -4,112 +4,118 @@ ! SMAP RESOLUTIN AT ARFS GRID !======================================================================= MODULE invdist_temp2smap - IMPLICIT NONE + IMPLICIT NONE - CONTAINS - !SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon,arfs_fine_wt,arfs_fine_temp,arfs_wt,arfs_smap_temp) - SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon,arfs_smap_temp) + CONTAINS + !SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon,arfs_fine_wt,arfs_fine_temp,arfs_wt,arfs_smap_temp) + SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon,arfs_smap_temp) - INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb - REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 - REAL(8) :: gcdist, lat1, lon1, lat2, lon2 - REAL*8 ,DIMENSION(:), ALLOCATABLE :: arfs_lat, arfs_lon - REAL*8 ,DIMENSION(:), ALLOCATABLE :: arfs_fine_lat, arfs_fine_lon - REAL*4,DIMENSION(2560,1920) :: arfs_temp, arfs_smap_temp, arfs_wt - REAL*4,DIMENSION(7680,5760) :: arfs_fine_temp, arfs_fine_wt - INTEGER(4),DIMENSION(2560,1920):: zerodistflag - INTEGER(4),DIMENSION(7680,5760):: zerodistflag_fine + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb + REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 + REAL(8) :: gcdist, lat1, lon1, lat2, lon2 + REAL*8 ,DIMENSION(:), ALLOCATABLE :: arfs_lat, arfs_lon + REAL*8 ,DIMENSION(:), ALLOCATABLE :: arfs_fine_lat, arfs_fine_lon + REAL*4,DIMENSION(2560,1920) :: arfs_temp, arfs_smap_temp, arfs_wt + REAL*4,DIMENSION(7680,5760) :: arfs_fine_temp, arfs_fine_wt + INTEGER(4),DIMENSION(2560,1920):: zerodistflag + INTEGER(4),DIMENSION(7680,5760):: zerodistflag_fine - !INITIAL THE OUTPUT VARIABLES - zerodistflag=0 - zerodistflag_fine=0 - arfs_smap_temp=0 - arfs_wt=0 - arfs_fine_temp=0 - arfs_fine_wt=0 - !DISAGGREGATE ARFS TEMP TO FINEER GRID (~3km) - DO ii=1,1920 + !INITIAL THE OUTPUT VARIABLES + zerodistflag=0 + zerodistflag_fine=0 + arfs_smap_temp=0 + arfs_wt=0 + arfs_fine_temp=0 + arfs_fine_wt=0 + !DISAGGREGATE ARFS TEMP TO FINEER GRID (~3km) + DO ii=1,1920 !DO ii=522,524 - c = MINLOC(ABS(arfs_lat(ii)-arfs_fine_lat(:)),1) !Lat Direction r: row in fine scale - !PRINT*, arfs_fine_lat(r), arfs_lat(ii) - DO jj=1,2560 + lat1 = DBLE (arfs_lat(ii)*d2r) + c = MINLOC(ABS(arfs_lat(ii)-arfs_fine_lat(:)),1) !Lat Direction r: row in fine scale + !PRINT*, arfs_fine_lat(r), arfs_lat(ii) + cmin=c-3 ; IF (cmin < 1) cmin=1 + cmax=c+3 ; IF (cmax > size(arfs_fine_lat)) cmax=size(arfs_fine_lat) + + DO jj=1,2560 !DO jj=82,84 - r = MINLOC(ABS(arfs_lon(jj)-arfs_fine_lon(:)),1) !Lat Direction c: colume in fine scale - !PRINT*, arfs_fine_lon(c), arfs_lon(jj) - cmin=c-3 ; IF (cmin < 1) cmin=1 - cmax=c+3 ; IF (cmax > size(arfs_fine_lat)) cmax=size(arfs_fine_lat) - rmin=r-3 ; IF (rmin < 1) rmin=1 - rmax=r+3 ; IF (rmax > size(arfs_fine_lon)) rmax=size(arfs_fine_lon) - !PRINT*,'cmin cmax', cmin, cmax, size(arfs_fine_lon) - DO rr=rmin,rmax - DO cc=cmin,cmax - lat1 = DBLE (arfs_lat(ii)*d2r) - lon1 = DBLE (arfs_lon(jj)*d2r) - lat2 = DBLE (arfs_fine_lat(cc)*d2r) - lon2 = DBLE (arfs_fine_lon(rr)*d2r) - !PRINT*, lat1, lon1, lat2, lon2 - !gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) !original - !---------------------------------------kyh - if(lat1.eq.lat2.and.lon1.eq.lon2) then - gcdist = 0. - else - gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) - endif - !---------------------------------------kyh - !PRINT*, lat1, lon1, lat2, lon2, gcdist - !PRINT*, arfs_temp(ii,jj) - IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE - !PRINT*,'HERE 0' - IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center - zerodistflag_fine(rr,cc) = 1 - !PRINT*,'HERE 01' - IF ((ABS (arfs_temp(jj,ii)-(-9999.000)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(0) - arfs_fine_temp(rr,cc) = arfs_temp(jj,ii) ; arfs_fine_wt(rr,cc) = 1.0 - !PRINT*,'Here 1' - ENDIF - ELSE - IF (zerodistflag_fine(rr,cc).EQ.0) THEN !To maintain the corresponding pixel has the same value - IF ((ABS (arfs_temp(jj,ii)-(-9999.000)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(0) - arfs_fine_temp(rr,cc) = arfs_fine_temp(rr,cc)+arfs_temp(jj,ii) / SNGL(gcdist) - arfs_fine_wt(rr,cc) = arfs_fine_wt(rr,cc) + 1.0 / SNGL(gcdist) - !PRINT*,'Here 2' - ENDIF - ENDIF !(zerodistflag_fine(rr,cc).NE.0) - ENDIF !IF (gcdist < 0.0001D0) - ENDIF !(gcdist < search_radius) - ENDDO !cc=cmin,cmax - ENDDO !rr=rmin,rmax - - ENDDO !jj=1:2560 - ENDDO !ii=1,1920 - WHERE(arfs_fine_temp.NE.0.0.AND.arfs_fine_wt.NE.0.0) - arfs_fine_temp=arfs_fine_temp/arfs_fine_wt - ENDWHERE - !UPSCALL ARFS FINE TEMP TO ARFS GRID (at ~33km) - DO ii=1,1920 - c=3*ii-1 !3x3 FINE GRID EQ TO A ARFS GRID - DO jj=1,2560 - r=3*jj-1 !3x3 FINE GRID EQ TO A ARFS GRID - cmin=c-5 ; IF (cmin < 1) cmin=1 - cmax=c+5 ; IF (cmax > size(arfs_fine_lat)) cmax=size(arfs_fine_lat) - rmin=r-5 ; IF (rmin < 1) rmin=1 - rmax=r+5 ; IF (rmax > size(arfs_fine_lon)) rmax=size(arfs_fine_lon) - DO rr=rmin,rmax - DO cc=cmin,cmax - IF (abs(arfs_fine_temp(rr,cc)).GT.1.0D-7) THEN !DO WHEN T ~0 (change to fillvalue) - arfs_smap_temp(jj,ii)=arfs_smap_temp(jj,ii)+arfs_fine_temp(rr,cc); arfs_wt(jj,ii)=arfs_wt(jj,ii)+1.0 !Weight the point 1 - ENDIF - ENDDO !cc=cmin,cmax - ENDDO !rr=rmin,rmax - ENDDO !jj=1:2560 - ENDDO !ii=1:1920 - WHERE(arfs_smap_temp.NE.0.0.AND.arfs_wt.NE.0.0) - arfs_smap_temp=arfs_smap_temp/arfs_wt - ENDWHERE - WHERE(arfs_smap_temp.EQ.0.0) - arfs_smap_temp=-9999 - ENDWHERE + lon1 = DBLE (arfs_lon(jj)*d2r) + r = MINLOC(ABS(arfs_lon(jj)-arfs_fine_lon(:)),1) !Lat Direction c: colume in fine scale + !PRINT*, arfs_fine_lon(c), arfs_lon(jj) + rmin=r-3 ; IF (rmin < 1) rmin=1 + rmax=r+3 ; IF (rmax > size(arfs_fine_lon)) rmax=size(arfs_fine_lon) + !PRINT*,'cmin cmax', cmin, cmax, size(arfs_fine_lon) + !DO rr=rmin,rmax + ! DO cc=cmin,cmax + DO cc=cmin,cmax + lat2 = DBLE (arfs_fine_lat(cc)*d2r) + DO rr=rmin,rmax + lon2 = DBLE (arfs_fine_lon(rr)*d2r) + !PRINT*, lat1, lon1, lat2, lon2 + !gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) !original + !---------------------------------------kyh + if(lat1.eq.lat2.and.lon1.eq.lon2) then + gcdist = 0. + else + gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) + endif + !---------------------------------------kyh + !PRINT*, lat1, lon1, lat2, lon2, gcdist + !PRINT*, arfs_temp(ii,jj) + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE + !PRINT*,'HERE 0' + IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center + zerodistflag_fine(rr,cc) = 1 + !PRINT*,'HERE 01' + IF ((ABS (arfs_temp(jj,ii)-(-9999.000)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(0) + arfs_fine_temp(rr,cc) = arfs_temp(jj,ii) ; arfs_fine_wt(rr,cc) = 1.0 + !PRINT*,'Here 1' + ENDIF + ELSE + IF (zerodistflag_fine(rr,cc).EQ.0) THEN !To maintain the corresponding pixel has the same value + IF ((ABS (arfs_temp(jj,ii)-(-9999.000)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(0) + arfs_fine_temp(rr,cc) = arfs_fine_temp(rr,cc)+arfs_temp(jj,ii) / SNGL(gcdist) + arfs_fine_wt(rr,cc) = arfs_fine_wt(rr,cc) + 1.0 / SNGL(gcdist) + !PRINT*,'Here 2' + ENDIF + ENDIF !(zerodistflag_fine(rr,cc).NE.0) + ENDIF !IF (gcdist < 0.0001D0) + ENDIF !(gcdist < search_radius) + ! ENDDO !cc=cmin,cmax + ! ENDDO !rr=rmin,rmax + ENDDO !rr=rmin,rmax + ENDDO !cc=cmin,cmax + ENDDO !jj=1:2560 + ENDDO !ii=1,1920 + WHERE(arfs_fine_temp.NE.0.0.AND.arfs_fine_wt.NE.0.0) + arfs_fine_temp=arfs_fine_temp/arfs_fine_wt + ENDWHERE + !UPSCALL ARFS FINE TEMP TO ARFS GRID (at ~33km) + DO ii=1,1920 + c=3*ii-1 !3x3 FINE GRID EQ TO A ARFS GRID + cmin=c-5 ; IF (cmin < 1) cmin=1 + cmax=c+5 ; IF (cmax > size(arfs_fine_lat)) cmax=size(arfs_fine_lat) + DO jj=1,2560 + r=3*jj-1 !3x3 FINE GRID EQ TO A ARFS GRID + rmin=r-5 ; IF (rmin < 1) rmin=1 + rmax=r+5 ; IF (rmax > size(arfs_fine_lon)) rmax=size(arfs_fine_lon) + ! DO rr=rmin,rmax + ! DO cc=cmin,cmax + DO cc=cmin,cmax + DO rr=rmin,rmax + IF (abs(arfs_fine_temp(rr,cc)).GT.1.0D-7) THEN !DO WHEN T ~0 (change to fillvalue) + arfs_smap_temp(jj,ii)=arfs_smap_temp(jj,ii)+arfs_fine_temp(rr,cc); arfs_wt(jj,ii)=arfs_wt(jj,ii)+1.0 !Weight the point 1 + ENDIF + ENDDO !cc=cmin,cmax + ENDDO !rr=rmin,rmax + ENDDO !jj=1:2560 + ENDDO !ii=1:1920 + WHERE(arfs_smap_temp.NE.0.0.AND.arfs_wt.NE.0.0) + arfs_smap_temp=arfs_smap_temp/arfs_wt + ENDWHERE + WHERE(arfs_smap_temp.EQ.0.0) + arfs_smap_temp=-9999 + ENDWHERE - END SUBROUTINE RESAMPLETEMP + END SUBROUTINE RESAMPLETEMP END MODULE invdist_temp2smap From 0524dced82ff687debe34491be851adcbada6660 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Feb 2023 17:00:16 -0500 Subject: [PATCH 084/328] Fixed bug in resampling code. --- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index ee5aa1eee..11110d890 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -244,7 +244,8 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & rmax=r+5 ; IF (rmax > size(ref_lon)) rmax=size(ref_lon) cmin=c-5 ; IF (cmin < 1) cmin=1 cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) - IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY +! IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY + IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,ii),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY k=0 ! DO rr = rmin,rmax !Lon direction ! DO cc =cmin,cmax !Lat direction From f7e665afdf5915dc107f1ed2cc7a3cf3ab81d73c Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Feb 2023 10:27:23 -0500 Subject: [PATCH 085/328] First attempt at reading USAFSI for snow depth. Not tested, and probably not sufficiently fault tolerant for production. --- ldt/SMAP_E_OPL/readUSAFSI.F90 | 188 ++++++++++++++++++++++++++++++++++ 1 file changed, 188 insertions(+) create mode 100644 ldt/SMAP_E_OPL/readUSAFSI.F90 diff --git a/ldt/SMAP_E_OPL/readUSAFSI.F90 b/ldt/SMAP_E_OPL/readUSAFSI.F90 new file mode 100644 index 000000000..516947817 --- /dev/null +++ b/ldt/SMAP_E_OPL/readUSAFSI.F90 @@ -0,0 +1,188 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT---------------------- + +#include "LDT_misc.h" +#include "LDT_NetCDF_inc.h" +!BOP +! +! !ROUTINE: readUSAFSI +! \label{readUSAFSI} +! +! !REVISION HISTORY: +! 13 Feb 2023: Eric Kemp, Initial Specification +! +! !INTERFACE: +subroutine readUSASI(n, yyyymmdd, hh, SnowDepth) + +! !USES: + use LDT_coreMod + use LDT_logMod + use LDT_smap_e_oplMod + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: n + character*8 :: yyyymmdd + character*2 :: hh + real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + +!EOP + character*255 :: fname + character*8 :: yyyymmdd_snow + character*4 :: yyyy_snow + character*2 :: mm_snow, dd_snow, hh_snow + logical :: file_exists + integer :: yr, mo, da, hr + integer :: nn + integer :: ierr + + external :: create_USAFSI_filename + external :: read_USAFSI_data + + SnowDepth = LDT_rc%udef + + yyyymmdd_snow = yyyymmdd + yyyy_snow = yyyymmdd(1:4) + mm_snow = yyyymmdd(5:6) + dd_snow = yyyymmdd(7:8) + hh_snow = hh + + read(yyyy_snow, *, iostat=ierr) yr + read(mm_snow, *, iostat=ierr) mo + read(dd_snow, *, iostat=ierr) da + read(hh_snow, *, iostat=ierr) hr + + nn = 0 + do while (nn <= 24) + + call create_USAFSI_filename(SMAPeOPL%LISsnowdir, & + yyyymmdd_snow, hh_snow, fname) + inquire(file=trim(fname), exist=file_exists) + + if (file_exists) then + write(LDT_logunit,*) '[INFO] Reading snow depth from ', trim(fname) + call read_USAFSI_data(n, fname, SnowDepth) + write(LDT_logunit,*) '[INFO] Finished reading snow outputs from ', & + trim(fname) + exit + else + hr = hr - 1 + if (hr < 0) then + da = da - 1 + hr = 23 + if (da == 0) then + mo = mo - 1 + if (mo == 0) then + yr = yr - 1 + mo = 12 + da = 31 + else + if (mo == 1 .or. & + mo == 3 .or. & + mo == 5 .or. & + mo == 7 .or. & + mo == 8 .or. & + mo == 10 .or. & + mo == 12) then + da = 31 + elseif (mo == 2) then + if (mod(yr,4) == 0) then + da = 29 + else + da = 28 + endif + else + da = 30 + endif + endif + endif + endif + + write(unit=yyyy_snow, fmt='(i4.4)') yr + write(unit=mm_snow, fmt='(i2.2)') mo + write(unit=dd_snow, fmt='(i2.2)') da + write(unit=hh_snow, fmt='(i2.2)') hr + yyyymmdd_snow = trim(yyyy_snow) // trim(mm_snow) // trim(dd_snow) + + nn = nn + 1 + endif + end do +end subroutine readUSASI + +!BOP +! +! !ROUTINE: read_USAFSI_data +! \label{read_USAFSI_data} +! +! !INTERFACE: +subroutine read_USAFSI_data(n, fname, SnowDepth) +! +! !USES: + use LDT_logMod + use LDT_coreMod + use LDT_smap_e_oplMod +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! +! !INPUT PARAMETERS: +! + integer, intent(in) :: n + character (len=*) :: fname +!EOP + + integer :: ios, nid + integer :: snowdepthid + real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + ios = nf90_open(path=trim(fname), mode=NF90_NOWRITE, ncid=nid) + call LDT_verify(ios, 'Error opening file ' // trim(fname)) + + ios = nf90_inq_varid(nid, 'snoanl', snowdepthid) + call LDT_verify(ios, 'Error nf90_inq_varid: snoanl') + + ios = nf90_get_var(nid, snowdepthid, SnowDepth, & + start=(/1, 1/), & + count=(/LDT_rc%lnc(n), LDT_rc%lnr(n)/)) + call LDT_verify(ios, 'Error nf90_get_var: snoanl') + + ios = nf90_close(ncid=nid) + call LDT_verify(ios, 'Error closing file ' // trim(fname)) + +#endif + +end subroutine read_USAFSI_data + +!BOP +! !ROUTINE: create_USAFSI_filename +! \label{create_USAFSI_filename} +! +! !INTERFACE: +subroutine create_USAFSI_filename(LISdir, yyyymmdd, hh, filename) +! !USES: + + implicit none + +! !ARGUMENTS: + character(*), intent(in) :: LISdir + character(8), intent(in) :: yyyymmdd + character(2), intent(in) :: hh + character(*), intent(out) :: filename +!EOP + + filename = trim(LISdir) // '/USAFSI_' // trim(yyyymmdd) & + // trim(hh) // '.nc' + +end subroutine create_USAFSI_filename + From f4bc775b5d94ee23b31394b86faa9421d1bee496 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Feb 2023 11:44:40 -0500 Subject: [PATCH 086/328] Fixed subroutine name. Replaced call for snow depth data. Still need to test. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 5 ++++- ldt/SMAP_E_OPL/readUSAFSI.F90 | 4 ++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index b8599c571..222841e34 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -226,6 +226,8 @@ subroutine LDT_smap_e_oplRun(n) integer :: doy_pre, doy_curr integer :: rc + external :: readUSAFSI + ! Resample SMAP L1B to L1C call search_SMAPL1B_files(SMAPeOPL%L1Bdir,SMAPeOPL%date_curr,& SMAPeOPL%L1Btype) @@ -441,7 +443,8 @@ subroutine LDT_smap_e_oplRun(n) read_L1Bdata = .false. ! Get snow information from LIS outputs - call readLIS_snow(n,yyyymmdd,hh,SnowDepth) + !call readLIS_snow(n,yyyymmdd,hh,SnowDepth) + call readUSAFSI(n, yyyymmdd, hh, SnowDepth) ! Retrieve SMAP soil moisture ! get DOY diff --git a/ldt/SMAP_E_OPL/readUSAFSI.F90 b/ldt/SMAP_E_OPL/readUSAFSI.F90 index 516947817..ec7f693c5 100644 --- a/ldt/SMAP_E_OPL/readUSAFSI.F90 +++ b/ldt/SMAP_E_OPL/readUSAFSI.F90 @@ -19,7 +19,7 @@ ! 13 Feb 2023: Eric Kemp, Initial Specification ! ! !INTERFACE: -subroutine readUSASI(n, yyyymmdd, hh, SnowDepth) +subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) ! !USES: use LDT_coreMod @@ -115,7 +115,7 @@ subroutine readUSASI(n, yyyymmdd, hh, SnowDepth) nn = nn + 1 endif end do -end subroutine readUSASI +end subroutine readUSAFSI !BOP ! From ebbf44400c3d2a872b7cde9ddf1b0d9de8068736 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 13 Feb 2023 14:41:59 -0500 Subject: [PATCH 087/328] Revert "Update landcover options in doc" This reverts commit 4810fc8c4fc9be2c922e72b8bed60ebb95d8c680. --- ldt/configs/ldt.config.adoc | 505 +++--------------------------------- 1 file changed, 36 insertions(+), 469 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 5f9b04ee3..6b3535e5e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -28,7 +28,6 @@ Not all options described here are available in the public version of LDT. |"`OPTUE parameter processing`" |Process the OPT/UE output to generate optimized parameters |"`USAFSI analysis`" |USAF Snow and Ice analysis |"`LISHydro preprocessing for WRFHydro`" |Preprocessing Option for WRFHydro -|"`OPL E SMAP soil moisture retrieval`" |Operational 9-km enhanced SMAP soil moisture retrieval |=== .Example _ldt.config_ entry @@ -36,7 +35,7 @@ Not all options described here are available in the public version of LDT. LDT running mode: "LSM parameter processing" .... -`Processed LSM parameter filename:` specifies the output filename (with netcdf extension) of the LSM parameters processed in LDT to go into LIS. See a sample _lis_input.d01.nc_ (Appendix <>) file for a complete specification description. +`Processed LSM parameter filename:` specifies the output filename (with netcdf extension) of the LSM parameters processed in LDT to go into LIS. See a sample _lis_input.d01.nc_ (Appendix <>) file for a complete specification description. .Example _ldt.config_ entry .... @@ -94,7 +93,6 @@ Surface model types: "LSM" |Mosaic |Mosaic |HySSIB |HySSIB |CLSMF2.5 |Catchment, Fortuna 2.5 -|SnowModel |SnowModel |SAC.3.5.6 |Sacramento |SNOW17 |Snow17 |RDHM.3.5.6 |Sacramento+snow17 @@ -367,7 +365,7 @@ Forcing climatology temporal frequency of data: "6hr" Bayesian merging seasonal stratification type: .... -`Forcing variables list file:` specifies the file containing the list of forcing variables to be used. (Please refer to Section "`Specification of Input Forcing Variables`" in the _LIS Users' Guide_ for a complete specification description of this file.) +`Forcing variables list file:` specifies the file containing the list of forcing variables to be used. (Please refer to Section "`Specification of Input Forcing Variables`" in the _LIS Users' Guide_ for a complete specification description of this file.) .Example _ldt.config_ entry .... @@ -420,33 +418,19 @@ The default value is 0. Add buffer to parameter grid domain: 0 .... -`Buffer count in x-direction:` adds a set number of pixels that buffer -around a parameter file target domain in the x-direction. +`Buffer count in x-direction:` adds a set number of pixels that buffer +around a parameter file target domain, both in the x- and y-directions. Acceptable values are: [cols="<,<",] |=== |Value |Description -|0 |Results in no buffer added -|1 (or greater) |Buffer points included -|=== - -The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. - -`Buffer count in y-direction:` adds a set number of pixels that buffer -around a parameter file target domain in the y-direction. -Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|0 |Results in no buffer added -|1 (or greater) |Buffer points included +|"`0`" |No buffer added +|"`1`" (or greater) |Buffer points included |=== -The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. +The default value is 5, and only activated if buffer option is selected. .Example _ldt.config_ entry .... @@ -618,7 +602,7 @@ Output naming style: "3 level hierarchy" [[ssec-domainspec]] === Domain specification -This section of the config file specifies the LIS running domain (domain over which the simulation is carried out). The specification of the LIS Run domain section depends on the type of LIS domain and projection used. Section <> lists the projections that LIS supports. +This section of the config file specifies the LIS running domain (domain over which the simulation is carried out). The specification of the LIS Run domain section depends on the type of LIS domain and projection used. Section <> lists the projections that LIS supports. `Map projection of the LIS domain:` specifies the output LIS domain grid to be used with LIS. Acceptable values are: @@ -646,7 +630,7 @@ Map projection of the LIS domain: latlon [[sssec-run_latlon]] ==== Cylindrical lat/lon -This section describes how to specify a cylindrical latitude/longitude projection. See Appendix <> for more details about setting these values. +This section describes how to specify a cylindrical latitude/longitude projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -661,7 +645,7 @@ Run domain resolution (dy): 0.25 [[sssec-run_lambert]] ==== Lambert conformal -This section describes how to specify a Lambert conformal projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Lambert conformal projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -678,7 +662,7 @@ Run domain y-dimension size: 30 [[sssec-run_gaussian]] ==== Gaussian -This section describes how to specify a Gaussian projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Gaussian projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -693,7 +677,7 @@ Run domain number of lat circles: 95 [[sssec-run_ps]] ==== Polar stereographic -This section describes how to specify a polar stereographic projection. See Appendix <> for more details about setting these values. +This section describes how to specify a polar stereographic projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -710,7 +694,7 @@ Run domain y-dimension size: 30 [[sssec-run_hrap]] ==== HRAP -This section describes how to specify a HRAP projection. See Appendix <> for more details about setting these values. +This section describes how to specify a HRAP projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -724,7 +708,7 @@ Run domain y-dimension size: 774 [[sssec-run_mercator]] ==== Mercator -This section describes how to specify a Mercator projection. See Appendix <> for more details about setting these values. +This section describes how to specify a Mercator projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -741,7 +725,7 @@ ifdef::devonly[] [[sssec-run_utm]] ==== UTM -This section describes how to specify a UTM projection. See Appendix <> for more details about setting these values. +This section describes how to specify a UTM projection. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -767,7 +751,7 @@ endif::devonly[] |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. |MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. -|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. +|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. |USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html @@ -775,8 +759,6 @@ endif::devonly[] |VIC412 |Variable Infiltration Capacity model, v4.1.2, UMD land cover. |ISA |Impervious Surface Area (ISA) landcover dataset. |CLM45 |CLM-4.5 landcover dataset. -|NALCMS_SM |SnowModel-based NALCMS landcover dataset. -|NALCMS_SM_IGBPNCEP |SnowModel-based NALCMS landcover dataset with IGBPNCEP-mapped classes. |CONSTANT |Ability to set a constant landcover type for a set classification. |=== @@ -859,7 +841,7 @@ Landcover fill radius: 3. # Number of pixels to search for neighbor Landcover fill value: 5. # Static value to fill where missing .... -This section also outlines the domain specifications of the landcover (and for now landmask) data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying landcover data. Note: The Landcover grid domain inputs below are really only required for the "`_LIS`" data source options and that do not include "`_Native`" in the data source entries. All native parameters do not require the below inputs for LDT. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of the landcover (and for now landmask) data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying landcover data. Note: The Landcover grid domain inputs below are really only required for the "`_LIS`" data source options and that do not include "`_Native`" in the data source entries. All native parameters do not require the below inputs for LDT. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -928,7 +910,7 @@ Landmask map projection: latlon This section also outlines the domain specifications of the land water/mask data. The landmask map projection and extents are only needed if you specify "`readin`" for mask type and if the landmask data source is "`MOD44W`" or "`_LIS`". -If the map projection of parameter data is specified to be "`latlon`", the following extents and resolution configuration should be used for specifying landmask data. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be "`latlon`", the following extents and resolution configuration should be used for specifying landmask data. See Appendix <> for more details about setting these values. Future landmask data sets will have the projection, grid extents and resolution on the data reader side and not needed to be specified in the _ldt.config_ file, depending on the data source. @@ -1054,7 +1036,7 @@ Inland waterbody spatial transform: tile Regional mask data source: "none" .... -`Regional mask file:` specifies the location of a regional mask file. This file can be either an index-based state, country, basin, catchment, etc. map used to mask further beyond the main water/land mask. +`Regional mask file:` specifies the location of a regional mask file. This file can be either an index-based state, country, basin, catchment, etc. map used to mask further beyond the main water/land mask. .Example _ldt.config_ entry .... @@ -1093,7 +1075,7 @@ Regional mask spatial transform: mode This section also outlines the domain specifications of the regional-based land mask data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying regional mask data. -See Appendix <> for more details about setting these values. +See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1335,7 +1317,7 @@ Irrigation fraction map projection: latlon .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying irrigation data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying irrigation data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1507,7 +1489,7 @@ Soils fill value: 0.33 Porosity fill value: 0.30 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soils data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soils data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1631,20 +1613,6 @@ Soil texture spatial transform: none `Soil texture fill value:` indicates which soil texture value to be used if an arbitrary value fill is needed. (For example, when the landmask indicates a land point but no existing soil texture value, a value of 6 could be assigned if no nearest neighbor values exists to fill). -`Soil texture fill value for Antarctica:` indicates which soil texture value to be used if an arbitrary value fill is needed south of 60S. If not specified, value of `Soil texture fill value:` will be used. - -`Soil texture force exclusion of water points during fill:` indicates whether to force exclusion of water points when filling soil texture. Required when using STATSGOFAO south of 60S (texture is set to all water) and multiple surface model types are used. - -[cols="<,<",] -|=== -|Value |Description - -|.false. |do not enable -|.true. |enable -|=== - -Defaults to `.false.`. - `Soil texture fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. .Example _ldt.config_ entry @@ -1652,11 +1620,9 @@ Defaults to `.false.`. Soil texture fill option: neighbor Soil texture fill radius: 3. Soil texture fill value: 6. -Soil texture fill value for Antarctica: 16 -Soil texture force exclusion of water points during fill: .true. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1693,7 +1659,7 @@ Soil color map: Soil color spatial transform: none .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil color data, data source option "`FAO`" or has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil color data, data source option "`FAO`" or has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1730,7 +1696,6 @@ Current options include: |SRTM_LIS |Similar dataset as to the above one but processed by LISF-team. |CONSTANT |User can set a constant elevation, slope or aspect class. |MERIT_1K |The MERIT elevation map, but processed by LISF-team to have a resolution '`0.008333`'. See: http://hydro.iis.u-tokyo.ac.jp/~yamadai/MERIT_DEM/index.html -|NED_SM | SnowModel-based National Elevation Dataset (NED) topographic fields. |=== .Example _ldt.config_ entry @@ -1859,7 +1824,7 @@ Aspect fill value: 2.0 Topography spatial transform: tile .... -This section should also specify the domain specifications of the topography data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying topography data, especially if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +This section should also specify the domain specifications of the topography data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying topography data, especially if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -1958,7 +1923,7 @@ Albedo fill radius: 2. Albedo fill value: 0.12 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying albedo data where the albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying albedo data where the albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2029,7 +1994,7 @@ Max snow albedo fill radius: 3. Max snow albedo fill value: 0.42 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying max snow albedo data, where the max snow albedo albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying max snow albedo data, where the max snow albedo albedo data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2130,7 +2095,7 @@ Greenness maximum fill value: 0.80 Greenness minimum fill value: 0.05 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying greenness data source, if the option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying greenness data source, if the option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2243,7 +2208,7 @@ LAI maximum fill value: 4 LAI minimum fill value: 1 .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying LAI/SAI data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying LAI/SAI data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2311,7 +2276,7 @@ Slope type fill radius: 2. Slope type fill value: 1. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying slope type data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying slope type data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2397,7 +2362,7 @@ Bottom temperature fill value: 287.0 Bottom temperature topographic downscaling: none .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying bottom temperature parameter data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying bottom temperature parameter data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2417,136 +2382,6 @@ Bottom temperature resolution (dy): 0.2500 Noah-MP PBL Height Value: 900. # in meters .... -Miguez-Macho and Fan (MMF) Groundwater Parameters - -IMPORTANT: Currently, Noah-MP.4.0.1 is the only land surface model that supports the MMF groundwater scheme. - -`Process Noah-MP-4.0.1 MMF groundwater parameters:` specifies whether to process Noah-MP-4.0.1 MMF groundwater parameters. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|.false. | do not process (default) -|.true. | process -|=== - -.Example _ldt.config_ entry -.... -Process Noah-MP-4.0.1 MMF groundwater parameters: .true. -.... - -[NOTE] -==== -The Noah-MP-4.0.1 parameters are only needed when running option "5" for the following lis.config entry when running LIS: - -`Noah-MP.4.0.1 runoff and groundwater option: 5` - -// TODO: remove following admonition when MMF groundwater option 5 is implemented in LIS -IMPORTANT: The MMF groundwater option (option 5) is not yet supported in LIS. Work on this feature is currently in progress. -==== - -`MMF transmissivity dir:` specifies the location of the directory containing FDEPTH (transmissivity e-folding depth [m]) data on GEOGRID tiles. - -`MMF climatological recharge dir:` specifies the location of the directory containing RECHARGE (climatological recharge [mm]) data on GEOGRID tiles. - -`MMF riverbed elevation dir:` specifies the location of the directory containing RIVERBED (riverbed elevation [m]) data on GEOGRID tiles. - -`MMF equilibrium water table depth dir:` specifies the location of the directory containing EQWTD (equilibrium water table depth [m]) data on GEOGRID tiles. - -`MMF HGT_M dir:` specifies the location of the directory containing GMTED2010 (30-arc-second topography height [m from MSL]) data on GEOGRID tiles. - -.Example _ldt.config_ entry -.... -MMF transmissivity dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/f/ -MMF climatological recharge dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/recharge/ -MMF riverbed elevation dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/riverbed/ -MMF equilibrium water table depth dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/wtd/ -MMF HGT_M dir: ./LS_PARAMETERS/noahmp401_parms/groundwater/topo_gmted2010_30s/ -.... - -[NOTE] -==== -Spatial interpolation and gap filling parameters for each MMF variable are also required. See the config entries below. - -link:https://www2.mmm.ucar.edu/wrf/users/docs/user_guide_v4/v4.3/users_guide_chap3.html#_Description_of_GEOGRID.TBL[The WRF User's Guide, window=_blank] (and link:https://github.com/wrf-model/WPS/blob/master/geogrid/GEOGRID.TBL.ARW.noahmp[WPS/WPS-4.0.1/geogrid/GEOGRID.TBL.ARW.noahmp, window=_blank]) describe WPS's MMF parameter preprocessing procedures from the GEOGRID grid to the model grid. WPS performing the entire interpolation process from aggregating to gap filling on the native GEOGRID space makes it fundamentally different to LDT because LDT first aggregates input data from the native grid to the model grid and then fills gaps on the model grid space. The current LDT implementation of MMF parameter preprocessing does not attempt to replicate the WPS interpolation procedures, instead, it uses existing LDT interpolation utilities to follow the WPS's interpolation concept. -==== - -`MMF map projection:` map projection parameter is always set to latlon for MMF parameters. - -`MMF spatial transform:` spatial transform parameter is always set to average for MMF parameters. - -.Example _ldt.config_ entry -.... -MMF map projection: latlon -MMF spatial transform: average -.... - -`FDEPTH fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). - -`FDEPTH fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). - -`FDEPTH fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - -`FDEPTH water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable FDEPTH value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. - -.Example _ldt.config_ entry -.... -FDEPTH fill option: neighbor -FDEPTH fill radius: 0. -FDEPTH fill value: 100. -FDEPTH water value: 100. -.... - - -`RECHCLIM fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). - -`RECHCLIM fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value (0 is preferred). - -`RECHCLIM fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - -`RECHCLIM water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable RECHCLIM value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. - -.Example _ldt.config_ entry -.... -RECHCLIM fill option: neighbor -RECHCLIM fill radius: 0. -RECHCLIM fill value: -1. -RECHCLIM water value: -1. -.... - - -`EQWTD fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). - -`EQWTD fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. - -`EQWTD fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - -`EQWTD water value:` MMF scheme is active in lake/water grid cells. Thus, a suitable EQWTD value in lakes/rivers is needed in case GEOGRID didn't have valid data at the location. - -.Example _ldt.config_ entry -.... -EQWTD fill option: neighbor -EQWTD fill radius: 0. -EQWTD fill value: 0. -EQWTD water value: 0. -.... - - -`HGT_M fill option:` specifies the MMF parameter fill option (`neighbor` is preferred). - -`HGT_M fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. - -`HGT_M fill value:` indicates the parameter value to be used if an arbitrary value fill is needed. - - -.Example _ldt.config_ entry -.... -HGT_M fill option: neighbor -HGT_M fill radius: 0. -HGT_M fill value: 0. -.... - If selecting the Community Land Model (4.5 version), the following config entires are also required. `CLM45 parameter mode:` specifies whether to "`readin`" the CLM-4.5 parameters from pre-processed files. Currently, only the "`readin`" option is available. @@ -2593,27 +2428,6 @@ CLM45 resolution (dx): 1.25 CLM45 resolution (dy): 0.9424060 .... -If selecting Glen Liston's SnowModel, the following config entires are required. - -`Snowmodel topo-veg data source:` specifies which pre-processed SnowModel parameters and file format type to be read in. Currently, only the "`Grads_binary`" option is available. - -`Snowmodel topo-veg map:` specifies the directory-file location of the pre-processed SnowModel topographic and vegetation class parameters. - -`Snowmodel topo-veg spatial transform:` specifies the type of grid transform for preprocessed SnowModel topographic and vegetation class parameters. Currently, this option is not yet supported and user option is only "`none`" at this time. - -`Snowmodel topo-veg map projection:` specifies the SnowModel parameter file projection. Currently, SnowModel parameter projection needs to be set to the same as the LIS domain projection, for now. SnowModel parameters are best provided either on a Lambert projection (in LIS) and supports some equal-area projection grids, like UTM, which is available in LIS. Future support for more options will be added. - -`Snowmodel topo-veg fill option:` specifies the type of fill option used with SnowModel parameters. Currently, this feature is not supported, and will be in future versions. - -.Example _ldt.config_ entry -.... -Snowmodel topo-veg data source: "Grads_binary" -Snowmodel topo-veg map: ../SnowModel_Inputs/uppertuo_100m/topo_vege.gdat -Snowmodel topo-veg spatial transform: "none" -Snowmodel topo-veg map projection: lambert -Snowmodel topo-veg fill option: none -.... - Potential Evapotranspiration (PET) maps `PET directory:` specifies the source of the monthly climatology based PET files. The climatology data files have the following naming convention: /..1gd4r. The tag should be represent the month (such as JAN, FEB, MAR, etc.). The file header can be anything (such as avhrr_pet_1KM). Currently, this parameter is used only with the RDHM-SAC model. @@ -2662,7 +2476,7 @@ PET fill radius: 3 PET fill value: 10. .... -If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying PET data. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying PET data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -2734,7 +2548,7 @@ CLSMF25 top soil layer depth: 0.02 CLSMF25 spatial transform: none .... -This section also outlines the domain specifications of the Catchment LSM Fortuna 2.5 data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying CLSM data. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of the Catchment LSM Fortuna 2.5 data. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying CLSM data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -3027,7 +2841,6 @@ Climatology parameter maps |PRISM |PRISM US-only climate downscaled fields. For more info, see: http://www.prism.oregonstate.edu/ |WORLDCLIM |Global climate layers downscaled. For more info, see: http://www.worldclim.org/ -|NAFPA_BACK_GALWEM|US Air Force GALWEM NWP fields on 10-km NAFPA grid (Oct2017-May2022). |=== `PPT climatology maps:` specifies the source of the climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: @@ -3042,11 +2855,6 @@ WORLDCLIM: /..1gd4r * The file header can be prec_ * The tag should represent the month (such as 1, 2,..., 12). -NAFPA_BACK_GALWEM: /..d01.nc - -* The field header is SUM_TS -* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). - `PPT climatology interval:` specifies the frequency of the precipitation climatology in months. Current option is: "`monthly`" .Example _ldt.config_ entry @@ -3056,34 +2864,6 @@ PPT climatology maps: ../LS_PARAMETERS/climate_maps/ppt_1981_2010 PPT climatology interval: monthly .... -`PPT climatology data source 2:` specifies the second monthly precipitation (PPT) climatology fields, for calculating bias ratios. Current source options include: - -[cols="<,<",] -|=== -|Value |Description - -|NLDAS |NOAA NLDAS-2 fields -|NAFPA_BACK_GFS|NOAA GFS NWP fields on 10-km NAFPA grid (Oct2017-May2022). -|=== - -`PPT climatology maps 2:` specifies the source of the second group climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: - -NLDAS: /..txt - -* The file header can be anything (such as ppt_1931_2010). -* The tag should represent the month (such as jan, feb, mar, etc.). - -NAFPA_BACK_GFS: /..d01.nc - -* The field header is SUM_TS -* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). - -.Example _ldt.config_ entry -.... -PPT climatology data source 2: NAFPA_BACK_GFS -PPT climatology maps 2: ./METRICS_GFS/ -.... - `TMIN climatology maps:` specifies the source of the climatology based minimum temperature files. `TMAX climatology maps:` specifies the source of the climatology based maximum temperature files. @@ -3112,7 +2892,7 @@ TMAX climatology maps: Climate params spatial transform: average .... -This section also outlines the domain specifications of climatology-based parameters, like higher scaled monthly precipitation or min/max temperatures. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying climatology data. See Appendix <> for more details about setting these values. +This section also outlines the domain specifications of climatology-based parameters, like higher scaled monthly precipitation or min/max temperatures. If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying climatology data. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -3602,11 +3382,6 @@ LIS output timestep: 1da |"`NASA SMAP vegetation optical depth`" |NASA SMAP vegetation optical depth observations (units in "`-`") |"`SMOS NRT NN soil moisture`" | SMOS Level 2 Soil Moisture Near Real Time Neural Network |"`THySM soil moisture`" | Thermal Hydraulic disaggregation of Soil Moisture -|"`SMAP_E_OPL soil moisture`" | Operational 9-km enhanced SMAP soil moisture retrieval -|"`GEOS effective soil temperature`" | GEOS-FP effective soil temperature -|"`CDFS GVF`" | CDFS green vegetation fraction (GVF) -|"`VIIRS GVF`" | VIIRS green vegetation fraction (GVF) -|"`LIS LSM effective soil temperature`" | Soil temperature output from a LIS run |=== .Example _ldt.config_ entry @@ -3652,7 +3427,6 @@ Number of bins to use in the CDF: 100 |monthly |stratify for each calendar month |yearly |lump (considering all years and all seasons) -|half-monthly | stratify for each calendar half-month (for SMAP_E_OPL) |=== .Example _ldt.config_ entry @@ -3660,8 +3434,6 @@ Number of bins to use in the CDF: 100 Temporal resolution of CDFs: monthly .... -`Daily interpolation of mean and stddev:` specifies whether daily interpolation of mean and standrd deviation is conducted when 'Temporal resolution of CDFS:' is set to 'half-monthly'. This should be '1' to generate statistics of effective soil temperature (Teff), which are used to scale the LIS Teff during generating the SMAP_E_OPL soil moisture retrievals - `Enable spatial sampling for CDF calculations:` Normally CDFs are calculated (for a given grid cell) by using the data values available at that grid point only. If this option is enabled, then values around a specified radius will be used in the CDF calculations, effectively improving the sampling density at the risk of reduced geographic specificity. .Example _ldt.config_ entry @@ -3811,68 +3583,6 @@ LIS soil moisture area of data: LIS soil moisture write interval: .... -`LIS soil temperature output model name:` specifies the model name used to simulate soil temperature - -`LIS soil temperature output directory:` specifies the location of the LIS model output. - -`LIS soil temperature output format:` specifies the output format of the LIS model output. (binary/netcdf/grib1) - -`LIS soil temperature output methodology:` specifies the output methodology used in the LIS model output (1d tilespace/1d gridspace/2d gridspace). - -`LIS soil temperature output naming style:` specifies the output naming style used in the LIS model output (3 level hierarchy/4 level hierarchy, etc.). - -`LIS soil temperature output nest index:` specifies the index of the nest used in the LIS model output. - -`LIS soil temperature output map projection:` specifies the map projection used in the LIS model output. - -`LIS soil temperature domain lower left lat:` specifies the lower left latitude of the LIS model outpu. - -`LIS soil temperature domain upper right lat:` specifies the upper right latitude of the LIS model output. - -`LIS soil temperature domain lower left lon:` specifies the lower left longitude of the LIS model output. - -`LIS soil temperature domain upper right lon` specifies the upper right longitude of the LIS model output. - -`LIS soil temperature domain resolution (dx):` specifies the resolution (in degrees) along the latitude of the LIS model output. - -`LIS soil temperature domain resolution (dy):` specifies the resolution (in degrees) along the longitude of the LIS model output. - -For Lambert and polar projections: - -`LIS soil temperature domain lower left lat:` specifies the lower left latitude of the LIS model output - -`LIS soil temperature domain lower left lon:` specifies the lower left longitude of the LIS model output - -`LIS soil temperature domain true lat1:` specifies the true lat1 of the LIS model output - -`LIS soil temperature domain true lat2:` specifies the true lat2 of the LIS model output - -`LIS soil temperature domain standard lon:` specifies the standard longitude of the LIS model output - -`LIS soil temperature domain resolution:` specifies the resolution of the LIS model output - -`LIS soil temperature domain x-dimension size:` specifies the x-dimension size of the LIS model output - -`LIS soil temperature domain y-dimension size:` specifies the y-dimension size of the LIS model output - -.Example _ldt.config_ entry -.... -LIS soil temperature output model name: "Noah.3.9" -LIS soil temperature output directory: ../OL/OUTPUT -LIS soil temperature output format: "netcdf" -LIS soil temperature output methodology: "2d gridspace" -LIS soil temperature output naming style: "3 level hierarchy" -LIS soil temperature output nest index: 1 -LIS soil temperature output map projection: "latlon" - -LIS soil temperature domain lower left lat: -89.9531250 -LIS soil temperature domain upper right lat: 89.9531250 -LIS soil temperature domain lower left lon: -179.9296875 -LIS soil temperature domain upper right lon: 179.9296875 -LIS soil temperature domain resolution (dx): 0.1406250 -LIS soil temperature domain resolution (dy): 0.0937500 -.... - `Synthetic soil moisture observation directory:` specifies the location of the data directory containing the synthetic soil moisture data. `Synthetic soil moisture observation timestep:` specifies the timestep of the synthetic soil moisture observations. @@ -3904,22 +3614,10 @@ NASA AMSRE soil moisture observation directory: ./NASA_AMSRE `ESA CCI soil moisture version of data:` specifies the version of the ESA CCI soil moisture dataset. -`ESA CCI soil moisture sensor type:` specifies the sensor type of the ESA CCI soil moisture dataset. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|"`passive`" | passive sensor type -|"`active`" | active sensor type -|"`combined`" | combined sensor type -|=== - .Example _ldt.config_ entry .... ESA CCI soil moisture observation directory: ./ECV ESA CCI soil moisture version of data: EXAMPLE -ESA CCI soil moisture sensor type: combined .... `GCOMW AMSR2 L3 soil moisture observation directory:` specifies the location of the data directory containing the GCOMW AMSR v2 L3 soil moisture data. @@ -4290,7 +3988,7 @@ LPRM vegetation optical depth data designation: 'X-band' .Example _ldt.config_ entry .... -SMOS NRT NN soil moisture observation directory: ./SMOS_NRT_NN +MOS NRT NN soil moisture observation directory: ./SMOS_NRT_NN .... `SMOS NRT NN search radius for openwater proximity detection:` specifies the radius in which LDT search to detect open water. Then removes all pixels within the radius in the CDF calculations. @@ -4307,41 +4005,6 @@ SMOS NRT NN search radius for openwater proximity detection: 3 THySM observation directory: ../THySM .... -`SMAP_E_OPL soil moisture observation directory:` specifies the location of the data directory containing the SMAP_E_OPL soil moisture data - -.Example _ldt.config_ entry -.... -SMAP_E_OPL soil moisture observation directory: ../SMAP_E_OPL_noah39 -.... - -`SMAP_E_OPL search radius for openwater proximity detection:` specifies the radius in which LDT search to detect open water. Then removes all pixels within the radius in the CDF calculations - -.Example _ldt.config_ entry -.... -SMAP_E_OPL search radius for openwater proximity detection: 3 -.... - -`GEOS soil temperature data directory:` specifies the location of the data directory containing the GEOS-FP soil temperature data - -.Example _ldt.config_ entry -.... -GEOS soil temperature data directory: ./GEOS -.... - -`CDFS GVF data directory:` specifies the location of the data directory containing the CDFS GVF data - -.Example _ldt.config_ entry -.... -CDFS GVF data directory: ./CDFS_GVF -.... - -`VIIRS GVF data directory:` specifies the location of the data directory containing the VIIRS GVF data - -.Example _ldt.config_ entry -.... -VIIRS GVF data directory: ./VIIRS_GVF -.... - [[ssec-hymapopts]] === HYMAP routing options @@ -4416,7 +4079,7 @@ HYMAP river flow type map: ../HYMAP_parms/lis_rivflw_0125.bin This section also outlines the domain specifications of the HYMAP parameter data. For the HYMAP parameters spatial transform option, only "`none`" is supported at this time, and the user is required to input the HYMAP parameters at the grid and resolution of interest. -If the map projection of parameter data is specified to be "`latlon`", the following configuration should be used for specifying HYMAP parameters. See Appendix <> for more details about setting these values. +If the map projection of parameter data is specified to be "`latlon`", the following configuration should be used for specifying HYMAP parameters. See Appendix <> for more details about setting these values. .Example _ldt.config_ entry .... @@ -4965,99 +4628,3 @@ Sentinel1A OSSE mask data resolution (km): 1 TSSM OSSE mask directory: ../Masks/TSSM/ TSSM OSSE mask data resolution (km): 1 .... - -[[ssec-smap_e_opl]] -=== Operational 9-km enhanced SMAP soil moisture retrieval - -`SMAP_E_OPL valid date (YYYYMMDDHH):` valid date and hour (UTC) of SMAP L1B data - -`SMAP_E_OPL soil moisture output directory:` specifies a directory where soil moisture retrieval outputs are saved - -`SMAP_E_OPL L1B data directory:` specifies a directory containing the SMAP L1B data - -`SMAP_E_OPL L1B data type:` specifies the L1B data type. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|1 |Near real time data -|2 |Historical data -|=== - -`SMAP_E_OPL write L1B resampled output:` specifies whether to write L1B resampled output or not. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|0 |Do not write L1B resampled output -|1 |Write L1B resampled output -|=== - -`SMAP_E_OPL L1B resampled output directory:` specifies a L1B resampled output directory when 'SMAP_E_OPL write L1B resampled output: 1' - -`SMAP_E_OPL LIS soil temperature directory:` specifies a directory containing LIS soil temperature outputs - -`SMAP_E_OPL apply soil temperature bias correction:` specifies whether soil temperature bias correction is applied or not. Acceptable values are: - -[cols="<,<",] -|=== -|Value |Description - -|0 |Do not apply soil temperature bias correction -|1 |Apply soil temperature bias correction -|=== - -`SMAP_E_OPL reference Teff daily statistics file:` specifies a directory and filename of the reference effective soil temperature (Teff) daily statistics file - -`SMAP_E_OPL LIS Teff daily statistics file:` specifies a directory and filename of the LIS Teff daily statistics file - -`SMAP_E_OPL LIS snow directory:` specifies a directory containing LIS snow outputs - -`SMAP_E_OPL snow depth threshold:` specifies a snow depth threshold (unit: m). Soil moisture retrievals are not generate for grid cells with snow depth greater than the threshold. - -`SMAP_E_OPL TAU directory:` specifies a directory containing the pre-processed TAU data - -`SMAP_E_OPL OMEGA file:` specifies a directory and filename of the pre-processed OMEGA data - -`SMAP_E_OPL soil bulk density file:` specifies a directory and filename of the pre-processed soil bulk density data - -`SMAP_E_OPL soil clay fraction file:` specifies a directory and filename of the pre-processed soil clay fraction data - -`SMAP_E_OPL roughness file:` specifies a directory and filename of the pre-processed roughness data - -`SMAP_E_OPL landcover file:` specifies a directory and filename of the pre-processed land cover data - -.Example _ldt.config_ entry -.... -SMAP_E_OPL valid date (YYYYMMDDHH): 2015060312 -SMAP_E_OPL soil moisture output directory: ./SM_retrieval -SMAP_E_OPL L1B data directory: ../SMAP_L1B_TB -SMAP_E_OPL L1B data type: 1 -SMAP_E_OPL write L1B resampled output: 0 -SMAP_E_OPL L1B resampled output directory: ./ARFS_RESAMPLE -SMAP_E_OPL LIS soil temperature directory: ../Noah39_OL -SMAP_E_OPL apply soil temperature bias correction: 1 -SMAP_E_OPL reference Teff daily statistics file: ../geos_daily_statistics_15obs.nc -SMAP_E_OPL LIS Teff daily statistics file: ../noah39_daily_statistics_15obs.nc -SMAP_E_OPL LIS snow directory: ../Noah39_snow -SMAP_E_OPL snow depth threshold: 0.05 -SMAP_E_OPL TAU directory: ../../data/TAU_ARFS_DAILY -SMAP_E_OPL OMEGA file: ../../data/PRMS_RETRIEVAL_ARFS/omega_arfs.dat -SMAP_E_OPL soil bulk density file: ../../data/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat -SMAP_E_OPL soil clay fraction file: ../../data/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat -SMAP_E_OPL roughness file: ../../data/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat -SMAP_E_OPL landcover file: ../../data/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin -.... - - - - - - - - - - - From 1c3953ec1e5236a66579a14dc131ef8edfca1335 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 13 Feb 2023 14:42:29 -0500 Subject: [PATCH 088/328] Revert "Update landcover options in doc to include MCD12Q1" This reverts commit 16dcc6b2a1d9e6a5e23991808e76b0a861197634. --- ldt/configs/ldt.config.adoc | 92 ++++++++++++++++++++++++++++++++----- 1 file changed, 81 insertions(+), 11 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 6b3535e5e..8c0695d5e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -418,19 +418,33 @@ The default value is 0. Add buffer to parameter grid domain: 0 .... -`Buffer count in x-direction:` adds a set number of pixels that buffer -around a parameter file target domain, both in the x- and y-directions. +`Buffer count in x-direction:` adds a set number of pixels that buffer +around a parameter file target domain in the x-direction. Acceptable values are: [cols="<,<",] |=== |Value |Description -|"`0`" |No buffer added -|"`1`" (or greater) |Buffer points included +|0 |Results in no buffer added +|1 (or greater) |Buffer points included +|=== + +The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. + +`Buffer count in y-direction:` adds a set number of pixels that buffer +around a parameter file target domain in the y-direction. +Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|0 |Results in no buffer added +|1 (or greater) |Buffer points included |=== -The default value is 5, and only activated if buffer option is selected. +The default value is 5, and it is activated only if `Add buffer to parameter grid domain:` is enabled. .Example _ldt.config_ entry .... @@ -751,7 +765,6 @@ endif::devonly[] |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. |MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. -|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. |USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html @@ -793,11 +806,6 @@ Landcover classification: "UMD" `Landcover file:` specifies the location of the vegetation classification file. -.Example _ldt.config_ entry -.... -Landcover file: ./MODIS/MCD12Q1.006/2001/MCD12Q1.006_2001001.nc4 -.... - `Landcover map projection:` specifies the projection of the landcover map data. `Landcover spatial transform:` indicates which spatial transform (i.e., upscale or downscale) type is to be applied to the landcover map. Options include: @@ -1613,6 +1621,20 @@ Soil texture spatial transform: none `Soil texture fill value:` indicates which soil texture value to be used if an arbitrary value fill is needed. (For example, when the landmask indicates a land point but no existing soil texture value, a value of 6 could be assigned if no nearest neighbor values exists to fill). +`Soil texture fill value for Antarctica:` indicates which soil texture value to be used if an arbitrary value fill is needed south of 60S. If not specified, value of `Soil texture fill value:` will be used. + +`Soil texture force exclusion of water points during fill:` indicates whether to force exclusion of water points when filling soil texture. Required when using STATSGOFAO south of 60S (texture is set to all water) and multiple surface model types are used. + +[cols="<,<",] +|=== +|Value |Description + +|.false. |do not enable +|.true. |enable +|=== + +Defaults to `.false.`. + `Soil texture fill radius:` specifies the radius with which to search for nearby value(s) to help fill in the missing value. .Example _ldt.config_ entry @@ -1620,6 +1642,8 @@ Soil texture spatial transform: none Soil texture fill option: neighbor Soil texture fill radius: 3. Soil texture fill value: 6. +Soil texture fill value for Antarctica: 16 +Soil texture force exclusion of water points during fill: .true. .... If the map projection of parameter data is specified to be lat/lon, the following configuration should be used for specifying soil texture data, if the data source option has a "`_LIS`" in the name. See Appendix <> for more details about setting these values. @@ -2841,6 +2865,7 @@ Climatology parameter maps |PRISM |PRISM US-only climate downscaled fields. For more info, see: http://www.prism.oregonstate.edu/ |WORLDCLIM |Global climate layers downscaled. For more info, see: http://www.worldclim.org/ +|NAFPA_BACK_GALWEM|US Air Force GALWEM NWP fields on 10-km NAFPA grid (Oct2017-May2022). |=== `PPT climatology maps:` specifies the source of the climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: @@ -2855,6 +2880,11 @@ WORLDCLIM: /..1gd4r * The file header can be prec_ * The tag should represent the month (such as 1, 2,..., 12). +NAFPA_BACK_GALWEM: /..d01.nc + +* The field header is SUM_TS +* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). + `PPT climatology interval:` specifies the frequency of the precipitation climatology in months. Current option is: "`monthly`" .Example _ldt.config_ entry @@ -2864,6 +2894,34 @@ PPT climatology maps: ../LS_PARAMETERS/climate_maps/ppt_1981_2010 PPT climatology interval: monthly .... +`PPT climatology data source 2:` specifies the second monthly precipitation (PPT) climatology fields, for calculating bias ratios. Current source options include: + +[cols="<,<",] +|=== +|Value |Description + +|NLDAS |NOAA NLDAS-2 fields +|NAFPA_BACK_GFS|NOAA GFS NWP fields on 10-km NAFPA grid (Oct2017-May2022). +|=== + +`PPT climatology maps 2:` specifies the source of the second group climatology based precipitation files. The climatology precipitation data files can have the following naming conventions, depending on the data source: + +NLDAS: /..txt + +* The file header can be anything (such as ppt_1931_2010). +* The tag should represent the month (such as jan, feb, mar, etc.). + +NAFPA_BACK_GFS: /..d01.nc + +* The field header is SUM_TS +* The tag should be year, month, day, and hour in UTC (YYYYMMDDHH). + +.Example _ldt.config_ entry +.... +PPT climatology data source 2: NAFPA_BACK_GFS +PPT climatology maps 2: ./METRICS_GFS/ +.... + `TMIN climatology maps:` specifies the source of the climatology based minimum temperature files. `TMAX climatology maps:` specifies the source of the climatology based maximum temperature files. @@ -3614,10 +3672,22 @@ NASA AMSRE soil moisture observation directory: ./NASA_AMSRE `ESA CCI soil moisture version of data:` specifies the version of the ESA CCI soil moisture dataset. +`ESA CCI soil moisture sensor type:` specifies the sensor type of the ESA CCI soil moisture dataset. Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|"`passive`" | passive sensor type +|"`active`" | active sensor type +|"`combined`" | combined sensor type +|=== + .Example _ldt.config_ entry .... ESA CCI soil moisture observation directory: ./ECV ESA CCI soil moisture version of data: EXAMPLE +ESA CCI soil moisture sensor type: combined .... `GCOMW AMSR2 L3 soil moisture observation directory:` specifies the location of the data directory containing the GCOMW AMSR v2 L3 soil moisture data. From 46f8ab344aef2b04653a49861d463c359cfbd30b Mon Sep 17 00:00:00 2001 From: Shahryar Khalique Ahmad Date: Mon, 13 Feb 2023 15:08:43 -0500 Subject: [PATCH 089/328] Update landcover options in doc to include MCD12Q1 --- ldt/configs/ldt.config.adoc | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 8c0695d5e..28d3e168b 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -765,6 +765,7 @@ endif::devonly[] |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. |MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. +|MCD12Q1 |Terra and Aqua combined MODIS landcover map, available at yearly intervals. Allows dynamic annual landcover maps in "`Landcover file`" option. |USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html @@ -806,6 +807,11 @@ Landcover classification: "UMD" `Landcover file:` specifies the location of the vegetation classification file. +.Example _ldt.config_ entry +.... +Landcover file: ./MODIS/MCD12Q1.006/2001/MCD12Q1.006_2001001.nc4 +.... + `Landcover map projection:` specifies the projection of the landcover map data. `Landcover spatial transform:` indicates which spatial transform (i.e., upscale or downscale) type is to be applied to the landcover map. Options include: From 175d538893d5a3667586d61659b219bac04fe344 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Feb 2023 16:59:04 -0500 Subject: [PATCH 090/328] Improved fault tolerance of USAFSI fetching. Now, if an error is returned by netCDF, the code will move on to the next time (unless 24 hours of data have been searched for). Also, if no USAFSI data is found, a warning message is printed to the LDT log. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 7 +- ldt/SMAP_E_OPL/readUSAFSI.F90 | 129 ++++++++++++++++----------- 2 files changed, 83 insertions(+), 53 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 222841e34..9449ecf0b 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -444,8 +444,11 @@ subroutine LDT_smap_e_oplRun(n) ! Get snow information from LIS outputs !call readLIS_snow(n,yyyymmdd,hh,SnowDepth) - call readUSAFSI(n, yyyymmdd, hh, SnowDepth) - + call readUSAFSI(n, yyyymmdd, hh, SnowDepth, rc) + if (rc .ne. 0) then + write(LDT_logunit,*)'[WARN] No USAFSI data available!' + endif + ! Retrieve SMAP soil moisture ! get DOY call get_doy(mo,da,doy_curr) diff --git a/ldt/SMAP_E_OPL/readUSAFSI.F90 b/ldt/SMAP_E_OPL/readUSAFSI.F90 index ec7f693c5..a905b6f2c 100644 --- a/ldt/SMAP_E_OPL/readUSAFSI.F90 +++ b/ldt/SMAP_E_OPL/readUSAFSI.F90 @@ -19,7 +19,7 @@ ! 13 Feb 2023: Eric Kemp, Initial Specification ! ! !INTERFACE: -subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) +subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth, rc) ! !USES: use LDT_coreMod @@ -29,10 +29,11 @@ subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) implicit none ! !ARGUMENTS: - integer, intent(in) :: n - character*8 :: yyyymmdd - character*2 :: hh - real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + integer, intent(in) :: n + character*8, intent(in) :: yyyymmdd + character*2, intent(in) :: hh + real, intent(out):: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + integer, intent(out) :: rc !EOP character*255 :: fname @@ -43,10 +44,12 @@ subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) integer :: yr, mo, da, hr integer :: nn integer :: ierr + integer :: rc1 external :: create_USAFSI_filename external :: read_USAFSI_data + rc = 1 ! Default to error, will update below if USAFSI file read in. SnowDepth = LDT_rc%udef yyyymmdd_snow = yyyymmdd @@ -55,7 +58,7 @@ subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) dd_snow = yyyymmdd(7:8) hh_snow = hh - read(yyyy_snow, *, iostat=ierr) yr + read(yyyy_snow, *, iostat=ierr) yr read(mm_snow, *, iostat=ierr) mo read(dd_snow, *, iostat=ierr) da read(hh_snow, *, iostat=ierr) hr @@ -69,51 +72,56 @@ subroutine readUSAFSI(n, yyyymmdd, hh, SnowDepth) if (file_exists) then write(LDT_logunit,*) '[INFO] Reading snow depth from ', trim(fname) - call read_USAFSI_data(n, fname, SnowDepth) - write(LDT_logunit,*) '[INFO] Finished reading snow outputs from ', & - trim(fname) - exit - else - hr = hr - 1 - if (hr < 0) then - da = da - 1 - hr = 23 - if (da == 0) then - mo = mo - 1 - if (mo == 0) then - yr = yr - 1 - mo = 12 + call read_USAFSI_data(n, fname, SnowDepth, rc1) + if (rc1 == 0) then + write(LDT_logunit,*) '[INFO] Finished reading snow outputs from ', & + trim(fname) + rc = 0 + exit + end if + end if + + ! Go back one hour + hr = hr - 1 + if (hr < 0) then + da = da - 1 + hr = 23 + if (da == 0) then + mo = mo - 1 + if (mo == 0) then + yr = yr - 1 + mo = 12 + da = 31 + else + if (mo == 1 .or. & + mo == 3 .or. & + mo == 5 .or. & + mo == 7 .or. & + mo == 8 .or. & + mo == 10 .or. & + mo == 12) then da = 31 - else - if (mo == 1 .or. & - mo == 3 .or. & - mo == 5 .or. & - mo == 7 .or. & - mo == 8 .or. & - mo == 10 .or. & - mo == 12) then - da = 31 - elseif (mo == 2) then - if (mod(yr,4) == 0) then - da = 29 - else - da = 28 - endif + elseif (mo == 2) then + if (mod(yr,4) == 0) then + da = 29 else - da = 30 + da = 28 endif + else + da = 30 endif endif endif + endif - write(unit=yyyy_snow, fmt='(i4.4)') yr - write(unit=mm_snow, fmt='(i2.2)') mo - write(unit=dd_snow, fmt='(i2.2)') da - write(unit=hh_snow, fmt='(i2.2)') hr - yyyymmdd_snow = trim(yyyy_snow) // trim(mm_snow) // trim(dd_snow) + write(unit=yyyy_snow, fmt='(i4.4)') yr + write(unit=mm_snow, fmt='(i2.2)') mo + write(unit=dd_snow, fmt='(i2.2)') da + write(unit=hh_snow, fmt='(i2.2)') hr + yyyymmdd_snow = trim(yyyy_snow) // trim(mm_snow) // trim(dd_snow) + + nn = nn + 1 - nn = nn + 1 - endif end do end subroutine readUSAFSI @@ -123,7 +131,7 @@ end subroutine readUSAFSI ! \label{read_USAFSI_data} ! ! !INTERFACE: -subroutine read_USAFSI_data(n, fname, SnowDepth) +subroutine read_USAFSI_data(n, fname, SnowDepth, rc) ! ! !USES: use LDT_logMod @@ -137,28 +145,47 @@ subroutine read_USAFSI_data(n, fname, SnowDepth) ! ! !INPUT PARAMETERS: ! - integer, intent(in) :: n - character (len=*) :: fname + integer, intent(in) :: n + character(*), intent(in) :: fname + real, intent(inout) :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + integer, intent(out) :: rc !EOP integer :: ios, nid integer :: snowdepthid - real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) + + rc = 1 ! Initialize as error, reset near bottom #if (defined USE_NETCDF3 || defined USE_NETCDF4) ios = nf90_open(path=trim(fname), mode=NF90_NOWRITE, ncid=nid) - call LDT_verify(ios, 'Error opening file ' // trim(fname)) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Error opening file' // trim(fname) + return + end if ios = nf90_inq_varid(nid, 'snoanl', snowdepthid) - call LDT_verify(ios, 'Error nf90_inq_varid: snoanl') + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot find snoanl in ' // trim(fname) + ios = nf90_close(ncid=nid) + return + end if ios = nf90_get_var(nid, snowdepthid, SnowDepth, & start=(/1, 1/), & count=(/LDT_rc%lnc(n), LDT_rc%lnr(n)/)) - call LDT_verify(ios, 'Error nf90_get_var: snoanl') + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot read snoanl in ' // trim(fname) + ios = nf90_close(ncid=nid) + return + end if ios = nf90_close(ncid=nid) - call LDT_verify(ios, 'Error closing file ' // trim(fname)) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Error closing ' // trim(fname) + return + end if + + rc = 0 ! No error detected! #endif From 789f507315e2e55cbbdbc216f80f6f168002eff5 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 14 Feb 2023 10:28:39 -0500 Subject: [PATCH 091/328] Add CECILL_C license for Crocus8.1 --- lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt | 516 ++++++++++++++++++++ 1 file changed, 516 insertions(+) create mode 100644 lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt diff --git a/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt b/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt new file mode 100644 index 000000000..43ff90f1d --- /dev/null +++ b/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt @@ -0,0 +1,516 @@ +CeCILL-C FREE SOFTWARE LICENSE AGREEMENT + + + Notice + +This Agreement is a Free Software license agreement that is the result +of discussions between its authors in order to ensure compliance with +the two main principles guiding its drafting: + + * firstly, compliance with the principles governing the distribution + of Free Software: access to source code, broad rights granted to + users, + * secondly, the election of a governing law, French law, with which + it is conformant, both as regards the law of torts and + intellectual property law, and the protection that it offers to + both authors and holders of the economic rights over software. + +The authors of the CeCILL-C (for Ce[a] C[nrs] I[nria] L[ogiciel] L[ibre]) +license are: + +Commissariat à l'Energie Atomique - CEA, a public scientific, technical +and industrial research establishment, having its principal place of +business at 25 rue Leblanc, immeuble Le Ponant D, 75015 Paris, France. + +Centre National de la Recherche Scientifique - CNRS, a public scientific +and technological establishment, having its principal place of business +at 3 rue Michel-Ange, 75794 Paris cedex 16, France. + +Institut National de Recherche en Informatique et en Automatique - +INRIA, a public scientific and technological establishment, having its +principal place of business at Domaine de Voluceau, Rocquencourt, BP +105, 78153 Le Chesnay cedex, France. + + + Preamble + +The purpose of this Free Software license agreement is to grant users +the right to modify and re-use the software governed by this license. + +The exercising of this right is conditional upon the obligation to make +available to the community the modifications made to the source code of +the software so as to contribute to its evolution. + +In consideration of access to the source code and the rights to copy, +modify and redistribute granted by the license, users are provided only +with a limited warranty and the software's author, the holder of the +economic rights, and the successive licensors only have limited liability. + +In this respect, the risks associated with loading, using, modifying +and/or developing or reproducing the software by the user are brought to +the user's attention, given its Free Software status, which may make it +complicated to use, with the result that its use is reserved for +developers and experienced professionals having in-depth computer +knowledge. Users are therefore encouraged to load and test the +suitability of the software as regards their requirements in conditions +enabling the security of their systems and/or data to be ensured and, +more generally, to use and operate it in the same conditions of +security. This Agreement may be freely reproduced and published, +provided it is not altered, and that no provisions are either added or +removed herefrom. + +This Agreement may apply to any or all software for which the holder of +the economic rights decides to submit the use thereof to its provisions. + + + Article 1 - DEFINITIONS + +For the purpose of this Agreement, when the following expressions +commence with a capital letter, they shall have the following meaning: + +Agreement: means this license agreement, and its possible subsequent +versions and annexes. + +Software: means the software in its Object Code and/or Source Code form +and, where applicable, its documentation, "as is" when the Licensee +accepts the Agreement. + +Initial Software: means the Software in its Source Code and possibly its +Object Code form and, where applicable, its documentation, "as is" when +it is first distributed under the terms and conditions of the Agreement. + +Modified Software: means the Software modified by at least one +Integrated Contribution. + +Source Code: means all the Software's instructions and program lines to +which access is required so as to modify the Software. + +Object Code: means the binary files originating from the compilation of +the Source Code. + +Holder: means the holder(s) of the economic rights over the Initial +Software. + +Licensee: means the Software user(s) having accepted the Agreement. + +Contributor: means a Licensee having made at least one Integrated +Contribution. + +Licensor: means the Holder, or any other individual or legal entity, who +distributes the Software under the Agreement. + +Integrated Contribution: means any or all modifications, corrections, +translations, adaptations and/or new functions integrated into the +Source Code by any or all Contributors. + +Related Module: means a set of sources files including their +documentation that, without modification to the Source Code, enables +supplementary functions or services in addition to those offered by the +Software. + +Derivative Software: means any combination of the Software, modified or +not, and of a Related Module. + +Parties: mean both the Licensee and the Licensor. + +These expressions may be used both in singular and plural form. + + + Article 2 - PURPOSE + +The purpose of the Agreement is the grant by the Licensor to the +Licensee of a non-exclusive, transferable and worldwide license for the +Software as set forth in Article 5 hereinafter for the whole term of the +protection granted by the rights over said Software. + + + Article 3 - ACCEPTANCE + +3.1 The Licensee shall be deemed as having accepted the terms and +conditions of this Agreement upon the occurrence of the first of the +following events: + + * (i) loading the Software by any or all means, notably, by + downloading from a remote server, or by loading from a physical + medium; + * (ii) the first time the Licensee exercises any of the rights + granted hereunder. + +3.2 One copy of the Agreement, containing a notice relating to the +characteristics of the Software, to the limited warranty, and to the +fact that its use is restricted to experienced users has been provided +to the Licensee prior to its acceptance as set forth in Article 3.1 +hereinabove, and the Licensee hereby acknowledges that it has read and +understood it. + + + Article 4 - EFFECTIVE DATE AND TERM + + + 4.1 EFFECTIVE DATE + +The Agreement shall become effective on the date when it is accepted by +the Licensee as set forth in Article 3.1. + + + 4.2 TERM + +The Agreement shall remain in force for the entire legal term of +protection of the economic rights over the Software. + + + Article 5 - SCOPE OF RIGHTS GRANTED + +The Licensor hereby grants to the Licensee, who accepts, the following +rights over the Software for any or all use, and for the term of the +Agreement, on the basis of the terms and conditions set forth hereinafter. + +Besides, if the Licensor owns or comes to own one or more patents +protecting all or part of the functions of the Software or of its +components, the Licensor undertakes not to enforce the rights granted by +these patents against successive Licensees using, exploiting or +modifying the Software. If these patents are transferred, the Licensor +undertakes to have the transferees subscribe to the obligations set +forth in this paragraph. + + + 5.1 RIGHT OF USE + +The Licensee is authorized to use the Software, without any limitation +as to its fields of application, with it being hereinafter specified +that this comprises: + + 1. permanent or temporary reproduction of all or part of the Software + by any or all means and in any or all form. + + 2. loading, displaying, running, or storing the Software on any or + all medium. + + 3. entitlement to observe, study or test its operation so as to + determine the ideas and principles behind any or all constituent + elements of said Software. This shall apply when the Licensee + carries out any or all loading, displaying, running, transmission + or storage operation as regards the Software, that it is entitled + to carry out hereunder. + + + 5.2 RIGHT OF MODIFICATION + +The right of modification includes the right to translate, adapt, +arrange, or make any or all modifications to the Software, and the right +to reproduce the resulting software. It includes, in particular, the +right to create a Derivative Software. + +The Licensee is authorized to make any or all modification to the +Software provided that it includes an explicit notice that it is the +author of said modification and indicates the date of the creation thereof. + + + 5.3 RIGHT OF DISTRIBUTION + +In particular, the right of distribution includes the right to publish, +transmit and communicate the Software to the general public on any or +all medium, and by any or all means, and the right to market, either in +consideration of a fee, or free of charge, one or more copies of the +Software by any means. + +The Licensee is further authorized to distribute copies of the modified +or unmodified Software to third parties according to the terms and +conditions set forth hereinafter. + + + 5.3.1 DISTRIBUTION OF SOFTWARE WITHOUT MODIFICATION + +The Licensee is authorized to distribute true copies of the Software in +Source Code or Object Code form, provided that said distribution +complies with all the provisions of the Agreement and is accompanied by: + + 1. a copy of the Agreement, + + 2. a notice relating to the limitation of both the Licensor's + warranty and liability as set forth in Articles 8 and 9, + +and that, in the event that only the Object Code of the Software is +redistributed, the Licensee allows effective access to the full Source +Code of the Software at a minimum during the entire period of its +distribution of the Software, it being understood that the additional +cost of acquiring the Source Code shall not exceed the cost of +transferring the data. + + + 5.3.2 DISTRIBUTION OF MODIFIED SOFTWARE + +When the Licensee makes an Integrated Contribution to the Software, the +terms and conditions for the distribution of the resulting Modified +Software become subject to all the provisions of this Agreement. + +The Licensee is authorized to distribute the Modified Software, in +source code or object code form, provided that said distribution +complies with all the provisions of the Agreement and is accompanied by: + + 1. a copy of the Agreement, + + 2. a notice relating to the limitation of both the Licensor's + warranty and liability as set forth in Articles 8 and 9, + +and that, in the event that only the object code of the Modified +Software is redistributed, the Licensee allows effective access to the +full source code of the Modified Software at a minimum during the entire +period of its distribution of the Modified Software, it being understood +that the additional cost of acquiring the source code shall not exceed +the cost of transferring the data. + + + 5.3.3 DISTRIBUTION OF DERIVATIVE SOFTWARE + +When the Licensee creates Derivative Software, this Derivative Software +may be distributed under a license agreement other than this Agreement, +subject to compliance with the requirement to include a notice +concerning the rights over the Software as defined in Article 6.4. +In the event the creation of the Derivative Software required modification +of the Source Code, the Licensee undertakes that: + + 1. the resulting Modified Software will be governed by this Agreement, + 2. the Integrated Contributions in the resulting Modified Software + will be clearly identified and documented, + 3. the Licensee will allow effective access to the source code of the + Modified Software, at a minimum during the entire period of + distribution of the Derivative Software, such that such + modifications may be carried over in a subsequent version of the + Software; it being understood that the additional cost of + purchasing the source code of the Modified Software shall not + exceed the cost of transferring the data. + + + 5.3.4 COMPATIBILITY WITH THE CeCILL LICENSE + +When a Modified Software contains an Integrated Contribution subject to +the CeCILL license agreement, or when a Derivative Software contains a +Related Module subject to the CeCILL license agreement, the provisions +set forth in the third item of Article 6.4 are optional. + + + Article 6 - INTELLECTUAL PROPERTY + + + 6.1 OVER THE INITIAL SOFTWARE + +The Holder owns the economic rights over the Initial Software. Any or +all use of the Initial Software is subject to compliance with the terms +and conditions under which the Holder has elected to distribute its work +and no one shall be entitled to modify the terms and conditions for the +distribution of said Initial Software. + +The Holder undertakes that the Initial Software will remain ruled at +least by this Agreement, for the duration set forth in Article 4.2. + + + 6.2 OVER THE INTEGRATED CONTRIBUTIONS + +The Licensee who develops an Integrated Contribution is the owner of the +intellectual property rights over this Contribution as defined by +applicable law. + + + 6.3 OVER THE RELATED MODULES + +The Licensee who develops a Related Module is the owner of the +intellectual property rights over this Related Module as defined by +applicable law and is free to choose the type of agreement that shall +govern its distribution under the conditions defined in Article 5.3.3. + + + 6.4 NOTICE OF RIGHTS + +The Licensee expressly undertakes: + + 1. not to remove, or modify, in any manner, the intellectual property + notices attached to the Software; + + 2. to reproduce said notices, in an identical manner, in the copies + of the Software modified or not; + + 3. to ensure that use of the Software, its intellectual property + notices and the fact that it is governed by the Agreement is + indicated in a text that is easily accessible, specifically from + the interface of any Derivative Software. + +The Licensee undertakes not to directly or indirectly infringe the +intellectual property rights of the Holder and/or Contributors on the +Software and to take, where applicable, vis-à-vis its staff, any and all +measures required to ensure respect of said intellectual property rights +of the Holder and/or Contributors. + + + Article 7 - RELATED SERVICES + +7.1 Under no circumstances shall the Agreement oblige the Licensor to +provide technical assistance or maintenance services for the Software. + +However, the Licensor is entitled to offer this type of services. The +terms and conditions of such technical assistance, and/or such +maintenance, shall be set forth in a separate instrument. Only the +Licensor offering said maintenance and/or technical assistance services +shall incur liability therefor. + +7.2 Similarly, any Licensor is entitled to offer to its licensees, under +its sole responsibility, a warranty, that shall only be binding upon +itself, for the redistribution of the Software and/or the Modified +Software, under terms and conditions that it is free to decide. Said +warranty, and the financial terms and conditions of its application, +shall be subject of a separate instrument executed between the Licensor +and the Licensee. + + + Article 8 - LIABILITY + +8.1 Subject to the provisions of Article 8.2, the Licensee shall be +entitled to claim compensation for any direct loss it may have suffered +from the Software as a result of a fault on the part of the relevant +Licensor, subject to providing evidence thereof. + +8.2 The Licensor's liability is limited to the commitments made under +this Agreement and shall not be incurred as a result of in particular: +(i) loss due the Licensee's total or partial failure to fulfill its +obligations, (ii) direct or consequential loss that is suffered by the +Licensee due to the use or performance of the Software, and (iii) more +generally, any consequential loss. In particular the Parties expressly +agree that any or all pecuniary or business loss (i.e. loss of data, +loss of profits, operating loss, loss of customers or orders, +opportunity cost, any disturbance to business activities) or any or all +legal proceedings instituted against the Licensee by a third party, +shall constitute consequential loss and shall not provide entitlement to +any or all compensation from the Licensor. + + + Article 9 - WARRANTY + +9.1 The Licensee acknowledges that the scientific and technical +state-of-the-art when the Software was distributed did not enable all +possible uses to be tested and verified, nor for the presence of +possible defects to be detected. In this respect, the Licensee's +attention has been drawn to the risks associated with loading, using, +modifying and/or developing and reproducing the Software which are +reserved for experienced users. + +The Licensee shall be responsible for verifying, by any or all means, +the suitability of the product for its requirements, its good working +order, and for ensuring that it shall not cause damage to either persons +or properties. + +9.2 The Licensor hereby represents, in good faith, that it is entitled +to grant all the rights over the Software (including in particular the +rights set forth in Article 5). + +9.3 The Licensee acknowledges that the Software is supplied "as is" by +the Licensor without any other express or tacit warranty, other than +that provided for in Article 9.2 and, in particular, without any warranty +as to its commercial value, its secured, safe, innovative or relevant +nature. + +Specifically, the Licensor does not warrant that the Software is free +from any error, that it will operate without interruption, that it will +be compatible with the Licensee's own equipment and software +configuration, nor that it will meet the Licensee's requirements. + +9.4 The Licensor does not either expressly or tacitly warrant that the +Software does not infringe any third party intellectual property right +relating to a patent, software or any other property right. Therefore, +the Licensor disclaims any and all liability towards the Licensee +arising out of any or all proceedings for infringement that may be +instituted in respect of the use, modification and redistribution of the +Software. Nevertheless, should such proceedings be instituted against +the Licensee, the Licensor shall provide it with technical and legal +assistance for its defense. Such technical and legal assistance shall be +decided on a case-by-case basis between the relevant Licensor and the +Licensee pursuant to a memorandum of understanding. The Licensor +disclaims any and all liability as regards the Licensee's use of the +name of the Software. No warranty is given as regards the existence of +prior rights over the name of the Software or as regards the existence +of a trademark. + + + Article 10 - TERMINATION + +10.1 In the event of a breach by the Licensee of its obligations +hereunder, the Licensor may automatically terminate this Agreement +thirty (30) days after notice has been sent to the Licensee and has +remained ineffective. + +10.2 A Licensee whose Agreement is terminated shall no longer be +authorized to use, modify or distribute the Software. However, any +licenses that it may have granted prior to termination of the Agreement +shall remain valid subject to their having been granted in compliance +with the terms and conditions hereof. + + + Article 11 - MISCELLANEOUS + + + 11.1 EXCUSABLE EVENTS + +Neither Party shall be liable for any or all delay, or failure to +perform the Agreement, that may be attributable to an event of force +majeure, an act of God or an outside cause, such as defective +functioning or interruptions of the electricity or telecommunications +networks, network paralysis following a virus attack, intervention by +government authorities, natural disasters, water damage, earthquakes, +fire, explosions, strikes and labor unrest, war, etc. + +11.2 Any failure by either Party, on one or more occasions, to invoke +one or more of the provisions hereof, shall under no circumstances be +interpreted as being a waiver by the interested Party of its right to +invoke said provision(s) subsequently. + +11.3 The Agreement cancels and replaces any or all previous agreements, +whether written or oral, between the Parties and having the same +purpose, and constitutes the entirety of the agreement between said +Parties concerning said purpose. No supplement or modification to the +terms and conditions hereof shall be effective as between the Parties +unless it is made in writing and signed by their duly authorized +representatives. + +11.4 In the event that one or more of the provisions hereof were to +conflict with a current or future applicable act or legislative text, +said act or legislative text shall prevail, and the Parties shall make +the necessary amendments so as to comply with said act or legislative +text. All other provisions shall remain effective. Similarly, invalidity +of a provision of the Agreement, for any reason whatsoever, shall not +cause the Agreement as a whole to be invalid. + + + 11.5 LANGUAGE + +The Agreement is drafted in both French and English and both versions +are deemed authentic. + + + Article 12 - NEW VERSIONS OF THE AGREEMENT + +12.1 Any person is authorized to duplicate and distribute copies of this +Agreement. + +12.2 So as to ensure coherence, the wording of this Agreement is +protected and may only be modified by the authors of the License, who +reserve the right to periodically publish updates or new versions of the +Agreement, each with a separate number. These subsequent versions may +address new issues encountered by Free Software. + +12.3 Any Software distributed under a given version of the Agreement may +only be subsequently distributed under the same version of the Agreement +or a subsequent version. + + + Article 13 - GOVERNING LAW AND JURISDICTION + +13.1 The Agreement is governed by French law. The Parties agree to +endeavor to seek an amicable solution to any disagreements or disputes +that may arise during the performance of the Agreement. + +13.2 Failing an amicable solution within two (2) months as from their +occurrence, and unless emergency proceedings are necessary, the +disagreements or disputes shall be referred to the Paris Courts having +jurisdiction, by the more diligent Party. + + +Version 1.0 dated 2006-09-05. From ae3c3a20d42154e45efa9a7a12b185ec1fc56453 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 14 Feb 2023 10:52:50 -0500 Subject: [PATCH 092/328] Add Noah 3.2 and NoahMP 4.0.1 This also removes Noah 3.0 and Noah 3.4. --- ...3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx | Bin 84208 -> 13566 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx b/lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx index 4b746e55b1f0edf9e28b164a7a8ce89121ca8a7c..9d8b4ae9ec0a34ab47a2226fc6523a89785811af 100644 GIT binary patch literal 13566 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 BMX&$> literal 84208 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 From bebd7af8347122f85c2df87d6819c676fb6ac424 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 14 Feb 2023 10:56:38 -0500 Subject: [PATCH 093/328] Rename NCAR Noah/NoahMP license --- ...h_v2.7.1_v3.2_v3.3_v3.6_v3.9.1_vMP_License.docx} | Bin 1 file changed, 0 insertions(+), 0 deletions(-) rename lis/LICENSES/{Noah_v2.7.1_v3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx => Noah_v2.7.1_v3.2_v3.3_v3.6_v3.9.1_vMP_License.docx} (100%) diff --git a/lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx b/lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.6_v3.9.1_vMP_License.docx similarity index 100% rename from lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.4_v3.6_v3.9.1_vMP_License.docx rename to lis/LICENSES/Noah_v2.7.1_v3.2_v3.3_v3.6_v3.9.1_vMP_License.docx From bd51a0c976671eff348bc55cdf267da38de67ff8 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Feb 2023 14:52:15 -0500 Subject: [PATCH 094/328] First cut at reading 3-hrly GHI NRT data for Teff. TODO: Temporal interpolation of values between two time levels. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 216 +++++++++++------- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 327 +++++++++++++++++++++++++++ 2 files changed, 465 insertions(+), 78 deletions(-) create mode 100644 ldt/SMAP_E_OPL/readLISTeff_usaf.F90 diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 9449ecf0b..a7d01d90f 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -16,6 +16,7 @@ ! !REVISION HISTORY: ! 14 Dec 2021: Yonghwan Kwon, Initial Specification ! 06 Feb 2023: Eric Kemp, now process subset of SMAP fields. +! 14 Feb 2023: Eric Kemp, now uses USAFSI and USAF LIS output. ! #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -193,8 +194,9 @@ subroutine LDT_smap_e_oplRun(n) ! This calls the actual SMAP_E_OPL driver ! !USES: - use LDT_logMod + use esmf use LDT_coreMod + use LDT_logMod implicit none ! !ARGUMENTS: @@ -214,7 +216,7 @@ subroutine LDT_smap_e_oplRun(n) character*2 :: hh_02, mm_02, dd_02 character*1 :: Orbit integer :: yr, mo, da, hr - integer :: yr_pre, mo_pre, da_pre + integer :: yr_pre, mo_pre, da_pre, hh_pre integer :: yr_02, mo_02, da_02, hr_02 logical :: dir_exists, read_L1Bdata real :: teff_01(LDT_rc%lnc(n),LDT_rc%lnr(n)) @@ -224,11 +226,17 @@ subroutine LDT_smap_e_oplRun(n) real :: UTChr(LDT_rc%lnc(n),LDT_rc%lnr(n)) integer :: L1B_dir_len integer :: doy_pre, doy_curr + type(ESMF_Calendar) :: calendar + type(ESMF_Time) :: firsttime, lasttime, curtime + type(ESMF_TimeInterval) :: deltatime + integer :: deltahr integer :: rc external :: readUSAFSI - ! Resample SMAP L1B to L1C + allocate(LDT_rc%nensem(LDT_rc%nnest)) + + ! Resample SMAP L1B to L1C call search_SMAPL1B_files(SMAPeOPL%L1Bdir,SMAPeOPL%date_curr,& SMAPeOPL%L1Btype) @@ -308,89 +316,136 @@ subroutine LDT_smap_e_oplRun(n) read(dd,*,iostat=ierr) da read(hh,*,iostat=ierr) hr - yr_pre = yr - mo_pre = mo - da_pre = da - 1 - if(da_pre.eq.0) then - mo_pre = mo - 1 - - if(mo_pre.eq.0) then - yr_pre = yr - 1 - mo_pre = 12 - da_pre = 31 - else - if(mo_pre.eq.1.or.& - mo_pre.eq.3.or.& - mo_pre.eq.5.or.& - mo_pre.eq.7.or.& - mo_pre.eq.8.or.& - mo_pre.eq.10.or.& - mo_pre.eq.12) then - da_pre = 31 - elseif(mo_pre.eq.2) then - if(mod(yr,4).eq.0) then - da_pre = 29 - else - da_pre = 28 - endif - else - da_pre = 30 - endif - endif - endif + calendar = ESMF_CalendarCreate(ESMF_CALKIND_GREGORIAN, & + name="Gregorian", & + rc=rc) + + ! Set current time + call ESMF_TimeSet(curtime, yy=yr, mm=mo, dd=da, h=hr, m=0, s=0, & + calendar=calendar, rc=rc) + call LDT_verify(rc, '[ERR] in ESMF_TimeSet in LDT_smap_e_oplRun') + + ! Go back 24 hours + call ESMF_TimeIntervalSet(deltatime, d=1, rc=rc) + call LDT_verify(rc, & + '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') + curtime = curtime - deltatime + + ! Now, find the nearest 3-hrly time (00Z, 03Z, ..., 21Z) prior + ! to curtime + if (mod(hr,3) == 0) then + deltahr = 0 + else + deltahr = hr + end if + call ESMF_TimeIntervalSet(deltatime, h=deltahr, rc=rc) + call LDT_verify(rc, & + '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') + firsttime = curtime - deltatime + + ! Now, find the next 3-hrly time (00Z, 03Z, ..., 21Z) after + ! firsttime + call ESMF_TimeIntervalSet(deltatime, h=3, rc=rc) + call LDT_verify(rc, & + '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') + lasttime = firsttime + deltatime + + ! Now, read the first time. + call ESMF_TimeGet(firsttime, yy=yr_pre, mm=mo_pre, dd=da_pre, & + h=hh_pre) + + ! yr_pre = yr + ! mo_pre = mo + ! da_pre = da - 1 + ! if(da_pre.eq.0) then + ! mo_pre = mo - 1 + + ! if(mo_pre.eq.0) then + ! yr_pre = yr - 1 + ! mo_pre = 12 + ! da_pre = 31 + ! else + ! if(mo_pre.eq.1.or.& + ! mo_pre.eq.3.or.& + ! mo_pre.eq.5.or.& + ! mo_pre.eq.7.or.& + ! mo_pre.eq.8.or.& + ! mo_pre.eq.10.or.& + ! mo_pre.eq.12) then + ! da_pre = 31 + ! elseif(mo_pre.eq.2) then + ! if(mod(yr,4).eq.0) then + ! da_pre = 29 + ! else + ! da_pre = 28 + ! endif + ! else + ! da_pre = 30 + ! endif + ! endif + ! endif write(unit=yyyy_01, fmt='(i4.4)') yr_pre write(unit=mm_01, fmt='(i2.2)') mo_pre write(unit=dd_01, fmt='(i2.2)') da_pre yyyymmdd_01 = trim(yyyy_01)//trim(mm_01)//trim(dd_01) - hh_01 = hh + write(unit=hh_01, fmt='(i2.2)') hh_pre + !hh_01 = hh - call readLIS_Teff(n,yyyymmdd_01,hh_01,Orbit,teff_01) + !call readLIS_Teff(n,yyyymmdd_01,hh_01,Orbit,teff_01) + call readLIS_Teff_usaf(n, yyyymmdd_01, hh_01, Orbit, teff_01, rc) + if (rc .ne. 0) then + write(LDT_logunit,*)'[WARN] No Teff data available...' + endif + + ! Now, read the last time. + call ESMF_TimeGet(lasttime, yy=yr_02, mm=mo_02, dd=da_02, & + h=hr_02) - yr_02 = yr_pre - mo_02 = mo_pre - da_02 = da_pre - hr_02 = hr + 1 + ! yr_02 = yr_pre + ! mo_02 = mo_pre + ! da_02 = da_pre + ! hr_02 = hr + 1 - if(hr_02.eq.24) then - hr_02 = 0 - da_02 = da_pre + 1 + ! if(hr_02.eq.24) then + ! hr_02 = 0 + ! da_02 = da_pre + 1 - if(mo_pre.eq.1.or.& - mo_pre.eq.3.or.& - mo_pre.eq.5.or.& - mo_pre.eq.7.or.& - mo_pre.eq.8.or.& - mo_pre.eq.10.or.& - mo_pre.eq.12) then - if(da_02.gt.31) then - da_02 = 1 - mo_02 = mo_pre + 1 - endif - elseif(mo_pre.eq.2) then - if(mod(yr_02,4).eq.0) then - if(da_02.gt.29) then - da_02 = 1 - mo_02 = mo_pre + 1 - endif - else - if(da_02.gt.28) then - da_02 = 1 - mo_02 = mo_pre + 1 - endif - endif - else - if(da_02.gt.30) then - da_02 = 1 - mo_02 = mo_pre + 1 - endif - endif - - if(mo_02.gt.12) then - mo_02 = 1 - yr_02 = yr_pre + 1 - endif - endif + ! if(mo_pre.eq.1.or.& + ! mo_pre.eq.3.or.& + ! mo_pre.eq.5.or.& + ! mo_pre.eq.7.or.& + ! mo_pre.eq.8.or.& + ! mo_pre.eq.10.or.& + ! mo_pre.eq.12) then + ! if(da_02.gt.31) then + ! da_02 = 1 + ! mo_02 = mo_pre + 1 + ! endif + ! elseif(mo_pre.eq.2) then + ! if(mod(yr_02,4).eq.0) then + ! if(da_02.gt.29) then + ! da_02 = 1 + ! mo_02 = mo_pre + 1 + ! endif + ! else + ! if(da_02.gt.28) then + ! da_02 = 1 + ! mo_02 = mo_pre + 1 + ! endif + ! endif + ! else + ! if(da_02.gt.30) then + ! da_02 = 1 + ! mo_02 = mo_pre + 1 + ! endif + ! endif + + ! if(mo_02.gt.12) then + ! mo_02 = 1 + ! yr_02 = yr_pre + 1 + ! endif + ! endif write(unit=yyyy_02, fmt='(i4.4)') yr_02 write(unit=mm_02, fmt='(i2.2)') mo_02 @@ -398,7 +453,11 @@ subroutine LDT_smap_e_oplRun(n) write(unit=hh_02, fmt='(i2.2)') hr_02 yyyymmdd_02 = trim(yyyy_02)//trim(mm_02)//trim(dd_02) - call readLIS_Teff(n,yyyymmdd_02,hh_02,Orbit,teff_02) + !call readLIS_Teff(n,yyyymmdd_02,hh_02,Orbit,teff_02) + call readLIS_Teff_usaf(n, yyyymmdd_02, hh_02, Orbit, teff_02, rc) + if (rc .ne. 0) then + write(LDT_logunit,*)'[WARN] No Teff data available...' + endif ! Scale LIS teff to GEOS teff climatology ! get DOY @@ -500,4 +559,5 @@ subroutine search_SMAPL1B_files(ndir,date_curr,L1Btype) end subroutine search_SMAPL1B_files + end module LDT_smap_e_oplMod diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 new file mode 100644 index 000000000..3b6a759eb --- /dev/null +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -0,0 +1,327 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT---------------------- + +#include "LDT_misc.h" +#include "LDT_NetCDF_inc.h" + +!BOP +! +! !ROUTINE: readLIS_Teff_usaf +! \label{readLISTeff} +! +! !REVISION HISTORY: +! 14 FEB 2023: Eric Kemp, Initial Specification +! +! !INTERFACE: +subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) +! !USES: + use LDT_coreMod + use LDT_domainMod + use LDT_logMod + use LDT_smap_e_oplMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + character(8), intent(in) :: yyyymmdd + character(2), intent(in) :: hh + character(1), intent(in) :: Orbit + real, intent(out) :: teff(LDT_rc%lnc(n),LDT_rc%lnr(n)) + integer, intent(out) :: rc + +!EOP + integer :: c,r + real :: tsoil(LDT_rc%lnc(n),LDT_rc%lnr(n),4) + character(255) :: fname + logical :: file_exists + integer :: rc1 + integer :: t + real, parameter :: kk = 1.007 + real, parameter :: cc_6am = 0.246 + real, parameter :: cc_6pm = 1.000 + + external :: create_LISsoilT_filename_usaf + external :: read_LIStsoil_data_usaf + + ! Initializations + teff = LDT_rc%udef + tsoil = LDT_rc%udef + rc = 1 ! Assume error by default, update below + + ! Set up basic info on Air Force product + ! FIXME...Fetch critical data from ldt.config file instead of hardwiring + LDT_rc%nensem(n) = 12 + LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) + if (.not. allocated(LDT_domain(n)%ntiles_pergrid)) & + allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + LDT_domain(n)%ntiles_pergrid = 1 + if (.not. allocated(LDT_domain(n)%str_tind)) & + allocate(LDT_domain(n)%str_tind(LDT_rc%glbntiles_red(n))) + do t = 1, LDT_rc%glbntiles_red(n) + LDT_domain(n)%str_tind(t) = t + end do + + call create_LISsoilT_filename_usaf(SMAPeOPL%LISdir, & + yyyymmdd, hh, fname) + + inquire(file=trim(fname), exist=file_exists) + if (file_exists) then + write(LDT_logunit,*) '[INFO] Reading ', trim(fname) + call read_LIStsoil_data_usaf(n, fname, tsoil, rc1) + if (rc1 .ne. 0) then + write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) + return + endif + write(LDT_logunit,*) '[INFO] Finished reading ', trim(fname) + + ! Calculate effective temperature + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + if (Orbit == "D") then + if (tsoil(c,r,1) > 273.15 .and. tsoil(c,r,2) > 273.15) then + teff(c,r) = kk * & + (cc_6am * tsoil(c,r,1) + (1 - cc_6am) * tsoil(c,r,2)) + endif + elseif (Orbit == "A") then + if (tsoil(c,r,1) > 273.15 .and. tsoil(c,r,2) > 273.15) then + teff(c,r) = kk * & + (cc_6pm * tsoil(c,r,1) + (1 - cc_6pm) * tsoil(c,r,2)) + endif + endif + end do + end do + rc = 0 + end if + +end subroutine readLIS_Teff_usaf + +!BOP +! +! !ROUTINE: read_LIStsoil_data_usaf +! \label{read_LIStsoil_data_usaf} +! +! !INTERFACE: +subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) +! +! !USES: + use LDT_logMod + use LDT_coreMod + use LDT_smap_e_oplMod +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none + +! +! !INPUT PARAMETERS: +! + integer, intent(in) :: n + character(*), intent(in) :: fname + real, intent(inout) :: tsoil(LDT_rc%lnc(n),LDT_rc%lnr(n),4) + integer, intent(out) :: rc +!EOP + + integer :: ios, ncid + integer :: ntiles_dimid, ntiles + integer :: SoilTemp_profiles_dimid, SoilTemp_profiles + integer :: SoilTemp_tavg_id + real, allocatable :: SoilTemp_tavg_tiles(:,:) + real :: SoilTemp_tavg_ensmean_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) + integer :: k, c, r + + external :: calc_gridded_ensmean_1layer + + rc = 1 ! Initialize as error, reset near bottom + + ! Sanity checks + if (LDT_rc%gnc(n) .ne. LDT_rc%lnc(n)) then + write(LDT_logunit,*)'[ERR] Mismatched dimensions!' + write(LDT_logunit,*)'[ERR] LDT_rc%gnc(n) = ', LDT_rc%gnc(n) + write(LDT_logunit,*)'[ERR] LDT_rc%lnc(n) = ', LDT_rc%lnc(n) + call LDT_endrun() + end if + if (LDT_rc%gnr(n) .ne. LDT_rc%lnr(n)) then + write(LDT_logunit,*)'[ERR] Mismatched dimensions!' + write(LDT_logunit,*)'[ERR] LDT_rc%gnr(n) = ', LDT_rc%gnr(n) + write(LDT_logunit,*)'[ERR] LDT_rc%lnr(n) = ', LDT_rc%lnr(n) + call LDT_endrun() + end if + +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + ios = nf90_open(path=trim(fname), mode=NF90_NOWRITE ,ncid=ncid) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Error opening file' // trim(fname) + return + end if + + ios = nf90_inq_dimid(ncid, "ntiles", ntiles_dimid) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot find ntiles in ' // trim(fname) + ios = nf90_close(ncid=ncid) + return + end if + + ios = nf90_inquire_dimension(ncid, ntiles_dimid, len=ntiles) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot get dimension ntiles in ' & + // trim(fname) + ios = nf90_close(ncid=ncid) + return + end if + + if (ntiles .ne. LDT_rc%glbntiles_red(n)) then + write(LDT_logunit,*)'[ERR] Dimension mismatch!' + write(LDT_logunit,*)'[ERR] ntiles = ', ntiles + write(LDT_logunit,*)'[ERR] LDT_rc%glbntiles_red(n) = ', & + LDT_rc%glbntiles_red(n) + call LDT_endrun() + end if + + ios = nf90_inq_dimid(ncid, "SoilTemp_profiles", SoilTemp_profiles_dimid) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_profiles in ' & + // trim(fname) + ios = nf90_close(ncid=ncid) + return + end if + + ios = nf90_inquire_dimension(ncid, SoilTemp_profiles_dimid, & + len=SoilTemp_profiles) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot get dimension SoilTemp_profiles in ' & + // trim(fname) + ios = nf90_close(ncid=ncid) + return + end if + if (SoilTemp_profiles .ne. 4) then + write(LDT_logunit,*)'[ERR] Dimension mismatch!' + write(LDT_logunit,*)'[ERR] SoilTemp_profiles should be 4, but is ', & + SoilTemp_profiles + call LDT_endrun() + end if + + ios = nf90_inq_varid(ncid, 'SoilTemp_tavg', SoilTemp_tavg_id) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_tavg in ' // trim(fname) + ios = nf90_close(ncid=ncid) + return + end if + + allocate(SoilTemp_tavg_tiles(ntiles, SoilTemp_profiles)) + SoilTemp_tavg_tiles = 0 + + ios = nf90_get_var(ncid, SoilTemp_tavg_id, SoilTemp_tavg_tiles, & + start=(/1, 1/), & + count=(/ntiles, SoilTemp_profiles/)) + if (ios .ne. 0) then + write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_tavg in ' // trim(fname) + deallocate(SoilTemp_tavg_tiles) + ios = nf90_close(ncid=ncid) + return + end if + + ! Calculate ensemble mean in 2d grid space, for each soil layer + do k = 1, SoilTemp_profiles + call calc_gridded_ensmean_1layer(n, SoilTemp_tavg_tiles(:,k), & + SoilTemp_tavg_ensmean_1layer) + do r = 1, LDT_rc%lnr(n) + do c = 1, LDT_rc%lnc(n) + if (SoilTemp_tavg_ensmean_1layer(c,r) > 0) then + tsoil(c,r,k) = SoilTemp_tavg_ensmean_1layer(c,r) + end if + end do + end do + end do + + ! Clean up + deallocate(SoilTemp_tavg_tiles) + + ios = nf90_close(ncid=ncid) + if (ios .ne. 0) then + write(LDT_logunit,*) '[WARN] Error closing ' // trim(fname) + return + end if + + rc = 0 ! No error detected + +#endif + +end subroutine read_LIStsoil_data_usaf + +! Subroutine for calculating 2d gridded ensemble mean for a single soil layer, +! from tiled data. +subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) + + ! Imports + use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc + use LDT_logMod, only: LDT_logunit + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) + real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) + + ! Locals + integer :: count1 + integer :: l, m, r, c, gid, stid, t, tid + integer :: ierr + + gvar = 0 + if (LDT_masterproc) then + do r = 1, LDT_rc%gnr(n) + do c = 1, LDT_rc%gnc(n) + gid = c + ((r-1) * LDT_rc%gnc(n)) + stid = LDT_domain(n)%str_tind(gid) + if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then + do m = 1, LDT_rc%nensem(n) + tid = stid + m - 1 + gvar(c,r) = gvar(c,r) + gvar_tile(tid) + enddo + gvar(c,r) = gvar(c,r) / LDT_rc%nensem(n) + end if + end do + end do + end if +end subroutine calc_gridded_ensmean_1layer + +!BOP +! !ROUTINE: create_LISsoilT_filename_usaf +! \label{create_LISsoilT_filename_usaf} +! +! !INTERFACE: +subroutine create_LISsoilT_filename_usaf(LISdir, yyyymmdd, hh, filename) + !USES: + + implicit none + !ARGUMENTS: + character(*), intent(in) :: LISdir + character(8), intent(in) :: yyyymmdd + character(2), intent(in) :: hh + character(*), intent(out) :: filename +!EOP + + filename = trim(LISdir) & + // '/PS.AFWA' & + // '_SC.U' & + // '_DI.C' & + // '_DC.ANLYS' & + // '_GP.LIS' & + // '_GR.C0P09DEG' & + // '_AR.GLOBAL' & + // '_PA.03-HR-SUM' & + // '_DD.' // yyyymmdd & + // '_DT.' // hh // '00' & + // '_DF.nc' + +end subroutine create_LISsoilT_filename_usaf From a401628ffd5c87a5d21cb00bf0098ce6a8d1b5e1 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 14 Feb 2023 09:53:01 -0500 Subject: [PATCH 095/328] Correct dimensions of tmp_sfcheadrt, tmp_infxs1rt, and tmp_soldrain1rt This patch fixes an error that resulted in glaciers melting. Here variables tmp_sfcheadrt, tmp_infxs1rt, and tmp_soldrain1rt were declared to be scalars, but within the NoahMP 4.0.1 physics, they are 2-d arrays sized 1x1. Technically, these are not equivalent. I resolved this issue by declaring tmp_sfcheadrt, tmp_infxs1rt, and tmp_soldrain1rt to be "real, dimension(1,1)". --- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 index 228575965..87c42073b 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 @@ -242,9 +242,9 @@ subroutine NoahMP401_main(n) ! Code added by David Mocko 04/25/2019 real :: startsm, startswe, startint, startgw, endsm - real :: tmp_sfcheadrt ! extra input for WRF-HYDRO [m] - real :: tmp_infxs1rt ! extra output for WRF-HYDRO [m] - real :: tmp_soldrain1rt ! extra output for WRF-HYDRO [m] + real, dimension(1,1) :: tmp_sfcheadrt ! extra input for WRF-HYDRO [m] + real, dimension(1,1) :: tmp_infxs1rt ! extra output for WRF-HYDRO [m] + real, dimension(1,1) :: tmp_soldrain1rt ! extra output for WRF-HYDRO [m] !ag (05Jan2021) real :: tmp_rivsto @@ -866,8 +866,8 @@ subroutine NoahMP401_main(n) NOAHMP401_struc(n)%noahmp401(t)%chuc = tmp_chuc NOAHMP401_struc(n)%noahmp401(t)%chv2 = tmp_chv2 NOAHMP401_struc(n)%noahmp401(t)%chb2 = tmp_chb2 - NOAHMP401_struc(n)%noahmp401(t)%infxs1rt = tmp_infxs1rt - NOAHMP401_struc(n)%noahmp401(t)%soldrain1rt = tmp_soldrain1rt + NOAHMP401_struc(n)%noahmp401(t)%infxs1rt = tmp_infxs1rt(1,1) + NOAHMP401_struc(n)%noahmp401(t)%soldrain1rt = tmp_soldrain1rt(1,1) ! EMK Update RHMin for 557WW if (tmp_tair .lt. & From d690eb0f2d913e2f81ef953e4ddd1db6e47e7409 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 15 Feb 2023 17:54:37 -0500 Subject: [PATCH 096/328] Add contributing organization and POC to license --- lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt | 24 +++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt b/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt index 43ff90f1d..35e5d9776 100644 --- a/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt +++ b/lis/LICENSES/CNRS_CECILL_C_v1_Crocus8.1.txt @@ -1,3 +1,27 @@ +Component name(s): Crocus snowpack model v8.1 + +Contributing organization/individuals: National Centre for Scientific Research (CNRS) and Météo-France + +POC: + +Marie Minvielle +Météo-France CNRM/GMME/SURFACE +42, av. G. Coriolis +31057 Toulouse Cedex - France +tph : +33 (0) 5 61 07 93 55 +fax : +33 (0) 5 61 07 96 26 +email: marie.minvielle at meteo.fr + +Patrick Le Moigne +Météo-France CNRM/GMME/SURFACE +42, av. G. Coriolis +31057 Toulouse Cedex - France +tph : +33 (0) 5 61 07 98 24 +fax : +33 (0) 5 61 07 96 26 +email: patrick.lemoigne at meteo.fr + +License: + CeCILL-C FREE SOFTWARE LICENSE AGREEMENT From 69bdbdbe256b57eaecd4ca85ee83e36f3feabd19 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 16 Feb 2023 17:03:50 -0500 Subject: [PATCH 097/328] Fixed bug with converting tilespace to grid space. Revised attempt to temporally interpolate Teff to SMAP time. Unfortunately, I have found a case where SMAP data requires interpolating using three Teff times (either betwen first and second, or second and third). This requires reading in a third Teff and passing to ARFSSMRETRIEVAL. TODO. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 49 ++++++++++++++++++++++++---- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 9 +++-- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 10 +++--- 3 files changed, 51 insertions(+), 17 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 3bc2996b1..9990d6474 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -16,9 +16,10 @@ !------------------------------------------------------------------------- subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& - ARFS_SNOW,DOY,UTChr) + ARFS_SNOW,DOY,UTChr,firsttime) - !USE HDF5 + !USE HDF5 + use esmf USE VARIABLES USE DATADOMAIN USE FUNCTIONS @@ -36,6 +37,7 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& REAL*4, DIMENSION(2560,1920) :: TS_bfresample_01, TS_bfresample_02 REAL*4, DIMENSION(2560,1920) :: ARFS_SNOW, UTChr INTEGER :: DOY + type(ESMF_Time), intent(in) :: firsttime !EOP INTEGER :: i, j, nrow, mcol CHARACTER (len=100) :: fname_TAU @@ -60,6 +62,8 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& ! EMK character(8) :: yyyymmdd character(6) :: hhmmss + real :: deltasec, wgt + integer :: firstUTCyr, firstUTCmo, firstUTCdy, firstUTChr nrow=2560 mcol=1920 @@ -130,6 +134,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& write (LDT_logunit,*) '[INFO] Generating soil moisture retrievals' ARFS_SM=-9999 ARFS_SM_FLAG=-1 + + call ESMF_TimeGet(firsttime, yy=firstUTCyr, mm=firstUTCmo, dd=firstUTCdy, & + h=firstUTChr) + ! DO i=1,nrow !ROW LON ! DO j=1,mcol !COL LAT DO j=1,mcol !COL LAT @@ -138,13 +146,38 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& tbv = ARFS_TB(i,j) if(UTChr(i,j).ge.0) then - utc_check = UTChr(i,j) - floor(UTChr(i,j)) + !utc_check = UTChr(i,j) - floor(UTChr(i,j)) + !if(utc_check.le.0.5) then + ! Ts = ARFS_TS_01(i,j) + ! else + ! Ts = ARFS_TS_02(i,j) + ! endif + + ! EMK Use linear interpolation between two time periods + ! It is possible that a particular SMAP measurement is valid + ! just over three hours after the first LIS Teff value; in this + ! case we just use second Teff (wgt = 0 for first Teff). + if (firstUTChr == 21 .and. (UTChr(i,j) > 21)) then + deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 + wgt = (10800. - deltasec) / 10800. + else if (UTChr(i,j) < (firstUTChr + 3)) then + deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 + wgt = (10800. - deltasec) / 10800. +! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, deltasec, wgt = ', & +! i,j,firstUTChr,UTChr(i,j),deltasec,wgt + + else + wgt = 0 + write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, wgt = ', & + i,j,firstUTChr,UTChr(i,j),wgt - if(utc_check.le.0.5) then - Ts = ARFS_TS_01(i,j) + end if + if (ARFS_TS_01(i,j) > 0 .and. ARFS_TS_02(i,j) > 0) then + TS = ((wgt)*ARFS_TS_01(i,j)) + ((1. - wgt)*ARFS_TS_02(i,j)) else - Ts = ARFS_TS_02(i,j) - endif + TS = -9999 + end if + endif IF (tbv.GT.0.0.AND.Ts.GT.0.AND.ARFS_SNOW(i,j).LE.SMAPeOPL%SD_thold.AND.ARFS_BD(i,j).NE.-9999.AND.ARFS_LC(i,j).NE.0.AND.& @@ -191,6 +224,8 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& ! OPEN(UNIT=151, FILE=retrieval_fname,FORM='UNFORMATTED',ACCESS='DIRECT', RECL=nrow*mcol*4) ! WRITE(UNIT=151, REC = 1) ARFS_SM ! CLOSE(151) + + ! NOTE: nrow is actually number of columns, mcol is actually number of ! rows call LDT_ARFSSM_write_netcdf(nrow, mcol, arfs_sm, retrieval_fname, & diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index a7d01d90f..90c39b86d 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -227,7 +227,7 @@ subroutine LDT_smap_e_oplRun(n) integer :: L1B_dir_len integer :: doy_pre, doy_curr type(ESMF_Calendar) :: calendar - type(ESMF_Time) :: firsttime, lasttime, curtime + type(ESMF_Time) :: firsttime, lasttime, curtime, prevdaytime type(ESMF_TimeInterval) :: deltatime integer :: deltahr integer :: rc @@ -329,7 +329,7 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeIntervalSet(deltatime, d=1, rc=rc) call LDT_verify(rc, & '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') - curtime = curtime - deltatime + prevdaytime = curtime - deltatime ! Now, find the nearest 3-hrly time (00Z, 03Z, ..., 21Z) prior ! to curtime @@ -341,7 +341,7 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeIntervalSet(deltatime, h=deltahr, rc=rc) call LDT_verify(rc, & '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') - firsttime = curtime - deltatime + firsttime = prevdaytime - deltatime ! Now, find the next 3-hrly time (00Z, 03Z, ..., 21Z) after ! firsttime @@ -519,8 +519,7 @@ subroutine LDT_smap_e_oplRun(n) ierr = LDT_create_subdirs(len_trim(SMAPeOPL%SMoutdir), & trim(SMAPeOPL%SMoutdir)) call ARFSSMRETRIEVAL(smap_L1B_filename(i),teff_01,teff_02,& - SnowDepth,doy_curr,UTChr) - + SnowDepth,doy_curr,UTChr,firsttime) deallocate(SMAPeOPL%ARFS_TBV_COR) endif enddo diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index 3b6a759eb..32014b768 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -42,7 +42,7 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) character(255) :: fname logical :: file_exists integer :: rc1 - integer :: t + integer :: gid real, parameter :: kk = 1.007 real, parameter :: cc_6am = 0.246 real, parameter :: cc_6pm = 1.000 @@ -60,12 +60,12 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) LDT_rc%nensem(n) = 12 LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) if (.not. allocated(LDT_domain(n)%ntiles_pergrid)) & - allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%lnc(n) * LDT_rc%lnr(n))) LDT_domain(n)%ntiles_pergrid = 1 if (.not. allocated(LDT_domain(n)%str_tind)) & - allocate(LDT_domain(n)%str_tind(LDT_rc%glbntiles_red(n))) - do t = 1, LDT_rc%glbntiles_red(n) - LDT_domain(n)%str_tind(t) = t + allocate(LDT_domain(n)%str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + do gid = 1, (LDT_rc%gnc(n) * LDT_rc%gnr(n)) + LDT_domain(n)%str_tind(gid) = ((gid - 1) * LDT_rc%nensem(n)) + 1 end do call create_LISsoilT_filename_usaf(SMAPeOPL%LISdir, & From 95c197c7f3ae3ba3b180e64869aacac52a122ea0 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Fri, 17 Feb 2023 13:33:06 -0500 Subject: [PATCH 098/328] Add note: please do not commit testcases into repository --- CONTRIBUTING.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 283c1b4ef..720b40330 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -58,6 +58,8 @@ Please use descriptive commit messages. See [this post](https://chris.beams.io/p If you are contributing a new feature, we will need a testcase so we can reproduce the result before the pull request is merged. Please read the [How to Create a Testcase](https://github.com/NASA-LIS/LISF/blob/master/docs/howto_create_lis_testcases/howto_create_lis_testcases.adoc) document. +**IMPORTANT:** Please **do not** commit your testcase into the Pull Request/repository. We will make arrangements to obtain your input/output files and configuration files. + ### Documentation If you are adding or modifying config entries, please update the appropriate config documentation file (e.g., `lis/configs/lis.config.adoc`) to reflect these changes. Our Users' Guides are written in the [AsciiDoc markup language](https://docs.asciidoctor.org/asciidoc/latest/). If you require assistance with documentation, please ask in the Issue thread. From 6555e7344958d3383211b533ce33869395bfe623 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 21 Feb 2023 15:38:12 -0500 Subject: [PATCH 099/328] Now temporally interpolates between three LIS analyses. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 129 ++++++++++++++++++--------- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 57 ++++++++---- ldt/SMAP_E_OPL/scale_teff.F90 | 59 +++++++----- 3 files changed, 168 insertions(+), 77 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 9990d6474..1ee3d2051 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -8,15 +8,17 @@ ! 22 Feb 2022: P.W.LIU; Initial implemetation ! 22 Feb 2022: Yonghwan Kwon; modified for LDT ! 10 Feb 2023: Eric Kemp, modified to output retrievals in netCDF. +! 21 Feb 2023: Eric Kemp, added third LIS time level. ! ! DESCRIPTION: RETRIEVE SMAP SM FOR ARFS -! INPUT : SMAP - L1B Brightness Temperature +! INPUT : SMAP - L1B Brightness Temperature ! OUTPUT: SMAPTB_ARFSGRIDE_ddmmyyy.dat ! NOTES : Inverse Distance Squared with 0.4 deg serching window !------------------------------------------------------------------------- - subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& - ARFS_SNOW,DOY,UTChr,firsttime) +subroutine ARFSSMRETRIEVAL(SMAPFILE, & + TS_bfresample_01, TS_bfresample_02, TS_bfresample_03, & + ARFS_SNOW, DOY, UTChr, firsttime, secondtime, thirdtime) !USE HDF5 use esmf @@ -28,16 +30,19 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& USE varsio_m USE algo_vpol_m use LDT_ARFSSM_netcdfMod, only: LDT_ARFSSM_write_netcdf - use LDT_logMod + use LDT_logMod, only: LDT_logunit USE LDT_smap_e_oplMod IMPLICIT NONE ! !ARGUMENTS: CHARACTER (len=100) :: SMAPFILE - REAL*4, DIMENSION(2560,1920) :: TS_bfresample_01, TS_bfresample_02 + REAL*4, DIMENSION(2560,1920), intent(in) :: TS_bfresample_01, & + TS_bfresample_02, TS_bfresample_03 REAL*4, DIMENSION(2560,1920) :: ARFS_SNOW, UTChr INTEGER :: DOY type(ESMF_Time), intent(in) :: firsttime + type(ESMF_Time), intent(in) :: secondtime + type(ESMF_Time), intent(in) :: thirdtime !EOP INTEGER :: i, j, nrow, mcol CHARACTER (len=100) :: fname_TAU @@ -47,7 +52,7 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& REAL*4, DIMENSION(2560,1920) :: ARFS_TAU, ARFS_CLAY, ARFS_BD, ARFS_OMEGA, ARFS_H INTEGER*1, DIMENSION(2560,1920) :: ARFS_LC, ARFS_SM_FLAG INTEGER*1 :: retrieval_flag - REAL*4, DIMENSION(2560,1920) :: ARFS_TS_01, ARFS_TS_02, ARFS_SM + REAL*4, DIMENSION(2560,1920) :: ARFS_TS_01, ARFS_TS_02, ARFS_TS_03, ARFS_SM REAL*8 ,DIMENSION(:), ALLOCATABLE :: ARFS_FINE_LAT, ARFS_FINE_LON REAL*8 ,DIMENSION(:), ALLOCATABLE :: ARFS_LAT, ARFS_LON REAL :: T1, T2 @@ -64,6 +69,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& character(6) :: hhmmss real :: deltasec, wgt integer :: firstUTCyr, firstUTCmo, firstUTCdy, firstUTChr + integer :: secondUTCyr, secondUTCmo, secondUTCdy, secondUTChr + integer :: thirdUTCyr, thirdUTCmo, thirdUTCdy, thirdUTChr + + real :: TS_A, TS_B nrow=2560 mcol=1920 @@ -80,6 +89,7 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& ARFS_FINE_LON = LON(arfs_geo_lon_lf,arfs_geo_lon_rt,arfs_lon_3km_space) CALL RESAMPLETEMP(TS_bfresample_01,ARFS_LAT,ARFS_LON,ARFS_FINE_LAT,ARFS_FINE_LON,ARFS_TS_01) CALL RESAMPLETEMP(TS_bfresample_02,ARFS_LAT,ARFS_LON,ARFS_FINE_LAT,ARFS_FINE_LON,ARFS_TS_02) + CALL RESAMPLETEMP(TS_bfresample_03,ARFS_LAT,ARFS_LON,ARFS_FINE_LAT,ARFS_FINE_LON,ARFS_TS_03) ! IF EVENTUALLY THE RESAMPLING DOES NOT CHANGE TEFF MUCH WE COULD SIMPLELY USE ARFS_TS=TS_bfresample ! UP TO HERE TAKES 38 SECS write (LDT_logunit,*) '[INFO] Finished resampling effective soil temperature' @@ -137,6 +147,11 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& call ESMF_TimeGet(firsttime, yy=firstUTCyr, mm=firstUTCmo, dd=firstUTCdy, & h=firstUTChr) + call ESMF_TimeGet(secondtime, yy=secondUTCyr, mm=secondUTCmo, & + dd=secondUTCdy, & + h=secondUTChr) + call ESMF_TimeGet(thirdtime, yy=thirdUTCyr, mm=thirdUTCmo, dd=thirdUTCdy, & + h=thirdUTChr) ! DO i=1,nrow !ROW LON ! DO j=1,mcol !COL LAT @@ -145,40 +160,74 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE,TS_bfresample_01,TS_bfresample_02,& tbv = ARFS_TB(i,j) - if(UTChr(i,j).ge.0) then - !utc_check = UTChr(i,j) - floor(UTChr(i,j)) - !if(utc_check.le.0.5) then - ! Ts = ARFS_TS_01(i,j) - ! else - ! Ts = ARFS_TS_02(i,j) - ! endif - - ! EMK Use linear interpolation between two time periods - ! It is possible that a particular SMAP measurement is valid - ! just over three hours after the first LIS Teff value; in this - ! case we just use second Teff (wgt = 0 for first Teff). - if (firstUTChr == 21 .and. (UTChr(i,j) > 21)) then - deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 - wgt = (10800. - deltasec) / 10800. - else if (UTChr(i,j) < (firstUTChr + 3)) then - deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 - wgt = (10800. - deltasec) / 10800. -! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, deltasec, wgt = ', & -! i,j,firstUTChr,UTChr(i,j),deltasec,wgt - - else - wgt = 0 - write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, wgt = ', & - i,j,firstUTChr,UTChr(i,j),wgt - - end if - if (ARFS_TS_01(i,j) > 0 .and. ARFS_TS_02(i,j) > 0) then - TS = ((wgt)*ARFS_TS_01(i,j)) + ((1. - wgt)*ARFS_TS_02(i,j)) - else - TS = -9999 - end if - - endif + if (UTChr(i,j) < 0) cycle + + if (UTChr(i,j) == firstUTChr) then + TS_A = ARFS_TS_01(i,j) + TS_B = ARFS_TS_02(i,j) + wgt = 1 + else if (UTChr(i,j) > firstUTChr .and. & + UTChr(i,j) < secondUTChr) then + TS_A = ARFS_TS_01(i,j) + TS_B = ARFS_TS_02(i,j) + deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 + wgt = (10800. - deltasec) / 10800. + else if (UTChr(i,j) > firstUTChr .and. & + firstUTChr == 21 .and. secondUTChr == 0) then + TS_A = ARFS_TS_01(i,j) + TS_B = ARFS_TS_02(i,j) + deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 + wgt = (10800. - deltasec) / 10800. + else if (UTChr(i,j) == secondUTChr) then + TS_A = ARFS_TS_02(i,j) + TS_B = ARFS_TS_03(i,j) + wgt = 1 + else + TS_A = ARFS_TS_02(i,j) + TS_B = ARFS_TS_03(i,j) + deltasec = ( UTChr(i,j) - secondUTChr ) * 3600 + wgt = (10800. - deltasec) / 10800. + end if + if (TS_A > 0 .and. TS_B > 0) then + TS = ((wgt)*TS_A) + ((1. - wgt)*TS_B) + write(LDT_logunit,*) & + 'EMK: i,j,UTChr,firstUTChr,secondUTChr,thirdUTChr,wgt:', & + i,j,UTChr(i,j),firstUTChr,secondUTChr,thirdUTChr,wgt + else + cycle + end if + +! if(UTChr(i,j).ge.0) then +! !utc_check = UTChr(i,j) - floor(UTChr(i,j)) +! !if(utc_check.le.0.5) then +! ! Ts = ARFS_TS_01(i,j) +! ! else +! ! Ts = ARFS_TS_02(i,j) +! ! endif + +! ! EMK Use linear interpolation between two time periods +! if (firstUTChr == 21 .and. (UTChr(i,j) > 21)) then +! deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 +! wgt = (10800. - deltasec) / 10800. +! else if (UTChr(i,j) < (firstUTChr + 3)) then +! deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 +! wgt = (10800. - deltasec) / 10800. +! ! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, deltasec, wgt = ', & +! ! i,j,firstUTChr,UTChr(i,j),deltasec,wgt + +! else +! wgt = 0 +! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, wgt = ', & +! i,j,firstUTChr,UTChr(i,j),wgt + +! end if +! if (ARFS_TS_01(i,j) > 0 .and. ARFS_TS_02(i,j) > 0) then +! TS = ((wgt)*ARFS_TS_01(i,j)) + ((1. - wgt)*ARFS_TS_02(i,j)) +! else +! TS = -9999 +! end if + +! endif IF (tbv.GT.0.0.AND.Ts.GT.0.AND.ARFS_SNOW(i,j).LE.SMAPeOPL%SD_thold.AND.ARFS_BD(i,j).NE.-9999.AND.ARFS_LC(i,j).NE.0.AND.& UTChr(i,j).GE.0) THEN diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 90c39b86d..89d82d623 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -208,26 +208,29 @@ subroutine LDT_smap_e_oplRun(n) integer :: ftn, ierr character*100 :: fname character*100 :: smap_L1B_filename(10) - character*8 :: yyyymmdd, yyyymmdd_01, yyyymmdd_02 + character*8 :: yyyymmdd, yyyymmdd_01, yyyymmdd_02, yyyymmdd_03 character*6 :: hhmmss(10) - character*4 :: yyyy, yyyy_01, yyyy_02 + character*4 :: yyyy, yyyy_01, yyyy_02, yyyy_03 character*2 :: hh, mm, dd - character*2 :: hh_01, mm_01, dd_01 + character*2 :: hh_01, mm_01, dd_01 character*2 :: hh_02, mm_02, dd_02 + character*2 :: hh_03, mm_03, dd_03 character*1 :: Orbit integer :: yr, mo, da, hr integer :: yr_pre, mo_pre, da_pre, hh_pre integer :: yr_02, mo_02, da_02, hr_02 + integer :: yr_03, mo_03, da_03, hr_03 logical :: dir_exists, read_L1Bdata real :: teff_01(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: teff_02(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: teff_03(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: TIMEsec(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: UTChr(LDT_rc%lnc(n),LDT_rc%lnr(n)) integer :: L1B_dir_len integer :: doy_pre, doy_curr type(ESMF_Calendar) :: calendar - type(ESMF_Time) :: firsttime, lasttime, curtime, prevdaytime + type(ESMF_Time) :: firsttime, secondtime, thirdtime, curtime, prevdaytime type(ESMF_TimeInterval) :: deltatime integer :: deltahr integer :: rc @@ -332,11 +335,11 @@ subroutine LDT_smap_e_oplRun(n) prevdaytime = curtime - deltatime ! Now, find the nearest 3-hrly time (00Z, 03Z, ..., 21Z) prior - ! to curtime - if (mod(hr,3) == 0) then + ! to prevdaytime + if (mod(hr, 3) == 0) then deltahr = 0 else - deltahr = hr + deltahr = hr - ((floor(real(hr)/3.))*3) end if call ESMF_TimeIntervalSet(deltatime, h=deltahr, rc=rc) call LDT_verify(rc, & @@ -348,7 +351,14 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeIntervalSet(deltatime, h=3, rc=rc) call LDT_verify(rc, & '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') - lasttime = firsttime + deltatime + secondtime = firsttime + deltatime + + ! Now, find the next 3-hrly time (00Z, 03Z, ..., 21Z) after + ! secondtime + call ESMF_TimeIntervalSet(deltatime, h=3, rc=rc) + call LDT_verify(rc, & + '[ERR] in ESMF_TimeIntervalSet in LDT_smap_e_oplRun') + thirdtime = secondtime + deltatime ! Now, read the first time. call ESMF_TimeGet(firsttime, yy=yr_pre, mm=mo_pre, dd=da_pre, & @@ -398,8 +408,8 @@ subroutine LDT_smap_e_oplRun(n) write(LDT_logunit,*)'[WARN] No Teff data available...' endif - ! Now, read the last time. - call ESMF_TimeGet(lasttime, yy=yr_02, mm=mo_02, dd=da_02, & + ! Now, read the second time. + call ESMF_TimeGet(secondtime, yy=yr_02, mm=mo_02, dd=da_02, & h=hr_02) ! yr_02 = yr_pre @@ -459,7 +469,23 @@ subroutine LDT_smap_e_oplRun(n) write(LDT_logunit,*)'[WARN] No Teff data available...' endif - ! Scale LIS teff to GEOS teff climatology + ! Now read the third time. + call ESMF_TimeGet(thirdtime, yy=yr_03, mm=mo_03, dd=da_03, & + h=hr_03) + + write(unit=yyyy_03, fmt='(i4.4)') yr_03 + write(unit=mm_03, fmt='(i2.2)') mo_03 + write(unit=dd_03, fmt='(i2.2)') da_03 + write(unit=hh_03, fmt='(i2.2)') hr_03 + yyyymmdd_03 = trim(yyyy_03)//trim(mm_03)//trim(dd_03) + + !call readLIS_Teff(n,yyyymmdd_03,hh_03,Orbit,teff_03) + call readLIS_Teff_usaf(n, yyyymmdd_03, hh_03, Orbit, teff_03, rc) + if (rc .ne. 0) then + write(LDT_logunit,*)'[WARN] No Teff data available...' + endif + + ! Scale LIS teff to GEOS teff climatology ! get DOY call get_doy(mo_pre,da_pre,doy_pre) @@ -484,7 +510,7 @@ subroutine LDT_smap_e_oplRun(n) ! scale write (LDT_logunit,*) '[INFO] Scaling LIS effective soil temperature' - call scale_teff(n,Orbit,teff_01,teff_02) + call scale_teff(n, Orbit, teff_01, teff_02, teff_03) write (LDT_logunit,*) '[INFO] Finished scaling LIS effective soil temperature' deallocate(SMAPeOPL%mu_6am_ref) @@ -507,7 +533,7 @@ subroutine LDT_smap_e_oplRun(n) if (rc .ne. 0) then write(LDT_logunit,*)'[WARN] No USAFSI data available!' endif - + ! Retrieve SMAP soil moisture ! get DOY call get_doy(mo,da,doy_curr) @@ -518,8 +544,9 @@ subroutine LDT_smap_e_oplRun(n) ! retrieve ierr = LDT_create_subdirs(len_trim(SMAPeOPL%SMoutdir), & trim(SMAPeOPL%SMoutdir)) - call ARFSSMRETRIEVAL(smap_L1B_filename(i),teff_01,teff_02,& - SnowDepth,doy_curr,UTChr,firsttime) + call ARFSSMRETRIEVAL(smap_L1B_filename(i), & + teff_01, teff_02, teff_03, & + SnowDepth, doy_curr, UTChr, firsttime, secondtime, thirdtime) deallocate(SMAPeOPL%ARFS_TBV_COR) endif enddo diff --git a/ldt/SMAP_E_OPL/scale_teff.F90 b/ldt/SMAP_E_OPL/scale_teff.F90 index 1691b59ee..c7c97fd07 100644 --- a/ldt/SMAP_E_OPL/scale_teff.F90 +++ b/ldt/SMAP_E_OPL/scale_teff.F90 @@ -12,12 +12,13 @@ ! ! !ROUTINE: scale_teff ! \label{scale_teff} -! -! !REVISION HISTORY: +! +! !REVISION HISTORY: ! 12 JAN 2022: Yonghwan Kwon, Initial Specification -! -! !INTERFACE: -subroutine scale_teff(n,Orbit,teff_01,teff_02) +! 21 Feb 2023: Eric Kemp, added third time level +! +! !INTERFACE: +subroutine scale_teff(n, Orbit, teff_01, teff_02, teff_03) ! !USES: use LDT_coreMod use LDT_smap_e_oplMod @@ -25,51 +26,52 @@ subroutine scale_teff(n,Orbit,teff_01,teff_02) implicit none ! !ARGUMENTS: integer, intent(in) :: n - character*1 :: Orbit + character*1, intent(in) :: Orbit real :: teff_01(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: teff_02(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real :: teff_03(LDT_rc%lnc(n),LDT_rc%lnr(n)) !EOP integer :: t integer :: col, row real :: mu_ref, mu_lis real :: sigma_ref, sigma_lis - real :: teff_01_tmp, teff_02_tmp + real :: teff_01_tmp, teff_02_tmp, teff_03_tmp - do t=1,SMAPeOPL%ngrid + do t = 1, SMAPeOPL%ngrid col = SMAPeOPL%grid_col(t) row = SMAPeOPL%grid_row(t) - if(Orbit.eq."D") then + if (Orbit.eq."D") then mu_ref = SMAPeOPL%mu_6am_ref(t) mu_lis = SMAPeOPL%mu_6am_lis(t) sigma_ref = SMAPeOPL%sigma_6am_ref(t) - sigma_lis = SMAPeOPL%sigma_6am_lis(t) - elseif(Orbit.eq."A") then + sigma_lis = SMAPeOPL%sigma_6am_lis(t) + elseif (Orbit.eq."A") then mu_ref = SMAPeOPL%mu_6pm_ref(t) mu_lis = SMAPeOPL%mu_6pm_lis(t) sigma_ref = SMAPeOPL%sigma_6pm_ref(t) sigma_lis = SMAPeOPL%sigma_6pm_lis(t) endif - if(teff_01(col,row).ne.-9999.0) then - if(mu_ref.gt.0.and.& - mu_lis.gt.0.and.& - sigma_ref.gt.0.and.& - sigma_lis.gt.0) then + if (teff_01(col,row).ne.-9999.0) then + if (mu_ref.gt.0.and.& + mu_lis.gt.0.and.& + sigma_ref.gt.0.and.& + sigma_lis.gt.0) then teff_01_tmp = (teff_01(col,row) - mu_lis) * & sigma_ref/sigma_lis + mu_ref - teff_01(col,row) = teff_01_tmp + teff_01(col,row) = teff_01_tmp endif endif - if(teff_02(col,row).ne.-9999.0) then - if(mu_ref.gt.0.and.& - mu_lis.gt.0.and.& - sigma_ref.gt.0.and.& - sigma_lis.gt.0) then + if (teff_02(col,row).ne.-9999.0) then + if (mu_ref.gt.0.and.& + mu_lis.gt.0.and.& + sigma_ref.gt.0.and.& + sigma_lis.gt.0) then teff_02_tmp = (teff_02(col,row) - mu_lis) * & sigma_ref/sigma_lis + mu_ref @@ -78,6 +80,19 @@ subroutine scale_teff(n,Orbit,teff_01,teff_02) endif endif + if (teff_03(col,row).ne.-9999.0) then + if (mu_ref.gt.0.and.& + mu_lis.gt.0.and.& + sigma_ref.gt.0.and.& + sigma_lis.gt.0) then + + teff_03_tmp = (teff_03(col,row) - mu_lis) * & + sigma_ref/sigma_lis + mu_ref + + teff_03(col,row) = teff_03_tmp + endif + endif + enddo end subroutine scale_teff From ec146f5c3c92a76adf5bc608e962930ef9c51b26 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 22 Feb 2023 13:45:30 -0500 Subject: [PATCH 100/328] Removed printing debug statement. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 1ee3d2051..86de1e21a 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -190,9 +190,9 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & end if if (TS_A > 0 .and. TS_B > 0) then TS = ((wgt)*TS_A) + ((1. - wgt)*TS_B) - write(LDT_logunit,*) & - 'EMK: i,j,UTChr,firstUTChr,secondUTChr,thirdUTChr,wgt:', & - i,j,UTChr(i,j),firstUTChr,secondUTChr,thirdUTChr,wgt + ! write(LDT_logunit,*) & + ! 'EMK: i,j,UTChr,firstUTChr,secondUTChr,thirdUTChr,wgt:', & + ! i,j,UTChr(i,j),firstUTChr,secondUTChr,thirdUTChr,wgt else cycle end if From 0f6d269f8ebe91adf0c1db16a40f668c98c7085a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 22 Feb 2023 16:11:16 -0500 Subject: [PATCH 101/328] Added tile and ensemble info for LIS USAF data to ldt.config file. These settings are now configurable instead of just being hard-wired. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 43 ++++++++++++++++++++++++++-- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 16 +++++++++-- 2 files changed, 54 insertions(+), 5 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 89d82d623..114a7e022 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -17,6 +17,7 @@ ! 14 Dec 2021: Yonghwan Kwon, Initial Specification ! 06 Feb 2023: Eric Kemp, now process subset of SMAP fields. ! 14 Feb 2023: Eric Kemp, now uses USAFSI and USAF LIS output. +! 22 Feb 2023: Eric Kemp, ensemble size now in ldt.config file. ! #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -50,7 +51,9 @@ module LDT_smap_e_oplMod integer, allocatable :: grid_col(:), grid_row(:) !(ngrid) real, allocatable :: ARFS_TBV_COR(:,:) real :: SD_thold - + integer :: num_ens ! Number of ensemble members in LIS USAF file. + integer :: num_tiles ! Total number of tiles in LIS USAF file. + integer :: ntiles_pergrid ! Number of tiles per grid point end type smap_e_opl_dec type(smap_e_opl_dec), public :: SMAPeOPL @@ -63,7 +66,7 @@ subroutine LDT_smap_e_oplInit() ! Imports use ESMF use LDT_coreMod, only: LDT_config - use LDT_logMod, only: LDT_verify + use LDT_logMod, only: LDT_logunit, LDT_endrun, LDT_verify ! Defaults implicit none @@ -145,6 +148,42 @@ subroutine LDT_smap_e_oplInit() call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%LISsnowdir, rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") + cfg_entry = "SMAP_E_OPL LIS ensemble size:" + call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%num_ens, rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + if (SMAPeOPL%num_ens < 1) then + write(LDT_logunit,*)'[ERR] LIS ensemble size must be at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', SMAPeOPL%num_ens + call LDT_endrun() + end if + + cfg_entry = "SMAP_E_OPL LIS total number of tiles (including ensembles):" + call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%num_tiles, rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + if (SMAPeOPL%num_tiles < 1) then + write(LDT_logunit,*) & + '[ERR] LIS total number of tiles (including ensembles) must be' & + //'at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', SMAPeOPL%num_tiles + call LDT_endrun() + end if + + cfg_entry = "SMAP_E_OPL LIS number of tiles per grid point:" + call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%ntiles_pergrid, rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + if (SMAPeOPL%num_tiles < 1) then + write(LDT_logunit,*) & + '[ERR] LIS number of tiles per grid point must be at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', SMAPeOPL%ntiles_pergrid + call LDT_endrun() + end if + cfg_entry = "SMAP_E_OPL snow depth threshold:" call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index 32014b768..c56fa3d41 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -57,13 +57,23 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) ! Set up basic info on Air Force product ! FIXME...Fetch critical data from ldt.config file instead of hardwiring - LDT_rc%nensem(n) = 12 - LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) + !LDT_rc%nensem(n) = 12 + LDT_rc%nensem(n) = SMAPeOPL%num_ens + !LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) + LDT_rc%glbntiles_red(n) = SMAPeOPL%num_tiles if (.not. allocated(LDT_domain(n)%ntiles_pergrid)) & allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%lnc(n) * LDT_rc%lnr(n))) - LDT_domain(n)%ntiles_pergrid = 1 + !LDT_domain(n)%ntiles_pergrid = 1 + LDT_domain(n)%ntiles_pergrid = SMAPeOPL%ntiles_pergrid if (.not. allocated(LDT_domain(n)%str_tind)) & allocate(LDT_domain(n)%str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + if (SMAPeOPL%ntiles_pergrid .ne. 1) then + write(LDT_logunit,*) & + '[ERR] Current SMAP_E_OPL code assumes ntiles_pergrid = 1' + write(LDT_logunit,*) & + '[ERR] Actual value is ', SMAPeOPL%ntiles_pergrid + call LDT_endrun() + end if do gid = 1, (LDT_rc%gnc(n) * LDT_rc%gnr(n)) LDT_domain(n)%str_tind(gid) = ((gid - 1) * LDT_rc%nensem(n)) + 1 end do From 7d5ecd59f6b62bb5087e6efbd34d70882999db10 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 24 Feb 2023 14:38:23 -0500 Subject: [PATCH 102/328] First attempt at reading netCDF SMAP_E_OPL retrievals. Compiles, but not tested yet. --- .../obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 | 228 ++++++++++++++++-- 1 file changed, 206 insertions(+), 22 deletions(-) diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 index 049de1ce1..27c1b45a8 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 @@ -8,12 +8,14 @@ ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LIS_misc.h" +#include "LIS_NetCDF_inc.h" !BOP ! !ROUTINE: read_SMAPEOPLsm ! \label{read_SMAPEOPLsm} ! ! !REVISION HISTORY: ! 6 Jun 2022: Yonghwan Kwon; Updated for use with SMAP_E_OPL soil moisture +! 23 Feb 2023: Eric Kemp; Updated to read netCDF file. ! ! !INTERFACE: subroutine read_SMAPEOPLsm(n, k, OBS_State, OBS_Pert_State) @@ -143,8 +145,11 @@ subroutine read_SMAPEOPLsm(n, k, OBS_State, OBS_Pert_State) write(hh,'(i2.2)') LIS_rc%hr if(LIS_masterproc) then + !list_files = trim(smobsdir)//'/ARFS_SM_*' & + ! //trim(yyyymmdd)//'T'//trim(hh)//'*.dat' + !EMK...Use netCDF list_files = trim(smobsdir)//'/ARFS_SM_*' & - //trim(yyyymmdd)//'T'//trim(hh)//'*.dat' + //trim(yyyymmdd)//'T'//trim(hh)//'*.nc' write(LIS_logunit,*) & '[INFO] Searching for ',trim(list_files) rc = create_filelist(trim(list_files)//char(0), & @@ -426,7 +431,9 @@ end subroutine read_SMAPEOPLsm subroutine read_SMAPEOPLsm_data(n, k,fname, smobs_inp, time) ! ! !USES: - +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif use LIS_coreMod use LIS_logMod use LIS_timeMgrMod @@ -452,28 +459,205 @@ subroutine read_SMAPEOPLsm_data(n, k,fname, smobs_inp, time) integer :: ios, nid integer :: c,r integer :: ftn1 - - ftn1 = LIS_getNextUnitNumber() - open(unit=ftn1,file=fname,form='unformatted',access='direct',recl=4*nc*nr,status='old') - read(ftn1, rec=1) sm_raw - close(1) - call LIS_releaseUnitNumber(ftn1) - + ! EMK + logical :: file_exists + character(255) :: map_projection + integer :: ncid, dim_ids(3), var_id + integer :: ntime, nlat, nlon + real, allocatable :: tmp(:,:,:) + integer :: rc + + ! Old code to use binary data + !ftn1 = LIS_getNextUnitNumber() + !open(unit=ftn1,file=fname,form='unformatted',access='direct',recl=4*nc*nr,status='old') + + ! read(ftn1, rec=1) sm_raw + ! close(1) + ! call LIS_releaseUnitNumber(ftn1) + + ! sm_data_b = .false. + + ! do r=1,SMAPEOPLsm_struc(n)%nr + ! do c=1,SMAPEOPLsm_struc(n)%nc + ! if (sm_raw(c,r)>=0.and.& + ! sm_raw(c,r)<=100) then + + ! sm_in(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = sm_raw(c,r) + ! sm_data_b(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = .true. + ! else + ! sm_in(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = LIS_rc%udef + ! sm_data_b(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = .false. + ! endif + ! enddo + ! enddo + + ! EMK...Read netCDF data + sm_in = LIS_rc%udef sm_data_b = .false. - do r=1,SMAPEOPLsm_struc(n)%nr - do c=1,SMAPEOPLsm_struc(n)%nc - if (sm_raw(c,r)>=0.and.& - sm_raw(c,r)<=100) then +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + + ! See if the file exists. + inquire(file=trim(fname), exist=file_exists) + if (.not. file_exists) then + write(LIS_logunit,*)'[ERR] Cannot find ', trim(fname) + return + end if + + ! Open the file + rc = nf90_open(path=trim(fname), & + mode=NF90_NOWRITE, & + ncid=ncid) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot open ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + return + end if + + ! Read the map projection + rc = nf90_get_att(ncid=ncid, & + varid=NF90_GLOBAL, & + name='MAP_PROJECTION', & + values=map_projection) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read MAP_PROJECTION from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + + ! Sanity check map projection + ! TODO: Support other map projections + if (trim(map_projection) .ne. 'EQUIDISTANT CYLINDRICAL') then + write(LIS_logunit,*) & + '[ERR] Unrecognized map projection found in SMAP file!' + write(LIS_logunit,*) '[ERR] Expected EQUIDISTANT CYLINDRICAL' + write(LIS_logunit,*) '[ERR] Found ',trim(map_projection) + write(LIS_logunit,*) '[ERR] LIS will skip file ', trim(fname) + rc = nf90_close(ncid) + return + end if + + ! Get dimension IDs + rc = nf90_inq_dimid(ncid=ncid, & + name='time', & + dimid=dim_ids(3)) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read time dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + rc = nf90_inq_dimid(ncid=ncid, & + name='lat', & + dimid=dim_ids(2)) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read lat dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + rc = nf90_inq_dimid(ncid=ncid, & + name='lon', & + dimid=dim_ids(1)) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read lon dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + + ! Get actual dimension sizes + rc = nf90_inquire_dimension(ncid=ncid, & + dimid=dim_ids(3), & + len=ntime) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read time dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + rc = nf90_inquire_dimension(ncid=ncid, & + dimid=dim_ids(2), & + len=nlat) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read lat dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + rc = nf90_inquire_dimension(ncid=ncid, & + dimid=dim_ids(1), & + len=nlon) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read lon dimension from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + + ! Sanity check the dimensions + if (ntime .ne. 1) then + write(LIS_logunit,*)'[ERR] Expected time dimension to be 1' + write(LIS_logunit,*)'[ERR] Found ', ntime, ' from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + if (nlat .ne. SMAPEOPLsm_struc(n)%nr) then + write(LIS_logunit,*)'[ERR] Expected lat dimension to be ', & + SMAPEOPLsm_struc(n)%nr + write(LIS_logunit,*)'[ERR] Found ', nlat, ' from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + if (nlon .ne. SMAPEOPLsm_struc(n)%nc) then + write(LIS_logunit,*)'[ERR] Expected lon dimension to be ', & + SMAPEOPLsm_struc(n)%nc + write(LIS_logunit,*)'[ERR] Found ', nlon, ' from ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + + ! Fetch the variable id + rc = nf90_inq_varid(ncid=ncid, & + name='arfs_sm', & + varid=var_id) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read arfs_sm ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + return + end if + + ! Read the retrievals + allocate(tmp(nlon, nlat, ntime)) + rc = nf90_get_var(ncid=ncid, & + varid=var_id, & + values=tmp) + if (rc .ne. 0) then + write(LIS_logunit,*)'[ERR] Cannot read arfs_sm ', trim(fname) + write(LIS_logunit,*)'[ERR] LIS will continue...' + rc = nf90_close(ncid) + deallocate(tmp) + return + end if + rc = nf90_close(ncid) + + do r = 1, nlat + do c = 1, nlon + if (tmp(c,r,1) >= 0 .and. & + tmp(c,r,1) <= 1) then + sm_in(c + (r-1)*nc) = tmp(c,r,1)*100 + sm_data_b(c + (r-1)*nc) = .true. + end if + end do + end do + deallocate(tmp) - sm_in(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = sm_raw(c,r) - sm_data_b(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = .true. - else - sm_in(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = LIS_rc%udef - sm_data_b(c+(r-1)*SMAPEOPLsm_struc(n)%nc) = .false. - endif - enddo - enddo +#endif !-------------------------------------------------------------------------- ! Interpolate to the LIS running domain @@ -495,7 +679,7 @@ subroutine read_SMAPEOPLsm_data(n, k,fname, smobs_inp, time) sm_data_b,sm_in, smobs_b_ip, smobs_ip) endif -!overwrite the input data +!overwrite the input data do r=1,LIS_rc%obs_lnr(k) do c=1,LIS_rc%obs_lnc(k) if(smobs_ip(c+(r-1)*LIS_rc%obs_lnc(k)).ne.-9999.0) then From 023de24207435b4001994da498fc4e4ebae6c833 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 9 Mar 2023 09:58:26 -0500 Subject: [PATCH 103/328] Changed code to use 12th ensemble member of SoilTemp_inst for Teff. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 1 + ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 88 +++++++++++++++++++++------- 2 files changed, 69 insertions(+), 20 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 114a7e022..d47b00395 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -275,6 +275,7 @@ subroutine LDT_smap_e_oplRun(n) integer :: rc external :: readUSAFSI + external :: readLIS_Teff_usaf allocate(LDT_rc%nensem(LDT_rc%nnest)) diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index c56fa3d41..2b46105eb 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -142,12 +142,16 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) integer :: ios, ncid integer :: ntiles_dimid, ntiles integer :: SoilTemp_profiles_dimid, SoilTemp_profiles - integer :: SoilTemp_tavg_id - real, allocatable :: SoilTemp_tavg_tiles(:,:) - real :: SoilTemp_tavg_ensmean_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) + !integer :: SoilTemp_tavg_id + integer :: SoilTemp_inst_id + !real, allocatable :: SoilTemp_tavg_tiles(:,:) + !real :: SoilTemp_tavg_ensmean_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) + real, allocatable :: SoilTemp_inst_tiles(:,:) + real :: SoilTemp_inst_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) integer :: k, c, r - external :: calc_gridded_ensmean_1layer + !external :: calc_gridded_ensmean_1layer + external :: calc_gridded_lastens_1layer rc = 1 ! Initialize as error, reset near bottom @@ -218,41 +222,54 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) call LDT_endrun() end if - ios = nf90_inq_varid(ncid, 'SoilTemp_tavg', SoilTemp_tavg_id) + !ios = nf90_inq_varid(ncid, 'SoilTemp_tavg', SoilTemp_tavg_id) + ios = nf90_inq_varid(ncid, 'SoilTemp_inst', SoilTemp_inst_id) if (ios .ne. 0) then - write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_tavg in ' // trim(fname) + !write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_tavg in ' // trim(fname) + write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_inst in ' // trim(fname) ios = nf90_close(ncid=ncid) return end if - allocate(SoilTemp_tavg_tiles(ntiles, SoilTemp_profiles)) - SoilTemp_tavg_tiles = 0 + !allocate(SoilTemp_tavg_tiles(ntiles, SoilTemp_profiles)) + !SoilTemp_tavg_tiles = 0 + allocate(SoilTemp_inst_tiles(ntiles, SoilTemp_profiles)) + SoilTemp_inst_tiles = 0 - ios = nf90_get_var(ncid, SoilTemp_tavg_id, SoilTemp_tavg_tiles, & + !ios = nf90_get_var(ncid, SoilTemp_tavg_id, SoilTemp_tavg_tiles, & + ios = nf90_get_var(ncid, SoilTemp_inst_id, SoilTemp_inst_tiles, & start=(/1, 1/), & count=(/ntiles, SoilTemp_profiles/)) if (ios .ne. 0) then - write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_tavg in ' // trim(fname) - deallocate(SoilTemp_tavg_tiles) + !write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_tavg in ' // trim(fname) + !deallocate(SoilTemp_tavg_tiles) + write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_inst in ' // trim(fname) + deallocate(SoilTemp_inst_tiles) ios = nf90_close(ncid=ncid) return end if ! Calculate ensemble mean in 2d grid space, for each soil layer do k = 1, SoilTemp_profiles - call calc_gridded_ensmean_1layer(n, SoilTemp_tavg_tiles(:,k), & - SoilTemp_tavg_ensmean_1layer) + !call calc_gridded_ensmean_1layer(n, SoilTemp_tavg_tiles(:,k), & + ! SoilTemp_tavg_ensmean_1layer) + call calc_gridded_lastens_1layer(n, SoilTemp_inst_tiles(:,k), & + SoilTemp_inst_1layer) do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) - if (SoilTemp_tavg_ensmean_1layer(c,r) > 0) then - tsoil(c,r,k) = SoilTemp_tavg_ensmean_1layer(c,r) + !if (SoilTemp_tavg_ensmean_1layer(c,r) > 0) then + ! tsoil(c,r,k) = SoilTemp_tavg_ensmean_1layer(c,r) + !end if + if (SoilTemp_inst_1layer(c,r) > 0) then + tsoil(c,r,k) = SoilTemp_inst_1layer(c,r) end if end do end do end do ! Clean up - deallocate(SoilTemp_tavg_tiles) + !deallocate(SoilTemp_tavg_tiles) + deallocate(SoilTemp_inst_tiles) ios = nf90_close(ncid=ncid) if (ios .ne. 0) then @@ -272,7 +289,6 @@ subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) ! Imports use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc - use LDT_logMod, only: LDT_logunit ! Defaults implicit none @@ -283,9 +299,7 @@ subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) ! Locals - integer :: count1 - integer :: l, m, r, c, gid, stid, t, tid - integer :: ierr + integer :: m, r, c, gid, stid, tid gvar = 0 if (LDT_masterproc) then @@ -305,6 +319,40 @@ subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) end if end subroutine calc_gridded_ensmean_1layer +! Subroutine for extracting last ensemble member for a single soil layer, +! from tiled data. +subroutine calc_gridded_lastens_1layer(n, gvar_tile, gvar) + + ! Imports + use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) + real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) + + ! Locals + integer :: m, r, c, gid, stid, tid + + if (LDT_masterproc) then + gvar = 0 + do r = 1, LDT_rc%gnr(n) + do c = 1, LDT_rc%gnc(n) + gid = c + ((r-1) * LDT_rc%gnc(n)) + stid = LDT_domain(n)%str_tind(gid) + if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then + m = LDT_rc%nensem(n) + tid = stid + m - 1 + gvar(c,r) = gvar_tile(tid) + end if + end do + end do + end if +end subroutine calc_gridded_lastens_1layer + !BOP ! !ROUTINE: create_LISsoilT_filename_usaf ! \label{create_LISsoilT_filename_usaf} From dfdf985adc5e6952e4b3387a5e55e3645b51751f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 10 Mar 2023 17:21:40 -0500 Subject: [PATCH 104/328] Retrieval uses ensmean of SoilTemp_inst. DAobs uses USAF prod tilespace file. Changes to support USAF prod tilespace file not tested yet. --- ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 | 36 +++++++ ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 46 ++++++--- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 95 ++++++++----------- 3 files changed, 108 insertions(+), 69 deletions(-) diff --git a/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 b/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 index 5d171a908..33e0742c1 100644 --- a/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 @@ -52,6 +52,10 @@ module LISlsmTEFF_obsMod character*20 :: data_category character*20 :: area_of_data character*20 :: write_interval + ! EMK + integer :: num_ens + integer :: num_tiles + integer :: ntiles_pergrid !-------------------------------------------------------- ! interpolation/upscaling weights !-------------------------------------------------------- @@ -127,6 +131,38 @@ subroutine LISlsmTEFF_obsInit() label="LIS soil temperature output directory:",rc=rc) call LDT_verify(rc,'LIS soil temperature output directory: not defined') + ! EMK Add LIS ensemble information + call ESMF_ConfigGetAttribute(LDT_config, lsmteffobs%num_ens, & + label="LIS ensemble size:", rc=rc) + call LDT_verify(rc,'LIS ensemble size: not defined') + if (lsmteffobs%num_ens < 1) then + write(LDT_logunit,*)'[ERR] LIS ensemble size must be at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', lsmteffobs%num_ens + call LDT_endrun() + end if + + call ESMF_ConfigGetAttribute(LDT_config, lsmteffobs%num_tiles, & + label="LIS total number of tiles (including ensembles):", rc=rc) + call LDT_verify(rc,'LIS total number of tiles (including ensembles): ' // & + 'not defined') + if (lsmteffobs%num_tiles < 1) then + write(LDT_logunit,*) & + '[ERR] LIS total number of tiles (including ensembles) must be' & + //'at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', lsmteffobs%num_tiles + call LDT_endrun() + end if + + call ESMF_ConfigGetAttribute(LDT_config, lsmteffobs%ntiles_pergrid, & + label="LIS number of tiles per grid point:", rc=rc) + call LDT_verify(rc,'LIS number of tiles per grid point: not defined') + if (lsmteffobs%num_tiles < 1) then + write(LDT_logunit,*) & + '[ERR] LIS number of tiles per grid point must be at least 1!' + write(LDT_logunit,*)'[ERR] Read in ', lsmteffobs%ntiles_pergrid + call LDT_endrun() + end if + ! WMO-convention specific identifiers if ( lsmteffobs%wstyle == "WMO convention") then call ESMF_ConfigGetAttribute(LDT_config,lsmteffobs%security_class, & diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index 4cd00b183..96f642a9e 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -50,6 +50,8 @@ subroutine readLISlsmTEFFobs(n) real :: teffvalue1d(lsmteffobs%nc*lsmteffobs%nr) real :: Tsoil01value2d(lsmteffobs%nc, lsmteffobs%nr) real :: Tsoil02value2d(lsmteffobs%nc, lsmteffobs%nr) + real :: tsoil(lsmteffobs%nc, lsmteffobs%nr, 4) + integer :: rc1 integer :: c,r character*20 :: vname integer :: varid @@ -156,21 +158,39 @@ end subroutine create_lsm_teff_output_filename if(iret.ne.0) then vname = 'SoilTemp_tavg' endif - - if(lsmteffobs%datares.eq.LDT_rc%gridDesc(n,10)) then - call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) - call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) - else - call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) - call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) - endif - iret = nf90_close(ftn) call LDT_verify(iret,'Error in nf90_close') + + !if(lsmteffobs%datares.eq.LDT_rc%gridDesc(n,10)) then + ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + ! 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) + ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + ! 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) + !else + ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + ! 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) + ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& + ! 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) + !endif + !iret = nf90_close(ftn) + !call LDT_verify(iret,'Error in nf90_close') + + if ((LDT_rc%lnc(n) .ne. lsmteffobs%nc) .or. & + (LDT_rc%lnr(n) .ne. lsmteffobs%nr)) then + write(LDT_logunit,*)'[ERR] Dimension mismatch for LIS data!' + write(LDT_logunit,*)'[ERR] LDT_rc%lnc, LDT_rc%lnr = ', & + LDT_rc%lnc(n), LDT_rc%lnr(n) + write(LDT_Logunit,*)'[ERR] lsmteffobs%nc, lsmteffobs%nr = ', & + lsmteffobs%nc, lsmteffobs%nr + call LDT_endrun() + end if + call read_LIStsoil_data_usaf(n, fname, tsoil, rc1) + if (rc1 .ne. 0) then + write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) + call LDT_endrun() + end if + tsoil01value2d = tsoil(:,:,1) + tsoil02value2d = tsoil(:,:,2) kk = 1.007 cc_6am = 0.246; !Descending diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index 2b46105eb..cb4d1bae9 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -142,16 +142,12 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) integer :: ios, ncid integer :: ntiles_dimid, ntiles integer :: SoilTemp_profiles_dimid, SoilTemp_profiles - !integer :: SoilTemp_tavg_id integer :: SoilTemp_inst_id - !real, allocatable :: SoilTemp_tavg_tiles(:,:) - !real :: SoilTemp_tavg_ensmean_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) real, allocatable :: SoilTemp_inst_tiles(:,:) - real :: SoilTemp_inst_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) + real :: SoilTemp_inst_ensmean_1layer(LDT_rc%gnc(n), LDT_rc%gnr(n)) integer :: k, c, r - !external :: calc_gridded_ensmean_1layer - external :: calc_gridded_lastens_1layer + external :: calc_gridded_ensmean_1layer rc = 1 ! Initialize as error, reset near bottom @@ -222,27 +218,20 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) call LDT_endrun() end if - !ios = nf90_inq_varid(ncid, 'SoilTemp_tavg', SoilTemp_tavg_id) ios = nf90_inq_varid(ncid, 'SoilTemp_inst', SoilTemp_inst_id) if (ios .ne. 0) then - !write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_tavg in ' // trim(fname) write(LDT_logunit,*)'[WARN] Cannot find SoilTemp_inst in ' // trim(fname) ios = nf90_close(ncid=ncid) return end if - !allocate(SoilTemp_tavg_tiles(ntiles, SoilTemp_profiles)) - !SoilTemp_tavg_tiles = 0 allocate(SoilTemp_inst_tiles(ntiles, SoilTemp_profiles)) SoilTemp_inst_tiles = 0 - !ios = nf90_get_var(ncid, SoilTemp_tavg_id, SoilTemp_tavg_tiles, & ios = nf90_get_var(ncid, SoilTemp_inst_id, SoilTemp_inst_tiles, & start=(/1, 1/), & count=(/ntiles, SoilTemp_profiles/)) if (ios .ne. 0) then - !write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_tavg in ' // trim(fname) - !deallocate(SoilTemp_tavg_tiles) write(LDT_logunit,*)'[WARN] Cannot read SoilTemp_inst in ' // trim(fname) deallocate(SoilTemp_inst_tiles) ios = nf90_close(ncid=ncid) @@ -251,24 +240,18 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) ! Calculate ensemble mean in 2d grid space, for each soil layer do k = 1, SoilTemp_profiles - !call calc_gridded_ensmean_1layer(n, SoilTemp_tavg_tiles(:,k), & - ! SoilTemp_tavg_ensmean_1layer) - call calc_gridded_lastens_1layer(n, SoilTemp_inst_tiles(:,k), & - SoilTemp_inst_1layer) + call calc_gridded_ensmean_1layer(n, SoilTemp_inst_tiles(:,k), & + SoilTemp_inst_ensmean_1layer) do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) - !if (SoilTemp_tavg_ensmean_1layer(c,r) > 0) then - ! tsoil(c,r,k) = SoilTemp_tavg_ensmean_1layer(c,r) - !end if - if (SoilTemp_inst_1layer(c,r) > 0) then - tsoil(c,r,k) = SoilTemp_inst_1layer(c,r) + if (SoilTemp_inst_ensmean_1layer(c,r) > 0) then + tsoil(c,r,k) = SoilTemp_inst_ensmean_1layer(c,r) end if end do end do end do ! Clean up - !deallocate(SoilTemp_tavg_tiles) deallocate(SoilTemp_inst_tiles) ios = nf90_close(ncid=ncid) @@ -319,39 +302,39 @@ subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) end if end subroutine calc_gridded_ensmean_1layer -! Subroutine for extracting last ensemble member for a single soil layer, -! from tiled data. -subroutine calc_gridded_lastens_1layer(n, gvar_tile, gvar) - - ! Imports - use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc - - ! Defaults - implicit none - - ! Arguments - integer, intent(in) :: n - real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) - real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) - - ! Locals - integer :: m, r, c, gid, stid, tid - - if (LDT_masterproc) then - gvar = 0 - do r = 1, LDT_rc%gnr(n) - do c = 1, LDT_rc%gnc(n) - gid = c + ((r-1) * LDT_rc%gnc(n)) - stid = LDT_domain(n)%str_tind(gid) - if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then - m = LDT_rc%nensem(n) - tid = stid + m - 1 - gvar(c,r) = gvar_tile(tid) - end if - end do - end do - end if -end subroutine calc_gridded_lastens_1layer +! ! Subroutine for extracting last ensemble member for a single soil layer, +! ! from tiled data. +! subroutine calc_gridded_lastens_1layer(n, gvar_tile, gvar) + +! ! Imports +! use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc + +! ! Defaults +! implicit none + +! ! Arguments +! integer, intent(in) :: n +! real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) +! real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) + +! ! Locals +! integer :: m, r, c, gid, stid, tid + +! if (LDT_masterproc) then +! gvar = 0 +! do r = 1, LDT_rc%gnr(n) +! do c = 1, LDT_rc%gnc(n) +! gid = c + ((r-1) * LDT_rc%gnc(n)) +! stid = LDT_domain(n)%str_tind(gid) +! if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then +! m = LDT_rc%nensem(n) +! tid = stid + m - 1 +! gvar(c,r) = gvar_tile(tid) +! end if +! end do +! end do +! end if +! end subroutine calc_gridded_lastens_1layer !BOP ! !ROUTINE: create_LISsoilT_filename_usaf From 445defe6c23335fdd089b19f5f015903be2efda4 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 14 Mar 2023 14:04:44 -0400 Subject: [PATCH 105/328] Bug fixes for LIS Teff CDF generation. --- ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 25 +++++++++++++-- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 32 ++++++++++++------- 2 files changed, 43 insertions(+), 14 deletions(-) diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index 96f642a9e..121dbd58e 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -184,7 +184,8 @@ end subroutine create_lsm_teff_output_filename lsmteffobs%nc, lsmteffobs%nr call LDT_endrun() end if - call read_LIStsoil_data_usaf(n, fname, tsoil, rc1) + call read_LIStsoil_data_usaf(n, lsmteffobs%num_tiles, fname, tsoil, & + rc1) if (rc1 .ne. 0) then write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) call LDT_endrun() @@ -515,6 +516,15 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & fres2 = trim(fres2)//'DEG' endif + ! out_fname = trim(odir)//'/'//& + ! '/PS.AFWA_SC.'//trim(security_class)//& + ! '_DI.'//trim(distribution_class)//& + ! '_DC.'//trim(data_category)//& + ! '_GP.LIS_GR.'//& + ! trim(fproj)//trim(fres2)//& + ! '_AR.'//trim(area_of_data)//& + ! '_PA.'//trim(write_interval)//'-HR-SUM_DD.'//& + ! trim(cdate1)//'_DT.'//trim(cdate)//'_DF.GR1' out_fname = trim(odir)//'/'//& '/PS.AFWA_SC.'//trim(security_class)//& '_DI.'//trim(distribution_class)//& @@ -523,7 +533,18 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & trim(fproj)//trim(fres2)//& '_AR.'//trim(area_of_data)//& '_PA.'//trim(write_interval)//'-HR-SUM_DD.'//& - trim(cdate1)//'_DT.'//trim(cdate)//'_DF.GR1' + trim(cdate1)//'_DT.'//trim(cdate)//'_DF' + if (form == "netcdf") then + out_fname = trim(out_fname) // ".nc" + else if (form == "grib1") then + out_fname = trim(out_fname) // ".GR1" + else if (form == "grib2") then + out_fname = trim(out_fname) // ".GR2" + else + write(LDT_logunit,*)'[ERR] Invalid LIS file format ', trim(form) + call LDT_endrun() + end if + endif fname = out_fname end subroutine create_lsm_teff_output_filename diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index cb4d1bae9..3428b4dd1 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -60,7 +60,7 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) !LDT_rc%nensem(n) = 12 LDT_rc%nensem(n) = SMAPeOPL%num_ens !LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) - LDT_rc%glbntiles_red(n) = SMAPeOPL%num_tiles + !LDT_rc%glbntiles_red(n) = SMAPeOPL%num_tiles if (.not. allocated(LDT_domain(n)%ntiles_pergrid)) & allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%lnc(n) * LDT_rc%lnr(n))) !LDT_domain(n)%ntiles_pergrid = 1 @@ -84,7 +84,7 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) inquire(file=trim(fname), exist=file_exists) if (file_exists) then write(LDT_logunit,*) '[INFO] Reading ', trim(fname) - call read_LIStsoil_data_usaf(n, fname, tsoil, rc1) + call read_LIStsoil_data_usaf(n, SMAPeOPL%num_tiles, fname, tsoil, rc1) if (rc1 .ne. 0) then write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) return @@ -118,7 +118,7 @@ end subroutine readLIS_Teff_usaf ! \label{read_LIStsoil_data_usaf} ! ! !INTERFACE: -subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) +subroutine read_LIStsoil_data_usaf(n, ntiles, fname, tsoil, rc) ! ! !USES: use LDT_logMod @@ -134,13 +134,14 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) ! !INPUT PARAMETERS: ! integer, intent(in) :: n + integer, intent(in) :: ntiles character(*), intent(in) :: fname real, intent(inout) :: tsoil(LDT_rc%lnc(n),LDT_rc%lnr(n),4) integer, intent(out) :: rc !EOP integer :: ios, ncid - integer :: ntiles_dimid, ntiles + integer :: ntiles_dimid, ntiles_local integer :: SoilTemp_profiles_dimid, SoilTemp_profiles integer :: SoilTemp_inst_id real, allocatable :: SoilTemp_inst_tiles(:,:) @@ -179,7 +180,7 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) return end if - ios = nf90_inquire_dimension(ncid, ntiles_dimid, len=ntiles) + ios = nf90_inquire_dimension(ncid, ntiles_dimid, len=ntiles_local) if (ios .ne. 0) then write(LDT_logunit,*)'[WARN] Cannot get dimension ntiles in ' & // trim(fname) @@ -187,11 +188,17 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) return end if - if (ntiles .ne. LDT_rc%glbntiles_red(n)) then + ! if (ntiles .ne. LDT_rc%glbntiles_red(n)) then + ! write(LDT_logunit,*)'[ERR] Dimension mismatch!' + ! write(LDT_logunit,*)'[ERR] ntiles = ', ntiles + ! write(LDT_logunit,*)'[ERR] LDT_rc%glbntiles_red(n) = ', & + ! LDT_rc%glbntiles_red(n) + ! call LDT_endrun() + ! end if + if (ntiles_local .ne. ntiles) then write(LDT_logunit,*)'[ERR] Dimension mismatch!' - write(LDT_logunit,*)'[ERR] ntiles = ', ntiles - write(LDT_logunit,*)'[ERR] LDT_rc%glbntiles_red(n) = ', & - LDT_rc%glbntiles_red(n) + write(LDT_logunit,*)'[ERR] ntiles = ', ntiles_local + write(LDT_logunit,*)'[ERR] Expected ', ntiles call LDT_endrun() end if @@ -240,7 +247,7 @@ subroutine read_LIStsoil_data_usaf(n, fname, tsoil, rc) ! Calculate ensemble mean in 2d grid space, for each soil layer do k = 1, SoilTemp_profiles - call calc_gridded_ensmean_1layer(n, SoilTemp_inst_tiles(:,k), & + call calc_gridded_ensmean_1layer(n, ntiles, SoilTemp_inst_tiles(:,k), & SoilTemp_inst_ensmean_1layer) do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) @@ -268,7 +275,7 @@ end subroutine read_LIStsoil_data_usaf ! Subroutine for calculating 2d gridded ensemble mean for a single soil layer, ! from tiled data. -subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) +subroutine calc_gridded_ensmean_1layer(n, ntiles, gvar_tile, gvar) ! Imports use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc @@ -278,7 +285,8 @@ subroutine calc_gridded_ensmean_1layer(n, gvar_tile, gvar) ! Arguments integer, intent(in) :: n - real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) + integer, intent(in) :: ntiles + real, intent(in) :: gvar_tile(ntiles) real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) ! Locals From 9b06a00863326875f25246ed3c4d070946104343 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 16 Mar 2023 09:29:06 -0400 Subject: [PATCH 106/328] Correct intent error This patch fixes an intent(out) vs intent(inout) error that resulted in glaciers melting. In SFCDIF1_GLACIER, the variable FV was declared as intent(out). Technically, this means that FV was uninitialized. FV was initialized for the first iteration (ITER=1), but it was not initialized for subsequent calls (iterations 2 through 5). --- .../land/noahmp.4.0.1/phys/module_sf_noahmp_glacier_401.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmp_glacier_401.F90 b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmp_glacier_401.F90 index cc0dba5ae..2a36e31e7 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmp_glacier_401.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmp_glacier_401.F90 @@ -1208,7 +1208,7 @@ SUBROUTINE SFCDIF1_GLACIER(ITER ,ZLVL ,ZPD ,Z0H ,Z0M , & !in REAL, INTENT(INOUT) :: FH2 !sen heat stability correction, weighted by prior iters ! outputs - REAL, INTENT(OUT) :: FV !friction velocity (m/s) + REAL, INTENT(INOUT) :: FV !friction velocity (m/s) REAL, INTENT(OUT) :: CM !drag coefficient for momentum REAL, INTENT(OUT) :: CH !drag coefficient for heat REAL, INTENT(OUT) :: CH2 !drag coefficient for heat From 64c39fe85c040fe202630a6f8211d6ab380f5fa8 Mon Sep 17 00:00:00 2001 From: David Mocko Date: Thu, 16 Mar 2023 11:18:54 -0400 Subject: [PATCH 107/328] Fix some HYMAP2 arrays not being deallocated Added deallocate statements for some allocated arrays for the HYMAP2 router. --- lis/routing/HYMAP2_router/HYMAP2_model_core.F90 | 12 ++++++++---- lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 | 12 +++++++----- 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 b/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 index 86d6ac893..8f47eb4e6 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 @@ -559,18 +559,22 @@ subroutine HYMAP2_model_core(n,it,mis,nseqall,nz,time,dt, & enddo deallocate(rivelv_glb) - deallocate(rivdph_glb) + deallocate(rivsto_glb) + deallocate(rivdph_glb) deallocate(rivdph_pre_glb) deallocate(fldelv1_glb) deallocate(flddph1_glb) + deallocate(fldsto_glb) deallocate(flddph_pre_glb) ! deallocate(next_glb) deallocate(rivout_glb) - deallocate(rivsto_glb) - deallocate(fldsto_glb) - deallocate(fldout_glb) + deallocate(fldout_glb) + deallocate(rivinf_glb) + deallocate(fldinf_glb) !ag(27Apr2020) if(flowtype==4)then + deallocate(drsto_glb) + deallocate(drout_glb) deallocate(drinf_glb) endif end subroutine HYMAP2_model_core diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 index 59538f81d..a091240c0 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 @@ -896,13 +896,15 @@ subroutine HYMAP2_routing_run(n) if(HYMAP2_routing_struc(n)%evapflag.ne.0)then deallocate(tmp_tmp) deallocate(tmp_q2) - deallocate(tmp_qnet) - deallocate(tmp_wind) deallocate(tmp_psurf) - deallocate(tair) + deallocate(tmp_wind) + deallocate(tmp_qnet) + + deallocate(evap) + deallocate(tair) deallocate(qair) - deallocate(pres) - deallocate(wind) + deallocate(pres) + deallocate(wind) deallocate(qnet) deallocate(tmpet) endif From 26b51b4ba7a9467b4013c24ff4f5a3d16a015a20 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 11:22:30 -0400 Subject: [PATCH 108/328] Add "How-To" Doc for SnowModel Adding documentation for how to run SnowModel in LIS and an example snowmodel.par file is provided in a new "docs" directory within the SnowModel code. Addresses GitHub Issue ticket #1290. --- .../snowmodel/docs/lis_snowmodel_howto.adoc | 173 +++ .../land/subLSM/snowmodel/docs/snowmodel.par | 1231 +++++++++++++++++ 2 files changed, 1404 insertions(+) create mode 100644 lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc create mode 100755 lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc new file mode 100644 index 000000000..f3449b2aa --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -0,0 +1,173 @@ +[[sec_doctitle,Quick “How To” for Setting up and Running SnowModel in LIS]] +== Quick “How To” for Setting up and Running SnowModel in LIS + +March.10.2023 + +[[ssec_overview,Overview]] +=== Overview + +Glen Liston’s SnowModel (Liston and Elder, 2006a), a spatially +distributed snow modeling system with several submodels, including +MicroMet (Liston and Elder, 2006b), SnowPack and a 3-D wind-snow +transport scheme, SnowTran-3D (Liston and Sturm, 1998), is now +available in the latest Land Information System Framework (LISF; +Kumar et al., 2006), available from our GitHub page (under the +“master” branch): https://github.com/NASA-LIS/LISF + +The version of SnowModel that was implemented is based on the +NCAR/CSU GitHub “candidate-changes” branch, that is an early +Fortran-90 update of the model and based on Glen Liston’s code +from April-2021. SnowModel in the LISF can utilize the same input +files and model parameter files as used in the offline version, +with a few updates to note for running in this newer model driver +environment. + +LISF has three main components: the Land surface Data Toolkit (LDT; +Arsenault et al., 2018), Land Information System (LIS; Kumar et al., 2006), +and the Land Verification Toolkit (LVT, Kumar et al., 2012). To run +SnowModel in LISF, you will need LDT and LIS components to prepare +parameters and run the model, respectively. Please find below the +quick “How to” steps for setting up and running SnowModel in LISF. + +[[ssec_purpose,Purpose]] +=== Purpose + +Running the SnowModel model within the LIS Framework. + +[[ssec_prerequisites,Prerequisites]] +=== Prerequisites + ++ +* SnowModel input files, including snowmodel.par, topo_vege file, + GrADS descriptor files (“ctl_files”) and optional forcing input file. +* Compiled LDT and LIS executables. +* LDT and LIS config files, LDT output parameter file, and LIS + input forcing and model output tables. ++ + +A. Outline of SnowModel Steps + +[[ssec_snowmodelsteps,A. Outline of SnowModel Steps]] +=== A. Outline of SnowModel Steps + +. Define and generate your model domain and native binary input parameter file (“topo_vege.gdat”) using Glen Liston’s SnowModel topo_vege tools and scripts. We recommend using Lambert conformal type grids when setting up your domain for running with LDT and LIS. LIS can handle also UTM and Mercator domains, but additional code updates would be needed to support these grids for SnowModel in LISF. + +. LIS is able to support running SnowModel with either its original native ASCII- or binary-formatted “station-based” meteorological forcing files (found in “met/[forcing_dataset]/7_mk_mm/”), or you can use any of the meteorological forcing data readers available in LIS (e.g., NLDAS2, GDAS, MERRA2), which allows the user to bypass all the main SnowModel preprocessing steps. For running with the SnowModel’s native ASCII-formatted files, for example, this option can allow the user to run with in situ station observations as before. + +. For large domains, we recommend also setting up the “extra_met” grid_lon.gdat and grid_lat.gdat files for handling of UTC time changes for the solar radiation calculations in SnowModel. + +. Next, you will want to set up your SnowModel parameter text-based input file: snowmodel.par, as you normally would to run the model. This input parameter file is read in by LIS and “loads” the variety of options available to run the SnowModel system. Note: With the LIS version, one new option was included in the snowmodel.par file, which an example is provided within this “docs” directory with this “How To”, default option is: + +[subs="attributes+,-callouts"] +.... + metforce_opt = 0 +.... + +. Finally, for the LIS-SnowModel model output, output fields and files are written in and follow the LIS output standards (e.g., ALMA standards). The native SnowModel output files are not currently supported in LIS (e.g., “outputs/wo_assim/snod.gdat”). + + +[[ssec_ldtsteps,B. Outline of LDT Steps: Generating the LIS-SnowModel input parameter file]] +=== B. Outline of LDT Steps: Generating the LIS-SnowModel input parameter file + +[NOTE] +==== + Check out the latest “master” branch from the LISF GitHub page. +==== + +. In the LDT directory, run the configure script and make sure to select the “little-endian” option (“1-little"), if running on a little-endian based operating system. Also note, the SnowModel parameter readers in LIS support parallel reads of the input topo_vege.gdat file, so you could also select “1-dmpar” for the “Parallelism” option. + +Then run the compile script to generate the LDT executable file. + +. Set up your LDT input config file (e.g., ldt.config) to match the run domain of your SnowModel grid that you generated in step A1 (above). You will point the SnowModel-based parameter readers to your single SnowModel input file, e.g., topo_vege.gdat. + +The main points that are specific to SnowModel are: + +* Set the Land Surface Model to “SnowModel”; +* Set the landcover data source to "NALCMS_SM_IGBPNCEP" and point to your topo_vege.gdat file. Make sure all the landcover lat/lon/dimensions match the extent of your SnowModel domain. +* Set your landmask to "NALCMS_SM_IGBPNCEP"; +* Set all your elevation data to "NED_SM" and point to your topo_vege.gdat file (including the curvature data source). Make sure your topograph lat/lon/dimensions match the extent of your SnowModel domain. +* Point your SnowModel input map to your topo_vege.gdat file. + +For more information on all the options supported for SnowModel parameters in LDT, please see the full LDT instructions and documentation: + + link:https://github.com/NASA-LIS/LISF/blob/master/ldt/configs/ldt.config.adoc + +. Run your LDT executable with your ldt.config to generate the model parameter input file used in your LIS-SnowModel run. + + ./LDT ldt.config + + Output file: lis_input.d01.nc. (for example) + + +[[ssec_lissteps,C. Outline of LIS Steps: Running LIS-SnowModel]] +=== C. Outline of LIS Steps: Running LIS-SnowModel + +. In the LIS directory, you will first go into “make” directory and you will do the following: + +a) Open the file: default.cfg (with an editor of choice) + +b) Go to the “SNOWMODEL” section and turn on the model with “True”: + + [SNOWMODEL] +enabled: True + +c) Save and close the file, and return to the main LIS directory. + +d) Run the LIS configure script. Here, you can select all the default options. + +e) Before compiling the LIS code, you will need to include the following Fortran compilation flag: + -mcmodel=medium + to the FFLAGS77 and FFLAGS in the make/configure.lis file. + +f) Once you add that flag, you are now ready to run the LIS compile script and generate the LIS executable file (“LIS”). + +. Set up your LIS input config file (e.g., lis.config) for the SnowModel setup, as a “subLSM” (and not as one of the LSMs). + Main things to pay attention to: ++ +* Land surface model should be set to "none" +* Number of subLSMs set to 1 +* subLSM model set to "SnowModel" +* Look at the options under the DOMAIN SPECIFICATION section. Most will be set to none, but make sure you do have these six options set to LDT, including curvature data source: ++ +[subs="attributes+,-callouts"] +.... +Landmask data source: LDT +Landcover data source: LDT +Elevation data source: LDT +Slope data source: LDT +Aspect data source: LDT +Curvature data source: LDT +.... ++ + +* Check out the SnowModel specific options under “LAND SURFACE MODELS” section header. This is where where you will specify your model timestep and point to your snowmodel.par file, for example. For further details and options, please check out link:https://github.com/NASA-LIS/LISF/blob/master/lis/configs/lis.config.adoc + +* Since SnowModel is a subLSM in LIS, this setup has some model-specific variable names, where we added an “SM” prefix to SWE, SnowDepth, and other fields, as designated in the MODEL_OUTPUT.TBL. This setup was in support of being able to run semi-coupled with other LSMs in LIS, e.g., Noah or Noah-MP (Niu et al., 2011 and Yang et al., 2011), allowing the user to be able to look at both the LSM and this subLSM-based output fields in the LIS output files. Output field specifications for SnowModel can be found here link:https://github.com/NASA-LIS/LISF/blob/master/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc + +. Place your LDT and LIS executables along with your input config files within the same working directory, running LDT first to generate your LIS input parameter file. Then run LIS to generate your LIS-SnowModel based simulation and output. + +. For additional options, please check the lis.config.adoc file within the “configs” directory in your checked out repository or on the LISF GitHub page. You can see the options of running SnowModel coupled with an LSM (currently only setup to run with NoahMP4.0.1 version), or using different forcing and output options. + + +[[ssec_lissteps,References]] +=== References + +Arsenault, K.R., S.V. Kumar, J.V. Geiger, S. Wang, E. Kemp, D.M. Mocko, H.K. Beaudoing, A. Getirana, M. Navari, B. Li, J. Jacob, J. Wegiel, and C.D. Peters-Lidard (2018), The Land surface Data Toolkit (LDT v7.2) – a data fusion environment for land data assimilation systems. Geosci. Model Dev., 11, 3605-3621, doi:10.5194/gmd-11-3605-2018 + +Liston, G., & Sturm, M. (1998), A snow-transport model for complex terrain. Journal of Glaciology, 44(148), 498-516. doi:10.3189/S0022143000002021. + +Liston, G. E., & Elder, K. (2006a), A distributed snow-evolution modeling system (SnowModel). Journal of Hydrometeorology. 7(6): 1259-1276. + +Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for high-resolution terrestrial modeling (MicroMet), Journal of Hydrometeorology, 7(2), 217-234. + +Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology, 53(181), 241-256. doi:10.3189/172756507782202865 + +Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). https://doi.org/10.1002/2017JC013706 + +Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling. Environ. Modelling & Software, 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 + +Kumar, S.V., et al. (2012), Land surface Verification Toolkit (LVT) - a generalized framework for land surface model evaluation. Geosci. Model Dev., 5, 869-886, doi:10.5194/gmd-5-869-2012 + +Niu, G.-Y., et al. (2011), The community Noah land surface model with multiparameterization options (Noah-MP): 1. Model description and evaluation with local-scale measurements. J. Geophys. Res., 116, D12109, doi: 10.1029/2010JD015139. + +Yang, Z.-L., G.-Y. Niu, K. E. Mitchell, F. Chen, M. B. Ek, M. Barlage, K. Manning, D. Niyogi, M. Tewari, & Y. Xia (2011), The Community Noah Land Surface Model with Multi-Parameterization Options (Noah-MP): 2. Evaluation over Global River Basins. J. Geophys. Res., doi:10.1029/2010JD015140. diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par b/lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par new file mode 100755 index 000000000..be931a036 --- /dev/null +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par @@ -0,0 +1,1231 @@ +! snowmodel.par file. +! +! Define any required constants specific to this model run. +! +! The following must be true: +! +! All comment lines start with a ! in the first position. +! +! Blank lines are permitted. +! +! All parameter statements start with the parameter name, followed +! by a space, followed by an =, followed by a space, followed by +! the actual value, with nothing after that. These statements can +! have leading blanks, and must fit within 120 columns, and the +! parameter value cannot be longer than 80 characters (so, for +! example, your paths/file_names to the right of the "=" sign +! cannot be longer than 80 characters). +! +! Also note that all of the input numbers follow standard +! fortran_77 convention where anything starting with the letters +! "i" through "n" are integers, and all others are real numbers. + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! GENERAL MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Number of x and y cells in the computational grid. +!!! (recommended default value: nx = user input required) +!!! (recommended default value: ny = user input required) + nx = 578 + ny = 541 + +! deltax = grid increment in x direction. Meters. +! deltay = grid increment in y direction. Meters. +!!! (recommended default value: deltax = user input required) +!!! (recommended default value: deltay = user input required) + deltax = 100.0 + deltay = 100.0 + +! Location (like UTM, in meters) value of lower-left grid point. +! xmn = value of x coordinate in center of lower left grid cell. +! Meters. +! ymn = value of y coordinate in center of lower left grid cell. +! Meters. +!!! (recommended default value: xmn = user input required) +!!! (recommended default value: ymn = user input required) + xmn = 251450.00 + ymn = 4176850.00 + +! Model time step, dt. Should be the same increment as in the input +! data file. In seconds. For what it is worth, I almost always +! run the model using 3-hour time steps or daily time steps. The +! 3-hour time step resolves the diurnal cycle, and the daily time +! step is 8 times faster. While other time steps can be used, +! there would need to be a good reason to (for example, it has +! been years since I have run the model on a daily time step; +! with no apparent loss in quality). +!!! (recommended default value: dt = user input required) +! One day. +! dt = 86400.0 +! Three hours. +! dt = 10800.0 +! One hour. + dt = 3600.0 + +! Start year of input data file. Four digit year. Integer. +!!! (recommended default value: iyear_init = user input required) + iyear_init = 2009 + +! Start month of input data file. One or two digit month. Integer. +!!! (recommended default value: imonth_init = user input required) + imonth_init = 9 + +! Start day of input data file. One or two digit day. Integer. +!!! (recommended default value: iday_init = user input required) + iday_init = 1 + +! Start hour of input data file. Local time, like in solar time. +! Decimal hour. Each day the clock runs from 0.00 through 23.99. +! Real. +!!! (recommended default value: xhour_init = user input required) + xhour_init = 1.0 +! xhour_init = 3.0 +! xhour_init = 12.0 + +! Number of model iterations defines how many times to process. +!!! (recommended default value: max_iter = user input required) +! max_iter = 1 +! max_iter = 365 +! max_iter = 2920 + max_iter = 8760 + +! MicroMet requires a met input file that has data in a specific +! format (see the MicroMet documentation). For the case of +! inputs from more than a single station, the input met file +! requires an initial number indicating the number of valid +! stations at a given time step. For the case of a single +! station, this number can be dropped (it doesn't have to be +! though). Identify whether to process as a single station +! without the valid station count (isingle_stn_flag = 1), or +! or to process with the count included (for multi stations +! and single stations with the number of stations included; +! isingle_stn_flag = 0). +!!! (recommended default value: isingle_stn_flag = user input +!!! required) + isingle_stn_flag = 0 + +! For the case of isingle_stn_flag = 1, the input file can be a GrADS +! binary file. Identify whether that is the case (= 1, else = 0). +!!! (recommended default value: igrads_metfile = 0) + igrads_metfile = 0 + +! (New) Meteorological forcing option to help specify whether +! forcing fields will be read in from the options selected in +! this snowmodel.par input file (including the forcing file +! read and station or gridcell interpolation), OR that 2-D +! meteorological fields are passed on the Snowmodel model +! grid space into MicroMet and utilize just the topographic +! downscaling operations and routines. +!!! (recommended default value: metforce_opt = 0 ) +!!! (0 = Read in SnowModel forcing specific file and perform +!!! interplation in MicroMet routines) +!!! (1 = Pass in 2D meteorological forcing fields, already +!!! interpolated to the model space grid, to MicroMet) + metforce_opt = 0 + + +! Define the meteorologial input file name. Note that this input +! file has very specific input format requirements (see the +! MicroMet preprocessor). The required met variables are: +! Tair (deg C or K), rh (%), wind speed (m/s), wind direction +! (0-360 True N), and precipitation (mm/time_step). +!!! (recommended default value: met_input_fname = user input required) + met_input_fname = SnowModel_Inputs/uppertuo_100m/mm_3hrly_wys2010-2020.dat + +! The number used as an undefined value for both inputs and outputs. +!!! (recommended default value: undef = -9999.0) + undef = -9999.0 + +! Define whether the topography and vegetation input files will +! be ARC/INFO ascii text (grid) files, or a GrADS binary file +! (ascii = 1.0, GrADS = 0.0). +!!! (recommended default value: ascii_topoveg = 1.0) + ascii_topoveg = 0.0 + +! Define the GrADS topography and vegetation input file name +! (record 1 = topo, record 2 = veg). Note that if you are using +! ascii files, you still cannot comment this line out (it is okay +! for it to point to something that doesn't exist) or you will +! an error message. +!!! (recommended default value: topoveg_fname = xxxxxx) + topoveg_fname = SnowModel_Inputs/topo_vege/topo_vege.gdat + +! For the case of using ascii text topography and vegetation files, +! provide the file names. Note that if you are using a grads +! file, you still cannot comment these two lines out (it is okay +! for it to point to something that doesn't exist) or you will +! an error message. +!!! (recommended default value: topo_ascii_fname = user input required) +!!! (recommended default value: veg_ascii_fname = user input required) + topo_ascii_fname = xxxxxx + veg_ascii_fname = xxxxxx + +! The vegetation types are assumed to range from 1 through 30. The +! last 6 types are available to be user-defined vegetation types +! and vegetation snow-holding depths. The first 24 vegetation +! types, and the associated vegetation snow-holding depths +! (meters), are hard-coded to be: +! +! code description veg_shd example class +! +! 1 coniferous forest 15.00 spruce-fir/taiga/lodgepole forest +! 2 deciduous forest 12.00 aspen forest forest +! 3 mixed forest 14.00 aspen/spruce-fir/low taiga forest +! 4 scattered short-conifer 8.00 pinyon-juniper forest +! 5 clearcut conifer 4.00 stumps and regenerating forest +! +! 6 mesic upland shrub 0.50 deeper soils, less rocky shrub +! 7 xeric upland shrub 0.25 rocky, windblown soils shrub +! 8 playa shrubland 1.00 greasewood, saltbush shrub +! 9 shrub wetland/riparian 1.75 willow along streams shrub +! 10 erect shrub tundra 0.65 arctic shrubland shrub +! 11 low shrub tundra 0.30 low to medium arctic shrubs shrub +! +! 12 grassland rangeland 0.15 graminoids and forbs grass +! 13 subalpine meadow 0.25 meadows below treeline grass +! 14 tundra (non-tussock) 0.15 alpine, high arctic grass +! 15 tundra (tussock) 0.20 graminoid and dwarf shrubs grass +! 16 prostrate shrub tundra 0.10 graminoid dominated grass +! 17 arctic gram. wetland 0.20 grassy wetlands, wet tundra grass +! +! 18 bare 0.01 bare +! +! 19 water/possibly frozen 0.01 water +! 20 permanent snow/glacier 0.01 water +! +! 21 residential/urban 0.01 human +! 22 tall crops 0.40 e.g., corn stubble human +! 23 short crops 0.25 e.g., wheat stubble human +! 24 ocean 0.01 water +! +! 25 user defined (see below) +! 26 user defined (see below) +! 27 user defined (see below) +! 28 user defined (see below) +! 29 user defined (see below) +! 30 user defined (see below) +! +! Define the vegetation snow-holding depths (in meters) for each +! of the user-defined vegetation types. The numbers in the +! list below correspond to the vegetation-type numbers in the +! vegetation-type data array (veg type 25.0 -> veg_shd_25). Note +! that even if these are not used, they cannot be commented out +! or you will get an error message. +!!! (recommended default value: veg_shd_25 = 0.10) +!!! (recommended default value: veg_shd_26 = 0.10) +!!! (recommended default value: veg_shd_27 = 0.10) +!!! (recommended default value: veg_shd_28 = 0.10) +!!! (recommended default value: veg_shd_29 = 0.10) +!!! (recommended default value: veg_shd_30 = 0.10) + veg_shd_25 = 0.10 + veg_shd_26 = 0.10 + veg_shd_27 = 0.10 + veg_shd_28 = 0.10 + veg_shd_29 = 0.10 + veg_shd_30 = 0.10 + +! Define whether the vegetation will be constant or defined by the +! topography/vegetation input file name (0.0 means use the file, +! 1.0 or greater means use a constant vegetation type equal to +! the number that is used). This will define the associated +! veg_shd that will be used. The reason you might use a constant +! vegetation type is to avoid generating a veg-distribution file. +!!! (recommended default value: const_veg_flag = 0.0) +! const_veg_flag = 12.0 + const_veg_flag = 0.0 + +! For the case where you have vegetation height data, and want to +! use that instead of the tables above, you must also provide a +! file that defines the vegetation height (m) of each grid cell. +! iveg_ht_flag = 0 means the file is not provided and the required +! array will be generated by filling it with the values listed in +! the above vegetation summary. iveg_ht_flag = -1 means the data +! file is a grads binary file with the name veg_ht.gdat. +! iveg_ht_flag = 1 means the data file is an ascii text file with +! the same format that ascii topo and veg files would have and +! with a name of veg_ht.asc. Note that this .asc file is +! y-reversed (see ascii topo/veg notes), and the .gdat file is +! not. It is assumed that the file, if provided, is located in +! the same directory as the topo and vege files listed above (in +! topoveg_fname or topo_ascii_fname and veg_ascii_fname). Note +! that this height information is primarily used as the vegetation +! snow-holding depth, thus the model is expecting average +! vegetation heights for each grid cell, not maximum heights. +!!! (recommended default value: iveg_ht_flag = 0) + iveg_ht_flag = 0 + +! The latitude of domain center (decimal degrees). This only needs +! to be approximate, since it is used to define some of the solar +! radiation calculations. +!!! (recommended default value: xlat = user input required) + xlat = 40.0 + +! For the case where your domain spans enough latitude that there +! is significant variation in solar radiation from the top to +! the bottom of the domain, you must also provide a file that +! defines the latitude (in decimal degrees) of the center of +! each grid cell. lat_solar_flag = 0 means the file is not +! provided and the required array will be generated by filling +! it with the constant xlat value listed above. lat_solar_flag +! = -1 means the data file is a grads binary file with the name +! grid_lat.gdat. lat_solar_flag = 1 means the data file is an +! ascii text file with the same format that ascii topo and veg +! files would have and with a name of grid_lat.asc. Note that +! the .gdat and .asc files are y-reversed (see ascii topo/veg +! notes). It is assumed that the file, if provided, is located +! in an 'extra_met/' directory off of the main model directory. +!!! (recommended default value: lat_solar_flag = 0) + lat_solar_flag = 0 + +! For the case where your domain spans enough longitude that there +! is significant variation in solar radiation from the side to +! the side of the domain, you must also provide a file that +! defines the lonitude (in decimal degrees) of the center of +! each grid cell. In this case it also no longer makes sense +! to be running the model in local time, and UTC (or GMT) time +! is required. UTC_flag = 0.0 means the the model will be run +! in local time. UTC_flag = -1.0 means the longitude data file +! is a grads binary file with the name grid_lon.gdat. UTC_flag +! = 1 means the longitude data file is an ascii text file with +! the same format that ascii topo and veg files would have and +! with a name of grid_lon.asc. Note that the .gdat and .asc +! files are y-reversed from each other (see ascii topo/veg +! notes). It is assumed that the file, if provided, is located +! in an 'extra_met/' directory off of the main model directory. +! Note that if UTC_flag is non-zero, lat_solar_flag should +! probably also be non-zero. +!!! (recommended default value: UTC_flag = 0.0) + UTC_flag = 0.0 + +! Define which models that are going to run. A value of 1.0 means +! that you want to run the model (0.0 means don't run it). +! Currently the model is only configured to run the following +! combinations (micromet), (micromet, enbal), (micromet, enbal, +! snowpack), (micromet, snowtran), or (micromet, enbal, snowpack, +! snowtran). +!!! (recommended default value: run_micromet = user input required) +!!! (recommended default value: run_enbal = user input required) +!!! (recommended default value: run_snowpack = user input required) +!!! (recommended default value: run_snowtran = user input required) + run_micromet = 1.0 + run_enbal = 1.0 + run_snowpack = 1.0 + run_snowtran = 1.0 + +! Define whether you are doing a standard model simulation, or a +! DATA ASSIMILATION RUN where you are going to assimilate +! observed snow water equivalent observations as part of the +! model integration. A data assimilation run can be used to +! correct precipitation inputs and/or melt rates to force the +! model towards your observed swe distributions. For a standard +! simulation, use irun_data_assim = 0, for a data assimilation +! run, use irun_data_assim = 1. Note that irun_data_assim = 1 +! requires swe data and some extra input files. See the +! dataassim_user.f subroutine for details (read the comments in +! that subroutine to learn how to set up a data assimilation +! run). If you are using this feature, you will also need to +! run the model with "print_user = 1.0" defined below in this +! .par file; there are three output files/variables that you +! must turn on (as noted below) to do a data assimilation run. +! Data assimilation works for single-layer runs and multi-layer +! runs (multilayer_snowpack = 1). The snow water equivalent +! assimilation input file must be placed in this directory and +! be called: /sm/swe_assim/swe_obs.dat. +!!! (recommended default value: irun_data_assim = user input +!!! required) + irun_data_assim = 0 +! irun_data_assim = 1 + +! In addition to the SWE data assimilation described above, +! you can also assimilate snow density observations as a +! post-processing step at the end of the model run. See the +! /post_process/density_assim/ directory for additional +! details. Assimilating both SWE and density will help +! reproduce the observed SWE, depth, and density (all three, +! not just one of them). + +! Define whether want to implement the history restart option. +! This creates periodic output files that allow you to restart +! the simulation from somewhere other than the beginning. All +! of the required data arrays are saved to a grads file that is +! read back in when the simulation is restarted. The new +! simulation starts at the history restart iteration, with the +! initial conditions defined by the saved data arrays. The +! new simulation starts in the micromet file where the original +! simulation ended. This is also true of the output files, +! if the run has been set up to write continuously to a given +! output file. This option also assumes that you have not made +! any changes to the model setup; it does no error checking. +! ihrestart_flag = -2 turns this option off, ihrestart_flag = -1 +! does the restart saves, and ihrestart_flag >= 0 runs a history +! restart where the number defines the restart iteration (e.g., +! ihrestart = 720 will set iteration 720 as the intitial +! condition for the start of the new simulation. For the case +! where ihrestart_flag = 0, and i_dataassim_loop <= -1, the +! run will start at the begining of the second data assimilation +! loop. NOTE: HISTORY RESTARTS NO LONGER WORK; THIS WILL BE +! CORRECTED IN THE COMING MONTHS. +!!! (recommended default value: ihrestart_flag = -2) + ihrestart_flag = -2 +! ihrestart_flag = -1 +! ihrestart_flag = 3444 +! ihrestart_flag = 0 + +! For the case where you are running a history restart, define +! whether you want to restart the run during a standard run or +! the first loop of a data assimilation model run +! (i_dataassim_loop = 1) or during the second loop of a data +! assimilation run (i_dataassim_loop < 0). The value of this +! negative number is used to define how many obervation dates +! you have in your data assimilation run (e.g., -3 would mean +! you have 3 observation dates and nobs_dates = 3 in +! dataassim_user.f). Also note that to correctly run the history +! restart function for the case of a data assimilation run, you +! need to first set i_corr_factor = 0 and save a history restart +! at the end of that run before going on to the second half of +! the assimilation run. +!!! (recommended default value: i_dataassim_loop = 1) + i_dataassim_loop = 1 +! i_dataassim_loop = -1 + +! If ihrestart_flag = -1, then define how often the restart +! files are generated. This is in iteration units (e.g., every +! 30 days for the model running at hourly time steps would be +! ihrestart_inc = 720). The history restart files will be +! placed in an 'hrestart/' directory off of the main model +! directory. In addition to this time increment, if the +! ihrestart_flag = -1, the last model iteration is always saved +! (so if you just want to save the last iteration, just set +! ihrestart_inc to a number bigger than your maximum iteration). +! Note that if you want to do history restarts with data +! assimilation this increment must be evenly divisible into +! the maximum interation; in other words, the simulation must +! at least do a write at the end of the first data assimilation +! loop. +!!! (recommended default value: ihrestart_inc = 0) + ihrestart_inc = 0 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! MICROMET MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Define which fields you want to process/distribute. 1 = do it, +! 0 = don't do it. As an example, if you are running SnowTran-3D +! with no melting, you don't need solar radiation. Also, MicroMet +! provides the ability to to read in an alternate wind dataset +! that has been previously generated with another program, like +! winds from NUATMOS. To do that set the flag to -1. See +! i_wind_flag = -1 in the code for an example of how to do this. +!!! (recommended default value: i_tair_flag = 1) +!!! (recommended default value: i_rh_flag = 1) +!!! (recommended default value: i_wind_flag = 1) +!!! (recommended default value: i_solar_flag = 1) +!!! (recommended default value: i_longwave_flag = 1) +!!! (recommended default value: i_prec_flag = 1) + i_tair_flag = 1 + i_rh_flag = 1 + i_wind_flag = 1 + i_solar_flag = 1 + i_longwave_flag = 1 + i_prec_flag = 1 + +! Force the model to determine a value for every grid cell (= 1), or +! just define values for some specified "radius of influence" (= 0). +!!! (recommended default value: ifill = 1) + ifill = 1 + +! Let the model determine an appropriate "radius of influence" (= 0), +! or define the "radius of influence" you want the model to use (= 1). +! 1 = use obs interval below, 0 = use model generated interval. +!!! (recommended default value: iobsint = 0) + iobsint = 0 + +! The "radius of influence" or "observation interval" you want the +! model to use for the interpolation. In units of deltax, deltay. +!!! (recommended default value: dn = 1.0) + dn = 1.0 + +! The barnes station interpolation can be done two different ways: +! First, barnes_oi does the interpolation by processing all of +! the available station data for each model grid cell. +! Second, barnes_oi_ij does the interpolation by processing only +! the "n_stns_used" number of stations for each model grid cell. +! For small domains, with relatively few met stations (100's), +! the first way is best. For large domains (like the +! United States, Globe, Pan-Arctic, North America, Greenland) +! and many met stations (like 1000's), the second approach is the +! most efficient. But, the second approach carries the following +! restrictions: 1) there can be no missing data for the fields of +! interest; 2) there can be no missing stations (all stations +! must exist throughout the simulation period); and 3) the +! station met file must list the stations in the same order for +! all time steps. This second method works well for regridding +! atmospheric analyses/model datasets. Also, the MicroMet +! preprocessor can be used to fill in missing data segments. +! The second option now has the option to calculate the nearest +! "stations" at every time step. This is useful if you have +! stations (instead of just reanalyis grid points) in your model +! domain. It works with either line (snowmodel_line_flag = 1.0) +! or rectangular domain (snowmodel_line_flag = 0.0) configurations +! (see below). Use barnes_lg_domain = 0.0 for the first method, +! barnes_lg_domain = 1.0 for the second method with all of the +! restrictions listed above, and barnes_lg_domain = 2.0 for the +! second method with stations that come and go with valid data +! during the model simulation. +!!! (recommended default value: barnes_lg_domain = 0.0) + barnes_lg_domain = 1.0 + +! For the case where barnes_lg_domain = 1.0, define the number +! of nearest stations to be used in the interpolation (9 or +! less). If barnes_lg_domain = 0.0, n_stns_used is not used, but +! n_stns_used still needs to have some value. Note that these +! station interpolations are very costly, and thus, very +! sensitive to the value of n_stns_used. So, it needs to be +! big enough to create smooth fields, but not so big as to +! waste CPU time (the CPU cost is something like nstns^2). Using +! a test run as an example, 4 stns = 33 mins, 5 stns = 40 mins, +! 6 stns = 49 mins, and 9 stns = 84 mins. In general, a value +! of 4 stns seems to be adequate, but if you see interpolation +! artifacts in our spatial fields, you may want to use a higher +! value. +!!! (recommended default value: n_stns_used = 4) + n_stns_used = 4 + +! The code has also been configured to run the model with all of +! grid cells of interest concatenated into a single line of grid +! cells. This is useful when large parts of a rectangular domain +! are not of interest in your simulation, for example, when you +! want to simulate snow processes over all of the glaciers in +! the Northern Hemisphere or all of the ice-free grid cells in +! Greenland. Because the grid cells in this configuration are +! not realistically connected on the x-y grid anymore, the blowing +! snow model (SnowTran-3D) cannot be used in this configuration. +! Also, the implementation assumes that you are running with +! barnes_lg_domain = 1.0 (see the notes above). To define the +! relationship between this line of grid cells and the original +! rectangular x-y domain, an indexing file is required. This +! is assumed to be called snowmodel_line_pts.dat, and to be +! located in the /extra_met/ directory. This data file has five +! columns: 1) a grid cell counter, 2) and 3) the i and j +! locations within the rectangular grid, and 4) and 5) the x and +! y SnowModel coordinates within the rectangular version of the +! domain. The number of rows in this file equals the number of +! grid cells in the line of grid cells. In addition to the +! requirements listed above, several preprocessing steps are +! required to generate the appropriate indexing for this +! implementation. These steps are highlighted in the +! /readme_docs/readme_snowmodel_line.txt file. 1.0 = run with a +! line domain, 0.0 = run with a standard rectangular domain. +!!! (recommended default value: snowmodel_line_flag = 0.0) + snowmodel_line_flag = 0.0 + +! Define whether you want to check the met input file to make sure +! it contains (some) valid data for every time step. While this +! is generally a good idea to do, if you are running, for example, +! the model with 30 years of reanalysis data, it can take a very +! long time and may not be necessary. 1.0 = do the check, 0.0 = +! skip the check. +!!! (recommended default value: check_met_data = 1.0) + check_met_data = 1.0 + +! The curvature is used as part of the wind model. Define a length +! scale that the curvature calculation will be performed on. This +! has units of meters, and should be approximately one-half the +! wavelength of the topographic features within the domain. +!!! (recommended default value: curve_len_scale = 500.0) + curve_len_scale = 300.0 + +! The curvature and wind_slope values range between -0.5 and +0.5. +! Valid slopewt and curvewt values are between 0 and 1, with +! values of 0.5 giving approximately equal weight to slope and +! curvature. I suggest that slopewt and curvewt be set such +! that slopewt + curvewt = 1.0. This will limit the total +! wind weight to between 0.5 and 1.5 (but this is not required). +!!! (recommended default value: slopewt = 0.58) +!!! (recommended default value: curvewt = 0.42) + slopewt = 0.58 + curvewt = 0.42 +! slopewt = 0.25 +! curvewt = 0.75 + +! Impose a second, larger length scale, curvature affect on the +! snow distribution. Turning this flag on (= 1.0) will reduce the +! Utau_t threshold in regions of positive curvature in big +! mountains. The net effect of this is to increase the wind- +! related snow erosion on high, steep, mountain slopes. If = 1.0 +! then the model will look in an 'extra_met/' directory off of +! the main model directory for a .gdat file of the weighing +! distribution (that has been created in preparation for the +! model run using the external program called make_lg_curve_wt.f). +! Turning this flag off (= 0.0) produces the default model and +! snow resistance to wind shear. +!!! (recommended default value: curve_lg_scale_flag = 0.0) + curve_lg_scale_flag = 0.0 + +! Avoid problems of zero (low) winds (for example, turbulence +! theory, log wind profile, etc., says that we must have some +! wind. Thus, some equations blow up when the wind speed gets +! very small). This number defines the value that any wind speed +! below this gets set to. +!!! (recommended default value: windspd_min = 0.1) + windspd_min = 0.1 + +! Define whether the model is to use the default monthly lapse +! rates (= 0) or user supplied monthly lapse rates (= 1). To use +! user supplied lapse rates, you have to edit the user lapse rate +! data array in micromet_code.f (subroutine get_lapse_rates). +! Note that this implementation currently only defines +! average-monthly lapse rates. +!!! (recommended default value: lapse_rate_user_flag = 0) + lapse_rate_user_flag = 0 + +! Define whether the precipitation adjustment factor, with units of +! km^-1 (kind of a precipitation lapse rate, used to adjust the +! precipitation for locations above and below the precipitation +! observing station(s)), is to use the default monthly lapse +! rates (= 0) or user supplied monthly lapse rates (= 1). To use +! user supplied lapse rates, you have to edit the user lapse rate +! data array in micromet_code.f (subroutine get_lapse_rates). +!!! (recommended default value: iprecip_lapse_rate_user_flag = 0) + iprecip_lapse_rate_user_flag = 0 + +! There are two different precipitation-increase-with-elevation +! schemes implemented in MicroMet. The first is described in +! Liston and Elder 2006; the original MicroMet paper. The +! second is described in the van Pelt et al. (2006) Svalbard +! paper. I used the original in everything except Svalbard +! simulations, but it is an option to expore. The parameter +! above, iprecip_lapse_rate_user_flag, only affects the original +! scheme. iprecip_scheme = 1 is the original scheme, and = 2 +! is the van Pelt scheme. +!!! (recommended default value: iprecip_scheme = 1) + iprecip_scheme = 1 + +! Define how the rain-snow fraction of the water-equivalent +! precipitation forcing is calculated. snowfall_frac = 1.0 +! uses Auer (1974) where rain occurs at air temperatures above +! +2 C and snow occurs below that threshold; snowfall_frac = +! 2.0 uses Dai (2008); and snowfall_frac = 3.0 uses Liston's +! linear fit to Dai's curve. Note that what options 2.0 and 3.0 +! are doing is causing a mix of rain and snow to occur during +! the time step when air temperatures are around freezing. +!!! (recommended default value: snowfall_frac = 3.0) +! snowfall_frac = 1.0 + snowfall_frac = 3.0 + +! The model can also impose a wind speed increase with elevation, +! called here the "wind_lapse_rate". If wind_lapse_rate = 0.0, +! then nothing is done. Or you can define a wind_lapse_rate to +! equal the wind multiplier per km. So, for example, a rate = 1.5 +! would give wind speeds at 1-km elevation above the wind speed +! observations that are 1.5 times those observations. Where this +! is useful is when you have all of your met stations in the +! valley bottoms, but you want higher wind speeds on the tops of +! the higher ridges. The elevation correction formulation follows +! that of precipitation (although there is no seasonal variation +! implemented). So this will have the effect of also making the +! wind speeds at lower elevations than the met stations less than +! the met station values. +!!! (recommended default value: wind_lapse_rate = 0.0) + wind_lapse_rate = 0.0 + +! Define whether you want the model to calculate, use, and output +! sub-forest-canopy windspeed, incoming solar and longwave +! radiation (= 1.0), or above canopy values (= 0.0). +!!! (recommended default value: calc_subcanopy_met = 1.0) + calc_subcanopy_met = 1.0 + +! Define the canopy gap fraction (0-1). This parameter accounts +! for solar radiation reaching the snow surface below the canopy, +! beyond that defined by the canopy transmissivity calculation. +! In effect, it allows additional solar radiation to penetrate +! the canopy (e.g., through gaps in the forest), thus inceasing +! melt rates, etc. A gap_frac = 0.0 produces the sub-canopy +! solar radiation using the default transmissivity calculation, +! a gap_frac = 1.0 (all gaps) produces sub_canopy radiation equal +! to the top-of-canopy radiation. If you want the snow in the +! forest to melt faster, increasing this value will do it. +!!! (recommended default value: gap_frac = 0.2) + gap_frac = 0.2 + +! To handle the case, for example, of a met station located in +! an inversion layer recording high relative humidity, and the +! model producing anomolously high cloud-cover fractions, the +! cloud_frac_factor can be used to decrease the simulated cloud +! fraction. This number is multiplied by the calculated cloud +! fraction. For example, a cloud_frac_factor = 1.0 produces the +! simulated cloud fraction, a cloud_frac_factor = 0.5 produces +! the half the simulated cloud fraction, and a cloud_frac_factor +! = 0.0 forces the simulated cloud fraction to be zero. +!!! (recommended default value: cloud_frac_factor = 1.0) + cloud_frac_factor = 1.0 + +! Define whether the simulation will assimilate shortwave radiation +! observations (no = 0.0, yes = 1.0). If yes, the model assumes +! there is a shortwave radation station data file, called +! shortwave.dat, in an 'extra_met/' directory off of the main +! model directory. See the micromet code for file format details. +!!! (recommended default value: use_shortwave_obs = 0.0) + use_shortwave_obs = 0.0 + +! Define whether the simulation will assimilate longwave radiation +! observations (no = 0.0, yes = 1.0). If yes, the model assumes +! there is a longwave radation station data file, called +! longwave.dat, in an 'extra_met/' directory off of the main model +! directory. See the micromet code for file format details. +!!! (recommended default value: use_longwave_obs = 0.0) + use_longwave_obs = 0.0 + +! Define whether the simulation will assimilate surface pressure +! observations (no = 0.0, yes = 1.0). If yes, the model assumes +! there is a surface pressure station data file, called +! sfc_pressure.dat, in an 'extra_met/' directory off of the main +! model directory. See the micromet code for file format details. +!!! (recommended default value: use_sfc_pressure_obs = 0.0) + use_sfc_pressure_obs = 0.0 + +! Define whether you want to use a user-defined precipitation +! correction factor. This can be either a 2-D grads file (=1.0), +! an ascii text file (=2.0), or a scalar (=3.0). Or it can be +! turned off by setting cf_precip_flag = 0.0. The file that +! contains the cf data must be in the /snowmodel/precip_cf/ +! directory, and they are assumed to be called: cf_precip.gdat, +! cf_precip.asc, and cf_precip.dat, for 1.0, 2.0, and 3.0, +! respectively. +!!! (recommended default value: cf_precip_flag = 0.0) + cf_precip_flag = 0.0 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! SNOWTRAN-3D MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Define whether the threshold surface shear velocity will be +! constant during the simulation (Utau_t_flag = 0.0), or whether +! it will evolve as a funtion of air temperature and wind speed +! (Utau_t_flag = 1.0). +!!! (recommended default value: Utau_t_flag = 0.0) + Utau_t_flag = 0.0 +! Utau_t_flag = 1.0 + +! For the case of Utau_t_flag = 0.0, define what the threshold +! surface shear velocity (m/s) will be during the simulation. +!!! (recommended default value: Utau_t_const = 0.25) + Utau_t_const = 0.25 + +! Define whether you want to apply the Tabler subgrid algorithm. +! Flag = 0.0 is the original model (no subgrid redistribution, as +! in the original model), flag = 1.0 uses Tabler (1975) to define +! equilibrium profiles for topographic drift catchments. Note +! that the model has not been tested for grid increments less than +! 1.0 m deltax and deltay. Also note that this subgrid algorithm +! is not really appropriate for grid increments greater than +! 30.0 m. There is also a computational penalty for running with +! this turned on: the simulations can take as much as 35% longer +! when subgrid_flag = 1.0 (but it does produce more realistic +! drift profiles at the higher resolutions). Note that as of June +! 2018 this version of subgrid_flag = 1.0 is different than that in +! previous years/versions. The old version has been replaced and +! is no longer supported. If subgrid_flag = 1.0, you need to set +! topoflag = 1.0. +!!! (recommended default value: subgrid_flag = 0.0 for resolutions +! >= 30 m, subgrid_flag = 1.0 for resolutions < 30 m) + subgrid_flag = 0.0 +! subgrid_flag = 1.0 + +! For subgrid_flag = 1.0, you can either define the dominant wind +! direction (one of the 8 primary wind directions) you want +! Tabler surfaces and drifts to be generated for. In this case, +! the blowing snow transport direction is constant during the +! entire simulation. Or you can let the code calculate the +! direction of the dominant blowing snow flux, and use that. In +! this case, the direction may be different at each time step, +! depending on the wind directions and transport fluxes. This +! second option is obtained by setting the tabler_dir = to a +! non-zero, negative wind direction (the number can't be -0.0). +! The second approach appears to be the best option for most +! simulations. Also note that the resulting direction is +! constant over the entire simulation domain; another code +! change will be required to relax this assumption. +!!! (recommended default value: user input required, or -270.0) + tabler_dir = -270.0 +! tabler_dir = 0.0 +! tabler_dir = 45.0 +! tabler_dir = 90.0 +! tabler_dir = 135.0 +! tabler_dir = 180.0 +! tabler_dir = 225.0 +! tabler_dir = 270.0 +! tabler_dir = 315.0 + +! You can make adjustments to the slopes of the Tabler surfaces +! using the 'slope_adjust' parameter. This factor is multiplied by +! the calculated Tabler equilibrium drift surface slope to get the +! simulated slope. So, for example, if you want the simulated +! slope to be 50% of what Tabler calculated, use a value of 0.5; a +! value of 1.5 would give half again steeper than Tabler's original +! model. +!!! (recommended default value: slope_adjust = 1.0) + slope_adjust = 1.0 + +! Define whether you want two-layer accounting for soft (movable) +! and hard (unmovable) layers (flag = 0.0 = off, flag = 1.0 = on). +!!! (recommended default value: twolayer_flag = 1.0) +! twolayer_flag = 0.0 + twolayer_flag = 1.0 + +! Define whether you want the upwind boundaries to have zero +! incoming transport flux, or the equilibrium transport flux. +! bc_flag = 0.0 corresponds to a zero flux, and bc_flag = 1.0 +! corresponds to the equilibrium flux. +!!! (recommended default value: bc_flag = 0.0) + bc_flag = 0.0 + +! Input the height of the wind and rh observations. The model does +! not need an air temperature height and is not very sensitive to +! the relative humidity observation height. +!!! (recommended default value: ht_windobs = user input required) +!!! (recommended default value: ht_rhobs = user input required) + ht_windobs = 10.0 + ht_rhobs = 10.0 + +! Snow density used in SnowTran-3D if you are running SnowTran-3D +! without SnowPack. This is required because without SnowPack, +! SnowTran-3D does not know what the snow density is. It should +! be defined to be a typical snow density for your simulation +! domain. This is also used to initialize the SWE if you have +! set snow_d_init_const (see below) to be non-zero. +!!! (recommended default value: ro_snow = 300.0) + ro_snow = 300.0 + +! Define the initial snow-depth distributions. +!!! (recommended default value: snow_d_init_const = 0.0) + snow_d_init_const = 0.0 + +! Define whether the simulation will use a surface topography +! equal to ground topography (topoflag = 0.0), or equal to the +! snow surface (topoflag = 1.0). +!!! (recommended default value: topoflag = 1.0) + topoflag = 1.0 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! ENBAL-2D MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Identify whether the surface energy balance calculation for +! this simulation will include a non-zero conduction term +! (icond_flag = 0 = no conduction, 1 = conduction). Note that +! icond_flag = 1 requires running the multi-layer snowpack model +! with at least 2 snow layers. +!!! (recommended default value: icond_flag = 0) + icond_flag = 0 +! icond_flag = 1 + +! Define the albedo for a melting snowcover under the forest +! canopy. This allows the user to control, to some degree, the +! melt rates in the forests. Note that adjusting the gap-frac +! parameter is also an effective way to do this. The non-melting +! snow albedo is set to 0.8 in the code. +!!! (recommended default value: albedo_snow_forest = 0.45) + albedo_snow_forest = 0.45 + +! Define the albedo for a melting snowcover in non-forested areas. +! This allows the user to control, to some degree, the melt +! rates in non-forested areas. The non-melting snow albedo is +! set to 0.8 in the code. +!!! (recommended default value: albedo_snow_clearing = 0.60) + albedo_snow_clearing = 0.60 + +! Define the albedo for a glacier surface (dry and melting). +!!! (recommended default value: albedo_glacier = 0.40) + albedo_glacier = 0.40 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! SNOWPACK MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Define whether static-surface (non-blowing snow) sublimation will +! be included in the model calculations (sfc_sublim_flag = 1.0). +! To turn this off, set sfc_sublim_flag = 0.0. If sfc_sublim_flag +! is turned on, the latent heat flux (Qe) calculated in ENBAL is +! used to add/remove snow from the snowpack. +!!! (recommended default value: sfc_sublim_flag = 1.0) + sfc_sublim_flag = 1.0 + +! Define whether this is going to be a multi-layer snowpack run +! (multilayer_snowpack = 1, else 0). This option does not work +! with the history restart or data assimilation functions. +!!! (recommended default value: multilayer_snowpack = 0) +! multilayer_snowpack = 1 + multilayer_snowpack = 0 + +! Define the time since last snowfall threshold, in hours. This +! sets how long you have to go without snow precipitation to +! start a new snow layer in the multi-layer snowpack model. +! Periods with zero snowfall at time gaps less than this threshold +! do not create a new snow layer. To force a single layer using +! this parameter, set tsls_threshold >= the number of hours in +! the simulation. Note the equation below can be used to +! calculate this number. +! tsls_threshold = dt * real(max_iter) / 3600.0 +!!! (recommended default value: tsls_threshold = 24.0) +! tsls_threshold = 1.0 + tsls_threshold = 24.0 +! tsls_threshold = 12.0 +! tsls_threshold = 144.0 +! tsls_threshold = 8000.0 + +! Define the maximum number of snow layers you want to allow in +! the multi-layer snowpack model. Note that nz_max in the +! snowmodel.inc file must be at least 1 greater than max_layers. +! So, if you want to run the multi-layer snowpack model with a +! single snow layer, set nz_max = 2. If you want to run the +! original single-layer snowpack model, you can set nz_max = 1 in +! snowmodel.inc. +!!! (recommended default value: max_layers = 6) +! max_layers = 12 +! max_layers = 6 + max_layers = 1 + +! Define the minimum snow layer thickness (m) for the multi-layer +! snowpack model. 0.001 is an appropriate number. It is also +! okay to set this to be 0.0 which will allow the tracking of +! thin layers in the simulation. +!!! (recommended default value: dz_snow_min = 0.001) + dz_snow_min = 0.001 +! dz_snow_min = 0.01 +! dz_snow_min = 0.0 + +! For multi-year simulations, sometimes it is desirable to zero +! out the snow cover arrays on a certain summer date. For +! example, to prevent glaciers from forming. Input that date +! here, in the form: mmddhh. I recommend setting this to be the +! last time step of the year in a multi-year simulation. For a +! simulation that starts on YYYY 09 01, with a 3-hour time step, +! 090100 is the last time step of the year (the first one is +! 090103). For the same simulation with a 1-day time step, +! 083112 is the last time step of the year (the first one is +! 090112). Set this to 999999 if you would like to disable this +! feature. +!!! (recommended default value: izero_snow_date = 090100 or 083112, +!!! depending on the model configuration details) +! izero_snow_date = 999999 + izero_snow_date = 090100 +! izero_snow_date = 083112 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! SEAICE MODEL SETUP +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! Define whether you want to simulate snow on sea ice. A land-only +! run (seaice_run = 0.0) means any snow on ocean grid cells +! (vegtype.eq.24.0) will be set to zero. A sea-ice-only run +! (seaice_run = 1.0) means any snow on land grid cells +! (vegtype.ne.24.0) will be set to zero. For a combined land +! and sea-ice run, seaice_run = 2.0. For a sea-ice-only run +! with incremental remapping to handle the ice motion, seaice_run +! = 3.0; this option is no longer supported (see the notes in: +! /sm/misc_programs/Eulerian_seaice_incremental_remapper/ if you +! want to reimplement and run this option). seaice_run = 4.0 is +! a Lagrangian parcel-tracking sea-ice only simulation (no land) +! where the following is required: barnes_lg_domain = 1.0, +! n_stns_used = 1, and snowmodel_line_flag = 1.0. +!!! (recommended default value: seaice_run = 0.0) +! seaice_run = 4.0 + seaice_run = 0.0 + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!! PRINTING OUTPUT FILES +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +! There are two kinds of GrADS .gdat output data files that the +! model is set up to automatically write out as part of the model +! simulation (see descriptions [1] and [2] below). GrADS +! control (.ctl), or data description, files are automatically +! created for any of the output files you elect to create. These +! .ctl files describe what is in the .gdat files and allow you to +! plot the outputs with GrADS (see: http://cola.gmu.edu/grads/). +! All of the .ctl files are written to the "ctl_files" directory, +! and they point to the .gdat file locations you define below. +! Note that any paths or directories that you list here must +! exist on your workstation (you have to make those directories +! before you start the model run). + +! The output file options are: + +![1] Individual data files for each sub-model (MicroMet, EnBal, +! SnowPack, SnowTran-3D, etc.). These typically have several +! output variables in them, so the files can be huge. In +! addition, these can only be written out at every model time +! step (e.g., you cannot write out daily data when you are +! running the model on hourly or 3-hourly time steps; to do +! that requires you to use the second output option described +! below). Also note that if you are saving with this option +! and running the data assimilation routines, during the +! second assimilation loop the code will write over the data +! that where written out in the first loop (so the first loop's +! data will be lost). I only use this output option for model +! development applications where I want to look at many +! interrelated variables and where I am typically +! troubleshooting problems with my model runs. I really do +! not recommend this output option except for special +! situations; maybe the multi-layer output file is an +! exception to this general rule, because output option 2) +! described below is not set up to handle multi-layer output +! variables. + +! For these files you have to define whether you want the data +! written out (print_name = 1.0) or if you do not want these +! files written out (print_name = 0.0), and the name of the +! output file. + +! MicroMet output file. +!!! (recommended default value: print_micromet = 0.0) +!!! (recommended default value: micromet_output_fname = +!!! outputs/micromet.gdat) + print_micromet = 0.0 + micromet_output_fname = outputs/micromet.gdat + +! SnowTran-3D output file. +!!! (recommended default value: print_snowtran = 0.0) +!!! (recommended default value: snowtran_output_fname = +!!! outputs/snowtran.gdat) + print_snowtran = 0.0 + snowtran_output_fname = outputs/snowtran.gdat + +! SnowTran-3D TABLER-SURFACE output files. There are two +! additional Tabler surface output files that can be output. + +! The first one is Tabler equilibrium surface distributions for +! each of the 8 Tabler directions (0, 45, 90, etc.), for the +! snow-free topographic distribution. These data distributions +! are saved with Tabler_1_flag = 1.0, and they are not saved +! with Tabler_1_flag = 0.0. You also have to define the path +! or directory you want this file saved in. +!!! (recommended default value: Tabler_1_flag = user input +!!! required) +!!! (recommended default value: tabler_sfc_path_name = outputs/) + Tabler_1_flag = 0.0 + tabler_sfc_path_name = outputs/ + +! The second one saves the Tabler equilibrium surface that was +! used at each time step. The file will be located according +! to "output_path_wo_assim" and "output_path_wi_assim" defined +! below, and the file name will be "tabler_sfcs_iter.gdat". So +! all that is required here is to define whether you want the +! data saved or not. Tabler_1_flag = 0.0 means don't save the +! data, and Tabler_1_flag = 1.0 means the data will be saved. +!!! (recommended default value: Tabler_1_flag = user input +!!! required) + Tabler_2_flag = 0.0 + +! EnBal output file. +!!! (recommended default value: print_enbal = 0.0) +!!! (recommended default value: enbal_output_fname = +!!! outputs/enbal.gdat) + print_enbal = 0.0 + enbal_output_fname = outputs/enbal.gdat + +! SnowPack output file. +!!! (recommended default value: print_snowpack = 0.0) +!!! (recommended default value: snowpack_output_fname = +!!! outputs/snowpack.gdat) + print_snowpack = 0.0 + snowpack_output_fname = outputs/snowpack.gdat + +! MultiLayer output file (s). print_multilayer = 1.0 +! prints a suite of multilayer variables to a single +! file called multilayer.gdat to the directory defined +! in 'multilayer_output_fname'. print_multilayer = 2.0 +! prints each of these variables to their own file +! located in the directories called 'output_path_wo_assim' +! and 'output_path_wi_assim' defined below. See +! snowmodel_main.f for a listing of the output variables. +!!! (recommended default value: print_multilayer = 0.0) +!!! (recommended default value: multilayer_output_fname = +!!! outputs/multilayer.gdat) + print_multilayer = 0.0 + multilayer_output_fname = outputs/multilayer.gdat + +![2] Individual data files for individual variables. These data +! outputs are controlled in the outputs_user.f subroutine. +! In the lines below you can define which of the most common +! variables you want to write out, and you can define the +! write interval in time-step units (e.g., for a 3-hour dt, +! a write interval of 8 time steps (print_inc = 8.0) will +! give you a data write at the end of each day). Note that +! this code will write the average, sum, or the instantanious +! value, depending on the variable of interest (see below). +! You have to define whether you want these kinds of data +! files to be written (print_user = 1.0) or not (print_user +! = 0.0). And you have to define the directory they will be +! written to. Two directories are required: one is for non- +! data assimilation outputs, and one is for data assimilation +! outputs. + +! Define whether you want to write individual files for each +! variable. +!!! (recommended default value: print_user = 1.0) + print_user = 1.0 + +! Define the print increment, in time-step units. +!!! (recommended default value: print_inc = 1.0 or 8.0) + print_inc = 1.0 +! print_inc = 8.0 + +! Define the directory (the path) where the data will be stored. +! This requires a path for "without" assimilation, and a path +! "with" assimilation. +!!! (recommended default value: +!!! output_path_wo_assim = user input required) +!!! output_path_wi_assim = user input required) + output_path_wo_assim = outputs/wo_assim/ + output_path_wi_assim = outputs/wi_assim/ + +! Individual data files can be output for each variable of +! interest. The code is set up to output 21 variables that +! are commonly used in SnowModel simulations. There are 9 +! empty variable names assigned for the user to add new +! variables of interest for their application. Listed below +! are the variable names as they are defined and used in the +! code, and the corresponding 4-character name that is used in +! the output file for that variable. + +! Define which variables you want to save by using a yes = y or +! no = n. + +! These data outputs are configured to mask out ocean points +! (vegtype.eq.24.0) if this is a land run (seaice_run = 0.0); +! mask out all land points (vegtype.ne.24.0) if this is an +! ocean/sea ice run (seaice_run = 1.0 or 3.0); and to not mask +! out anything if this is a combined land and sea ice run +! (seaice_run = 2.0). + +! If you want to do something different than this general output +! file setup, you can make changes to the outputs_user.f file. + +! VALUES AVERAGED OVER THE PERIOD. + +! air temperature (degrees C) +! 01 = tair(i,j) = Tair_grid(i,j) - 273.16 + print_var_01 = y + +! relative humidity (%) +! 02 = relh(i,j) = rh_grid(i,j) + print_var_02 = n + +! wind speed (m/s) +! 03 = wspd(i,j) = windspd_grid(i,j) + print_var_03 = n + +! incoming solar radiation reaching the surface (W/m2) +! 04 = qsin(i,j) = Qsi_grid(i,j) + print_var_04 = n + +! incoming longwave radiation reaching the surface (W/m2) +! 05 = qlin(i,j) = Qli_grid(i,j) + print_var_05 = n + +! emitted longwave radiation (W/m2) +! 06 = qlem(i,j) = Qle(i,j) + print_var_06 = n + +! albedo (0-1) +! 07 = albd(i,j) = albedo(i,j) + print_var_07 = n + +! wind direction (0-360, true N) +! 08 = wdir(i,j) = from uwind_grid(i,j) and vwind_grid(i,j) + print_var_08 = n + +! VALUES SUMMED OVER THE PERIOD. + +! water-equivalent precipitation (m/time_step) +! 09 = prec(i,j) = prec_grid(i,j) + print_var_09 = y + +! liquid precipitation (m/time_step) +! 10 = rpre(i,j) = rain(i,j) + print_var_10 = y + +! solid precipitation (m/time_step) +! 11 = spre(i,j) = sprec(i,j) + print_var_11 = y + +! snow-water-equivalent melt (m) +! 12 = smlt(i,j) = swemelt(i,j) + print_var_12 = n + +! static-surface sublimation (m) +! 13 = ssub(i,j) = swesublim(i,j) + print_var_13 = n + +! runoff from base of snowpack (m/time_step) +! 14 = roff(i,j) = runoff(i,j) + print_var_14 = n + +! snow-water-equivalent melt from glacier ice (m) +! 15 = glmt(i,j) = glacier_melt(i,j) + print_var_15 = n + +! VALUES SAVED AT THE END OF THE PERIOD. + +! snow depth (m) +! 16 = snod(i,j) = snow_depth(i,j) + print_var_16 = y + +! snow density (kg/m3) (if snod is zero, sden is undef) +! 17 = sden(i,j) = xro_snow(i,j) + print_var_17 = y + +! snow-water-equivalent depth (m) +! This is required if you are doing swe assimilation. +! 18 = swed(i,j) = swe_depth(i,j) + print_var_18 = y + +! summed snow precipitation during simulation year (m) +! This is required if you are doing swe assimilation. +! 19 = sspr(i,j) = sum_sprec(i,j) + print_var_19 = n + +! summed snow-water-equivalent melt during simulation year (m) +! This is required if you are doing swe assimilation. +! 20 = ssmt(i,j) = sum_swemelt(i,j) + print_var_20 = n + +! NEW VARIABLES ADDED TO THE OUTPUT DATA FILE OPTIONS. + +! cloud fraction (0-1) (averaged over the write period) +! 21 = cldf(i,j) = cloud_fraction_grid(i,j) + print_var_21 = n + +! These are extra variables that the user can add as needed. +! You have to modify the code in outputs_user.f to do the +! processing you want for these variables. + print_var_22 = n + print_var_23 = n + print_var_24 = n + print_var_25 = n + print_var_26 = n + print_var_27 = n + print_var_28 = n + print_var_29 = n + print_var_30 = n + +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! +!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + From 88ad6d9fcabe0b997f8b261ebfc249b6e8830bfa Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 11:39:20 -0400 Subject: [PATCH 109/328] Add new How-To Docs for SnowModel Adding new documentation on how to run SnowModel within LIS and also providing an example snowmodel.par file in a new 'docs' subdirectory within the SnowModel directory. This addresses GitHub ticket issue #1290. --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 2 +- lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par | 0 2 files changed, 1 insertion(+), 1 deletion(-) mode change 100755 => 100644 lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index f3449b2aa..b1f21aabc 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -162,7 +162,7 @@ Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for hig Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology, 53(181), 241-256. doi:10.3189/172756507782202865 -Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). https://doi.org/10.1002/2017JC013706 +Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). link:https://doi.org/10.1002/2017JC013706 Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling. Environ. Modelling & Software, 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par b/lis/surfacemodels/land/subLSM/snowmodel/docs/snowmodel.par old mode 100755 new mode 100644 From b950857fb6ff095cef2477c7038f1b0ed6b69468 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 11:57:42 -0400 Subject: [PATCH 110/328] Updates made to the SnowModel How-To Doc --- .../snowmodel/docs/lis_snowmodel_howto.adoc | 20 ++++++++----------- 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index b1f21aabc..9ed3a7c15 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -38,15 +38,11 @@ Running the SnowModel model within the LIS Framework. === Prerequisites + -* SnowModel input files, including snowmodel.par, topo_vege file, - GrADS descriptor files (“ctl_files”) and optional forcing input file. +* SnowModel input files, including snowmodel.par, topo_vege file, GrADS descriptor files (“ctl_files”) and optional forcing input file. * Compiled LDT and LIS executables. -* LDT and LIS config files, LDT output parameter file, and LIS - input forcing and model output tables. +* LDT and LIS config files, LDT output parameter file, and LIS input forcing and model output tables. + -A. Outline of SnowModel Steps - [[ssec_snowmodelsteps,A. Outline of SnowModel Steps]] === A. Outline of SnowModel Steps @@ -63,7 +59,7 @@ A. Outline of SnowModel Steps metforce_opt = 0 .... -. Finally, for the LIS-SnowModel model output, output fields and files are written in and follow the LIS output standards (e.g., ALMA standards). The native SnowModel output files are not currently supported in LIS (e.g., “outputs/wo_assim/snod.gdat”). +Finally, for the LIS-SnowModel model output, output fields and files are written in and follow the LIS output standards (e.g., ALMA standards). The native SnowModel output files are not currently supported in LIS (e.g., “outputs/wo_assim/snod.gdat”). [[ssec_ldtsteps,B. Outline of LDT Steps: Generating the LIS-SnowModel input parameter file]] @@ -71,12 +67,12 @@ A. Outline of SnowModel Steps [NOTE] ==== - Check out the latest “master” branch from the LISF GitHub page. +Check out the latest “master” branch from the LISF GitHub page. ==== . In the LDT directory, run the configure script and make sure to select the “little-endian” option (“1-little"), if running on a little-endian based operating system. Also note, the SnowModel parameter readers in LIS support parallel reads of the input topo_vege.gdat file, so you could also select “1-dmpar” for the “Parallelism” option. -Then run the compile script to generate the LDT executable file. +. Then run the compile script to generate the LDT executable file. . Set up your LDT input config file (e.g., ldt.config) to match the run domain of your SnowModel grid that you generated in step A1 (above). You will point the SnowModel-based parameter readers to your single SnowModel input file, e.g., topo_vege.gdat. @@ -90,13 +86,12 @@ The main points that are specific to SnowModel are: For more information on all the options supported for SnowModel parameters in LDT, please see the full LDT instructions and documentation: - link:https://github.com/NASA-LIS/LISF/blob/master/ldt/configs/ldt.config.adoc + https://github.com/NASA-LIS/LISF/blob/master/ldt/configs/ldt.config.adoc . Run your LDT executable with your ldt.config to generate the model parameter input file used in your LIS-SnowModel run. ./LDT ldt.config - - Output file: lis_input.d01.nc. (for example) + Output file: lis_input.d01.nc (example filename) [[ssec_lissteps,C. Outline of LIS Steps: Running LIS-SnowModel]] @@ -121,6 +116,7 @@ e) Before compiling the LIS code, you will need to include the following Fortran f) Once you add that flag, you are now ready to run the LIS compile script and generate the LIS executable file (“LIS”). +[start=2] . Set up your LIS input config file (e.g., lis.config) for the SnowModel setup, as a “subLSM” (and not as one of the LSMs). Main things to pay attention to: + From 2e32677cd8e55600883e768be40b3171e1a30f5b Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 11:59:39 -0400 Subject: [PATCH 111/328] More updates to SnowModel "How-To" --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index 9ed3a7c15..c9db33e10 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -37,12 +37,11 @@ Running the SnowModel model within the LIS Framework. [[ssec_prerequisites,Prerequisites]] === Prerequisites -+ * SnowModel input files, including snowmodel.par, topo_vege file, GrADS descriptor files (“ctl_files”) and optional forcing input file. * Compiled LDT and LIS executables. * LDT and LIS config files, LDT output parameter file, and LIS input forcing and model output tables. -+ + [[ssec_snowmodelsteps,A. Outline of SnowModel Steps]] === A. Outline of SnowModel Steps From be633e2a3d4ff86797a4b4f67a0728063b28da09 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 12:01:47 -0400 Subject: [PATCH 112/328] Minor modifications to Snowmodel How-To --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 1 + 1 file changed, 1 insertion(+) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index c9db33e10..83e62205d 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -87,6 +87,7 @@ For more information on all the options supported for SnowModel parameters in LD https://github.com/NASA-LIS/LISF/blob/master/ldt/configs/ldt.config.adoc +[start=4] . Run your LDT executable with your ldt.config to generate the model parameter input file used in your LIS-SnowModel run. ./LDT ldt.config From cf434cb2d7e55eba15159b2bffbd1ec6f01e99e4 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 13:42:22 -0400 Subject: [PATCH 113/328] Minor updates to the SnowModel How-To Doc In response to GitHub Issue #1290 --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index 83e62205d..6b1778345 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -136,9 +136,9 @@ Curvature data source: LDT .... + -* Check out the SnowModel specific options under “LAND SURFACE MODELS” section header. This is where where you will specify your model timestep and point to your snowmodel.par file, for example. For further details and options, please check out link:https://github.com/NASA-LIS/LISF/blob/master/lis/configs/lis.config.adoc +* Check out the SnowModel specific options under “LAND SURFACE MODELS” section header. This is where where you will specify your model timestep and point to your snowmodel.par file, for example. For further details and options, please check out :https://github.com/NASA-LIS/LISF/blob/master/lis/configs/lis.config.adoc -* Since SnowModel is a subLSM in LIS, this setup has some model-specific variable names, where we added an “SM” prefix to SWE, SnowDepth, and other fields, as designated in the MODEL_OUTPUT.TBL. This setup was in support of being able to run semi-coupled with other LSMs in LIS, e.g., Noah or Noah-MP (Niu et al., 2011 and Yang et al., 2011), allowing the user to be able to look at both the LSM and this subLSM-based output fields in the LIS output files. Output field specifications for SnowModel can be found here link:https://github.com/NASA-LIS/LISF/blob/master/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc +* Since SnowModel is a subLSM in LIS, this setup has some model-specific variable names, where we added an “SM” prefix to SWE, SnowDepth, and other fields, as designated in the MODEL_OUTPUT.TBL. This setup was in support of being able to run semi-coupled with other LSMs in LIS, e.g., Noah or Noah-MP (Niu et al., 2011 and Yang et al., 2011), allowing the user to be able to look at both the LSM and this subLSM-based output fields in the LIS output files. Output field specifications for SnowModel can be found here https://github.com/NASA-LIS/LISF/blob/master/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc . Place your LDT and LIS executables along with your input config files within the same working directory, running LDT first to generate your LIS input parameter file. Then run LIS to generate your LIS-SnowModel based simulation and output. @@ -158,7 +158,7 @@ Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for hig Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology, 53(181), 241-256. doi:10.3189/172756507782202865 -Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). link:https://doi.org/10.1002/2017JC013706 +Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). https://doi.org/10.1002/2017JC013706 Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling. Environ. Modelling & Software, 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 From c4baf69167422c62520b3923c1f0ab0336de5592 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Fri, 17 Mar 2023 14:46:05 -0400 Subject: [PATCH 114/328] Final notes and updates added to document Issue #1290 --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index 6b1778345..203497c13 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -45,7 +45,7 @@ Running the SnowModel model within the LIS Framework. [[ssec_snowmodelsteps,A. Outline of SnowModel Steps]] === A. Outline of SnowModel Steps -. Define and generate your model domain and native binary input parameter file (“topo_vege.gdat”) using Glen Liston’s SnowModel topo_vege tools and scripts. We recommend using Lambert conformal type grids when setting up your domain for running with LDT and LIS. LIS can handle also UTM and Mercator domains, but additional code updates would be needed to support these grids for SnowModel in LISF. +. Define and generate your model domain and native binary input parameter file (“topo_vege.gdat”) using Glen Liston’s SnowModel topo_vege tools and scripts. For access to these scripts, you can reach out to Dr. Glen Liston at CSU (glen.liston@colostate.edu). We recommend using Lambert conformal type grids when setting up your domain for running with LDT and LIS. LIS can handle also UTM and Mercator domains, but additional code updates would be needed to support these grids for SnowModel in LISF. . LIS is able to support running SnowModel with either its original native ASCII- or binary-formatted “station-based” meteorological forcing files (found in “met/[forcing_dataset]/7_mk_mm/”), or you can use any of the meteorological forcing data readers available in LIS (e.g., NLDAS2, GDAS, MERRA2), which allows the user to bypass all the main SnowModel preprocessing steps. For running with the SnowModel’s native ASCII-formatted files, for example, this option can allow the user to run with in situ station observations as before. @@ -69,7 +69,7 @@ Finally, for the LIS-SnowModel model output, output fields and files are written Check out the latest “master” branch from the LISF GitHub page. ==== -. In the LDT directory, run the configure script and make sure to select the “little-endian” option (“1-little"), if running on a little-endian based operating system. Also note, the SnowModel parameter readers in LIS support parallel reads of the input topo_vege.gdat file, so you could also select “1-dmpar” for the “Parallelism” option. +. In the LDT directory, run the configure script and make sure to select the “little-endian” option (“1-little"), if running on a little-endian based operating system. Also note, the SnowModel parameter readers in LDT and LIS support parallel reads of the input topo_vege.gdat file, so you could also select “1-dmpar” for the “Parallelism” option. . Then run the compile script to generate the LDT executable file. From bad1dd781cf540fb64df791099dd5d09b56ea714 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Tue, 21 Mar 2023 19:00:58 -0400 Subject: [PATCH 115/328] Minor typo and formatting fix --- .../snowmodel/docs/lis_snowmodel_howto.adoc | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index 203497c13..336a5d277 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -51,7 +51,7 @@ Running the SnowModel model within the LIS Framework. . For large domains, we recommend also setting up the “extra_met” grid_lon.gdat and grid_lat.gdat files for handling of UTC time changes for the solar radiation calculations in SnowModel. -. Next, you will want to set up your SnowModel parameter text-based input file: snowmodel.par, as you normally would to run the model. This input parameter file is read in by LIS and “loads” the variety of options available to run the SnowModel system. Note: With the LIS version, one new option was included in the snowmodel.par file, which an example is provided within this “docs” directory with this “How To”, default option is: +. Next, you will want to set up your SnowModel parameter text-based input file: snowmodel.par, as you normally would to run the model. This input parameter file is read in by LIS and “loads” the variety of options available to run the SnowModel system. Note: With the LIS version, one new option was included in the snowmodel.par file, which an example is provided within this “docs” directory with this “How To”. The default option is: [subs="attributes+,-callouts"] .... @@ -91,7 +91,7 @@ For more information on all the options supported for SnowModel parameters in LD . Run your LDT executable with your ldt.config to generate the model parameter input file used in your LIS-SnowModel run. ./LDT ldt.config - Output file: lis_input.d01.nc (example filename) + Output file: lis_input.d01.nc (example filename) [[ssec_lissteps,C. Outline of LIS Steps: Running LIS-SnowModel]] @@ -99,7 +99,7 @@ For more information on all the options supported for SnowModel parameters in LD . In the LIS directory, you will first go into “make” directory and you will do the following: -a) Open the file: default.cfg (with an editor of choice) +a) Open the file: default.cfg (with an editor of choice) b) Go to the “SNOWMODEL” section and turn on the model with “True”: @@ -136,9 +136,9 @@ Curvature data source: LDT .... + -* Check out the SnowModel specific options under “LAND SURFACE MODELS” section header. This is where where you will specify your model timestep and point to your snowmodel.par file, for example. For further details and options, please check out :https://github.com/NASA-LIS/LISF/blob/master/lis/configs/lis.config.adoc +* Check out the SnowModel specific options under “LAND SURFACE MODELS” section header. This is where where you will specify your model timestep and point to your snowmodel.par file, for example. For further details and options, please check out: https://github.com/NASA-LIS/LISF/blob/master/lis/configs/lis.config.adoc -* Since SnowModel is a subLSM in LIS, this setup has some model-specific variable names, where we added an “SM” prefix to SWE, SnowDepth, and other fields, as designated in the MODEL_OUTPUT.TBL. This setup was in support of being able to run semi-coupled with other LSMs in LIS, e.g., Noah or Noah-MP (Niu et al., 2011 and Yang et al., 2011), allowing the user to be able to look at both the LSM and this subLSM-based output fields in the LIS output files. Output field specifications for SnowModel can be found here https://github.com/NASA-LIS/LISF/blob/master/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc +* Since SnowModel is a subLSM in LIS, this setup has some model-specific variable names, where we added an “SM” prefix to SWE, SnowDepth, and other fields, as designated in the MODEL_OUTPUT.TBL. This setup was in support of being able to run semi-coupled with other LSMs in LIS, e.g., Noah or Noah-MP (Niu et al., 2011 and Yang et al., 2011), allowing the user to be able to look at both the LSM and this subLSM-based output fields in the LIS output files. Output field specifications for SnowModel can be found here: https://github.com/NASA-LIS/LISF/blob/master/lis/configs/MODEL_OUTPUT_LIST.TBL.adoc . Place your LDT and LIS executables along with your input config files within the same working directory, running LDT first to generate your LIS input parameter file. Then run LIS to generate your LIS-SnowModel based simulation and output. @@ -150,20 +150,20 @@ Curvature data source: LDT Arsenault, K.R., S.V. Kumar, J.V. Geiger, S. Wang, E. Kemp, D.M. Mocko, H.K. Beaudoing, A. Getirana, M. Navari, B. Li, J. Jacob, J. Wegiel, and C.D. Peters-Lidard (2018), The Land surface Data Toolkit (LDT v7.2) – a data fusion environment for land data assimilation systems. Geosci. Model Dev., 11, 3605-3621, doi:10.5194/gmd-11-3605-2018 -Liston, G., & Sturm, M. (1998), A snow-transport model for complex terrain. Journal of Glaciology, 44(148), 498-516. doi:10.3189/S0022143000002021. +Liston, G., & Sturm, M. (1998), A snow-transport model for complex terrain. Journal of Glaciology. 44(148), 498-516. doi:10.3189/S0022143000002021 -Liston, G. E., & Elder, K. (2006a), A distributed snow-evolution modeling system (SnowModel). Journal of Hydrometeorology. 7(6): 1259-1276. +Liston, G. E., & Elder, K. (2006a), A distributed snow-evolution modeling system (SnowModel). Journal of Hydrometeorology. 7(6): 1259-1276 -Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for high-resolution terrestrial modeling (MicroMet), Journal of Hydrometeorology, 7(2), 217-234. +Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for high-resolution terrestrial modeling (MicroMet). Journal of Hydrometeorology, 7(2), 217-234 -Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology, 53(181), 241-256. doi:10.3189/172756507782202865 +Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology. 53(181), 241-256. doi:10.3189/172756507782202865 Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). https://doi.org/10.1002/2017JC013706 -Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling. Environ. Modelling & Software, 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 +Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling, Environ. Modelling & Software. 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 Kumar, S.V., et al. (2012), Land surface Verification Toolkit (LVT) - a generalized framework for land surface model evaluation. Geosci. Model Dev., 5, 869-886, doi:10.5194/gmd-5-869-2012 -Niu, G.-Y., et al. (2011), The community Noah land surface model with multiparameterization options (Noah-MP): 1. Model description and evaluation with local-scale measurements. J. Geophys. Res., 116, D12109, doi: 10.1029/2010JD015139. +Niu, G.-Y., et al. (2011), The community Noah land surface model with multiparameterization options (Noah-MP): 1. Model description and evaluation with local-scale measurements. J. Geophys. Res., 116, D12109, doi: 10.1029/2010JD015139 -Yang, Z.-L., G.-Y. Niu, K. E. Mitchell, F. Chen, M. B. Ek, M. Barlage, K. Manning, D. Niyogi, M. Tewari, & Y. Xia (2011), The Community Noah Land Surface Model with Multi-Parameterization Options (Noah-MP): 2. Evaluation over Global River Basins. J. Geophys. Res., doi:10.1029/2010JD015140. +Yang, Z.-L., G.-Y. Niu, K. E. Mitchell, F. Chen, M. B. Ek, M. Barlage, K. Manning, D. Niyogi, M. Tewari, & Y. Xia (2011), The Community Noah Land Surface Model with Multi-Parameterization Options (Noah-MP): 2. Evaluation over Global River Basins. J. Geophys. Res., doi:10.1029/2010JD015140 From 349fed89257038ac78cce256594548e70501d3d1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 22 Mar 2023 10:09:51 -0400 Subject: [PATCH 116/328] DAobs code calcs Teff for locations with local mean time of 5-7 am or pm. TODO: Retest retrieval code. --- ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 33 +++++++++--- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 52 ++++++++++++------- ldt/core/LDT_SigmaMod.F90 | 6 ++- 3 files changed, 62 insertions(+), 29 deletions(-) diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index 121dbd58e..ea4d50d92 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -61,6 +61,9 @@ subroutine readLISlsmTEFFobs(n) real :: gmt real :: lhour integer :: zone + integer, allocatable :: ntiles_pergrid(:) + integer, allocatable :: str_tind(:) + integer :: gid interface subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & @@ -184,18 +187,29 @@ end subroutine create_lsm_teff_output_filename lsmteffobs%nc, lsmteffobs%nr call LDT_endrun() end if - call read_LIStsoil_data_usaf(n, lsmteffobs%num_tiles, fname, tsoil, & - rc1) + tsoil = 0 + allocate(ntiles_pergrid(lsmteffobs%nc * lsmteffobs%nr)) + ntiles_pergrid = lsmteffobs%ntiles_pergrid ! Copy scalar to array + allocate(str_tind(lsmteffobs%nc * lsmteffobs%nr)) + do gid = 1, lsmteffobs%nc * lsmteffobs%nr + str_tind(gid) = ((gid - 1) * lsmteffobs%num_ens) + 1 + end do + call read_LIStsoil_data_usaf(n, lsmteffobs%num_tiles, str_tind, & + ntiles_pergrid, & + lsmteffobs%num_ens, & + fname, tsoil, rc1) if (rc1 .ne. 0) then write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) call LDT_endrun() end if tsoil01value2d = tsoil(:,:,1) tsoil02value2d = tsoil(:,:,2) + deallocate(ntiles_pergrid) + deallocate(str_tind) kk = 1.007 - cc_6am = 0.246; !Descending - cc_6pm = 1.000; !Ascending + cc_6am = 0.246; !Descending + cc_6pm = 1.000; !Ascending do r=1,lsmteffobs%nr do c=1, lsmteffobs%nc @@ -204,14 +218,18 @@ end subroutine create_lsm_teff_output_filename gmt = LDT_rc%hr call LDT_gmt2localtime(gmt, lon, lhour, zone) - if(lhour.eq.6) then + !if(lhour.eq.6) then ! Orig + if(lhour > 4 .and. lhour < 8) then ! EMK for 3-hrly data + if (Tsoil01value2d(c,r).gt.273.15.and.Tsoil02value2d(c,r).gt.273.15) then teffvalue1d(c+(r-1)*lsmteffobs%nc) = & kk * (cc_6am * Tsoil01value2d(c,r) + (1 - cc_6am) * Tsoil02value2d(c,r)) else teffvalue1d(c+(r-1)*lsmteffobs%nc) = LDT_rc%udef endif - elseif(lhour.eq.18) then + !elseif(lhour.eq.18) then ! Orig + elseif (lhour > 16 .and. lhour < 20) then ! EMK for 3-hrly data + if (Tsoil01value2d(c,r).gt.273.15.and.Tsoil02value2d(c,r).gt.273.15) then teffvalue1d(c+(r-1)*lsmteffobs%nc) = & kk * (cc_6pm * Tsoil01value2d(c,r) + (1 - cc_6pm) * Tsoil02value2d(c,r)) @@ -221,9 +239,10 @@ end subroutine create_lsm_teff_output_filename else teffvalue1d(c+(r-1)*lsmteffobs%nc) = LDT_rc%udef endif + enddo enddo - + call transformDataToLDTgrid_teff(n,teffvalue1d,teff_data) #endif diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index 3428b4dd1..797afc6b9 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -43,6 +43,9 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) logical :: file_exists integer :: rc1 integer :: gid + integer :: nens + integer, allocatable :: str_tind(:) + integer, allocatable :: ntiles_pergrid(:) real, parameter :: kk = 1.007 real, parameter :: cc_6am = 0.246 real, parameter :: cc_6pm = 1.000 @@ -56,17 +59,8 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) rc = 1 ! Assume error by default, update below ! Set up basic info on Air Force product - ! FIXME...Fetch critical data from ldt.config file instead of hardwiring - !LDT_rc%nensem(n) = 12 - LDT_rc%nensem(n) = SMAPeOPL%num_ens - !LDT_rc%glbntiles_red(n) = LDT_rc%lnc(n) * LDT_rc%lnr(n) * LDT_rc%nensem(n) - !LDT_rc%glbntiles_red(n) = SMAPeOPL%num_tiles - if (.not. allocated(LDT_domain(n)%ntiles_pergrid)) & - allocate(LDT_domain(n)%ntiles_pergrid(LDT_rc%lnc(n) * LDT_rc%lnr(n))) - !LDT_domain(n)%ntiles_pergrid = 1 - LDT_domain(n)%ntiles_pergrid = SMAPeOPL%ntiles_pergrid - if (.not. allocated(LDT_domain(n)%str_tind)) & - allocate(LDT_domain(n)%str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + nens = SMAPeOPL%num_ens + allocate(str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n))) if (SMAPeOPL%ntiles_pergrid .ne. 1) then write(LDT_logunit,*) & '[ERR] Current SMAP_E_OPL code assumes ntiles_pergrid = 1' @@ -75,8 +69,10 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) call LDT_endrun() end if do gid = 1, (LDT_rc%gnc(n) * LDT_rc%gnr(n)) - LDT_domain(n)%str_tind(gid) = ((gid - 1) * LDT_rc%nensem(n)) + 1 + str_tind(gid) = ((gid - 1) * nens) + 1 end do + allocate(ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnr(n))) + ntiles_pergrid = SMAPeOPL%ntiles_pergrid call create_LISsoilT_filename_usaf(SMAPeOPL%LISdir, & yyyymmdd, hh, fname) @@ -84,7 +80,9 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) inquire(file=trim(fname), exist=file_exists) if (file_exists) then write(LDT_logunit,*) '[INFO] Reading ', trim(fname) - call read_LIStsoil_data_usaf(n, SMAPeOPL%num_tiles, fname, tsoil, rc1) + call read_LIStsoil_data_usaf(n, SMAPeOPL%num_tiles, str_tind, & + ntiles_pergrid, nens, & + fname, tsoil, rc1) if (rc1 .ne. 0) then write(LDT_logunit,*) '[ERR] Cannot read from ', trim(fname) return @@ -110,6 +108,9 @@ subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) rc = 0 end if + if (allocated(str_tind)) deallocate(str_tind) + if (allocated(ntiles_pergrid)) deallocate(ntiles_pergrid) + end subroutine readLIS_Teff_usaf !BOP @@ -118,7 +119,8 @@ end subroutine readLIS_Teff_usaf ! \label{read_LIStsoil_data_usaf} ! ! !INTERFACE: -subroutine read_LIStsoil_data_usaf(n, ntiles, fname, tsoil, rc) +subroutine read_LIStsoil_data_usaf(n, ntiles, str_tind, ntiles_pergrid, nens, & + fname, tsoil, rc) ! ! !USES: use LDT_logMod @@ -135,6 +137,9 @@ subroutine read_LIStsoil_data_usaf(n, ntiles, fname, tsoil, rc) ! integer, intent(in) :: n integer, intent(in) :: ntiles + integer, intent(in) :: str_tind(LDT_rc%gnc(n) * LDT_rc%gnc(n)) + integer, intent(in) :: ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnc(n)) + integer, intent(in) :: nens character(*), intent(in) :: fname real, intent(inout) :: tsoil(LDT_rc%lnc(n),LDT_rc%lnr(n),4) integer, intent(out) :: rc @@ -247,7 +252,9 @@ subroutine read_LIStsoil_data_usaf(n, ntiles, fname, tsoil, rc) ! Calculate ensemble mean in 2d grid space, for each soil layer do k = 1, SoilTemp_profiles - call calc_gridded_ensmean_1layer(n, ntiles, SoilTemp_inst_tiles(:,k), & + call calc_gridded_ensmean_1layer(n, ntiles, str_tind, ntiles_pergrid, & + nens, & + SoilTemp_inst_tiles(:,k), & SoilTemp_inst_ensmean_1layer) do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) @@ -275,10 +282,12 @@ end subroutine read_LIStsoil_data_usaf ! Subroutine for calculating 2d gridded ensemble mean for a single soil layer, ! from tiled data. -subroutine calc_gridded_ensmean_1layer(n, ntiles, gvar_tile, gvar) +subroutine calc_gridded_ensmean_1layer(n, ntiles, str_tind, ntiles_pergrid, & + nens, gvar_tile, gvar) ! Imports use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc + use LDT_logMod, only: LDT_logunit ! Defaults implicit none @@ -286,6 +295,9 @@ subroutine calc_gridded_ensmean_1layer(n, ntiles, gvar_tile, gvar) ! Arguments integer, intent(in) :: n integer, intent(in) :: ntiles + integer, intent(in) :: str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n)) + integer, intent(in) :: ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnr(n)) + integer, intent(in) :: nens real, intent(in) :: gvar_tile(ntiles) real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) @@ -297,13 +309,13 @@ subroutine calc_gridded_ensmean_1layer(n, ntiles, gvar_tile, gvar) do r = 1, LDT_rc%gnr(n) do c = 1, LDT_rc%gnc(n) gid = c + ((r-1) * LDT_rc%gnc(n)) - stid = LDT_domain(n)%str_tind(gid) - if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then - do m = 1, LDT_rc%nensem(n) + stid = str_tind(gid) + if (ntiles_pergrid(gid) > 0) then + do m = 1, nens tid = stid + m - 1 gvar(c,r) = gvar(c,r) + gvar_tile(tid) enddo - gvar(c,r) = gvar(c,r) / LDT_rc%nensem(n) + gvar(c,r) = gvar(c,r) / nens end if end do end do diff --git a/ldt/core/LDT_SigmaMod.F90 b/ldt/core/LDT_SigmaMod.F90 index 4b9ac9df3..f806b507b 100644 --- a/ldt/core/LDT_SigmaMod.F90 +++ b/ldt/core/LDT_SigmaMod.F90 @@ -178,14 +178,16 @@ subroutine diagnoseSingleSigma(n,obs, metrics) gmt = LDT_rc%hr call LDT_gmt2localtime(gmt, lon, lhour, zone) - if(lhour.eq.6) then + !if(lhour.eq.6) then ! Orig + if(lhour > 4 .and. lhour < 8) then ! EMK for 3-hrly data metrics%sxx_sigma_6am(t,j,k) = metrics%sxx_sigma_6am(t,j,k) + & obs%value(t1,k)*obs%value(t1,k) metrics%sx_sigma_6am(t,j,k) = metrics%sx_sigma_6am(t,j,k) + & obs%value(t1,k) metrics%count_sigma_6am(t,j,k) = & metrics%count_sigma_6am(t,j,k) + 1 - elseif(lhour.eq.18) then + !elseif(lhour.eq.18) then ! Orig + elseif (lhour > 16 .and. lhour < 20) then ! EMK for 3-hrly data metrics%sxx_sigma_6pm(t,j,k) = metrics%sxx_sigma_6pm(t,j,k) + & obs%value(t1,k)*obs%value(t1,k) metrics%sx_sigma_6pm(t,j,k) = metrics%sx_sigma_6pm(t,j,k) + & From d91e670cd3f2ce5abc5861d04dae88db86bc93c9 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 22 Mar 2023 12:09:21 -0400 Subject: [PATCH 117/328] Use consistent citation style. (1) Period after the title, (2) comma after the journal. --- .../land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc index 336a5d277..284e866e4 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc +++ b/lis/surfacemodels/land/subLSM/snowmodel/docs/lis_snowmodel_howto.adoc @@ -150,17 +150,17 @@ Curvature data source: LDT Arsenault, K.R., S.V. Kumar, J.V. Geiger, S. Wang, E. Kemp, D.M. Mocko, H.K. Beaudoing, A. Getirana, M. Navari, B. Li, J. Jacob, J. Wegiel, and C.D. Peters-Lidard (2018), The Land surface Data Toolkit (LDT v7.2) – a data fusion environment for land data assimilation systems. Geosci. Model Dev., 11, 3605-3621, doi:10.5194/gmd-11-3605-2018 -Liston, G., & Sturm, M. (1998), A snow-transport model for complex terrain. Journal of Glaciology. 44(148), 498-516. doi:10.3189/S0022143000002021 +Liston, G., & Sturm, M. (1998), A snow-transport model for complex terrain. Journal of Glaciology, 44(148), 498-516. doi:10.3189/S0022143000002021 -Liston, G. E., & Elder, K. (2006a), A distributed snow-evolution modeling system (SnowModel). Journal of Hydrometeorology. 7(6): 1259-1276 +Liston, G. E., & Elder, K. (2006a), A distributed snow-evolution modeling system (SnowModel). Journal of Hydrometeorology, 7(6): 1259-1276 Liston, G. E., & Elder, K. (2006b), A meteorological distribution system for high-resolution terrestrial modeling (MicroMet). Journal of Hydrometeorology, 7(2), 217-234 -Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology. 53(181), 241-256. doi:10.3189/172756507782202865 +Liston, G., Haehnel, R., Sturm, M., Hiemstra, C., Berezovskaya, S., & Tabler, R. (2007), Simulating complex snow distributions in windy environments using SnowTran-3D. Journal of Glaciology, 53(181), 241-256. doi:10.3189/172756507782202865 Liston, G. E., Polashenski, C., Rösel, A., Itkin, P., King, J., Merkouriadi, I., & Haapala, J. (2018), A distributed snow-evolution model for sea-ice applications (SnowModel). https://doi.org/10.1002/2017JC013706 -Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling, Environ. Modelling & Software. 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 +Kumar, S.V., C.D. Peters-Lidard, Y. Tian, P.R. Houser, J. Geiger, S. Olden, L. Lighty, J.L. Eastman, B. Doty, P. Dirmeyer, J. Adams, K. Mitchell, E. F. Wood, and J. Sheffield (2006), Land Information System - An Interoperable Framework for High Resolution Land Surface Modeling. Environ. Modelling & Software, 21, 1402-1415, doi:10.1016/j.envsoft.2005.07.004 Kumar, S.V., et al. (2012), Land surface Verification Toolkit (LVT) - a generalized framework for land surface model evaluation. Geosci. Model Dev., 5, 869-886, doi:10.5194/gmd-5-869-2012 From ee31ad632218c96bb733d50a28a56528d9da437f Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 27 Mar 2023 15:20:28 -0400 Subject: [PATCH 118/328] Add NASA copyright notice to EIS Visualization Portal files --- .../eis_visualization_portal/eis-fire/index.html | 11 +++++++++++ .../eis-freshwater/data/MissRiverBasin0.js | 11 +++++++++++ .../eis-freshwater/data/columbia_basin_0.js | 13 ++++++++++++- .../eis-freshwater/data/dams_columbia_all_3.js | 13 ++++++++++++- .../eis-freshwater/data/downstream_reach_4.js | 13 ++++++++++++- .../eis-freshwater/data/reservoir_only_6.js | 13 ++++++++++++- .../eis-freshwater/data/reservoir_upstream_7.js | 13 ++++++++++++- .../data/reservoir_upstream_dnstream_8.js | 13 ++++++++++++- .../eis-freshwater/data/reservoirs_2.js | 13 ++++++++++++- .../eis-freshwater/data/rivers_1.js | 13 ++++++++++++- .../eis-freshwater/data/rivers_mrb_0.js | 13 ++++++++++++- .../eis-freshwater/data/upstream_reach_5.js | 13 ++++++++++++- .../eis-freshwater/explorer.html | 11 +++++++++++ .../eis-freshwater/index.html | 11 +++++++++++ .../eis-freshwater/storymap.html | 11 +++++++++++ .../eis-freshwater/timeseries_altimeter.html | 11 +++++++++++ .../eis-freshwater/timeseries_streamflow.html | 11 +++++++++++ .../eis-sealevel/index.html | 11 +++++++++++ .../eis-sealevel/storymap.html | 11 +++++++++++ .../eis-toplanding/about.html | 11 +++++++++++ .../eis-toplanding/css/about.css | 11 +++++++++++ .../eis-toplanding/css/agency.css | 11 +++++++++++ .../eis-toplanding/css/agency.min.css | 13 ++++++++++++- .../eis-toplanding/css/style.css | 13 ++++++++++++- .../eis-toplanding/css/styles.css | 11 +++++++++++ .../eis-toplanding/index.html | 11 +++++++++++ .../eis-toplanding/js/agency.js | 11 +++++++++++ .../eis-toplanding/js/agency.min.js | 13 ++++++++++++- .../eis-toplanding/js/contact_me.js | 11 +++++++++++ .../eis-toplanding/scss/agency.scss | 12 ++++++++++++ .../eis-toplanding/scss/base/_mixins.scss | 12 ++++++++++++ .../eis-toplanding/scss/base/_page.scss | 12 ++++++++++++ .../eis-toplanding/scss/base/_variables.scss | 12 ++++++++++++ .../eis-toplanding/scss/components/_buttons.scss | 12 ++++++++++++ .../eis-toplanding/scss/components/_navbar.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_contact.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_footer.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_masthead.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_portfolio.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_services.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_team.scss | 12 ++++++++++++ .../eis-toplanding/scss/layout/_timeline.scss | 12 ++++++++++++ 42 files changed, 488 insertions(+), 13 deletions(-) diff --git a/lis/utils/eis_visualization_portal/eis-fire/index.html b/lis/utils/eis_visualization_portal/eis-fire/index.html index a4c1b1ee9..16c1283fc 100644 --- a/lis/utils/eis_visualization_portal/eis-fire/index.html +++ b/lis/utils/eis_visualization_portal/eis-fire/index.html @@ -1,4 +1,15 @@ + diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html index 9d88adb92..2f39bf58e 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html @@ -1,4 +1,15 @@ + diff --git a/lis/utils/eis_visualization_portal/eis-sealevel/index.html b/lis/utils/eis_visualization_portal/eis-sealevel/index.html index 16c9c5114..ddb77156d 100644 --- a/lis/utils/eis_visualization_portal/eis-sealevel/index.html +++ b/lis/utils/eis_visualization_portal/eis-sealevel/index.html @@ -1,4 +1,15 @@ + diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css index 20585f196..7a1b5312d 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css @@ -1,4 +1,15 @@ /* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ +/* CSS Styles */ diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css index e25547766..7387b072e 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css @@ -1,3 +1,14 @@ +/* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ /*! CSS Styles */ diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css index 82f0cef66..9ba16e678 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css @@ -1,3 +1,14 @@ +/* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ /*! Main CSS styles */ body { @@ -1185,4 +1196,4 @@ ul.social-buttons li a { } ul.social-buttons li a:active, ul.social-buttons li a:focus, ul.social-buttons li a:hover { background-color: #fed136 -} \ No newline at end of file +} diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css index aab5b31be..5c811d763 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css @@ -1,3 +1,14 @@ +/* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ .sd-selection:before { height: 200px; @@ -309,4 +320,4 @@ body { content: "\f09e"; font-family: FontAwesome; padding-right: .2em -} \ No newline at end of file +} diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css index 274e6f3b2..447269b27 100755 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css @@ -1,4 +1,15 @@ /* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ +/* CSS Styles diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/index.html b/lis/utils/eis_visualization_portal/eis-toplanding/index.html index ed2200913..e13018ba4 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/index.html +++ b/lis/utils/eis_visualization_portal/eis-toplanding/index.html @@ -1,4 +1,15 @@ + diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js index 9667027ff..b6e0463ca 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js +++ b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js @@ -1,3 +1,14 @@ +/* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 + + Copyright (c) 2022 United States Government as represented by the + Administrator of the National Aeronautics and Space Administration. + All Rights Reserved. +-------------------------END NOTICE -- DO NOT EDIT----------------------- +*/ (function($) { "use strict"; // Start of use strict diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js index b8847aa0d..207fc1e06 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js +++ b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js @@ -1,5 +1,16 @@ /*! JavaScript */ +/* +-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- + NASA Goddard Space Flight Center + Land Information System Framework (LISF) + Version 7.4 -!function(e){"use strict";e('a.js-scroll-trigger[href*="#"]:not([href="#"])').click(function(){if(location.pathname.replace(/^\//,"")==this.pathname.replace(/^\//,"")&&location.hostname==this.hostname){var a=e(this.hash);if((a=a.length?a:e("[name="+this.hash.slice(1)+"]")).length)return e("html, body").animate({scrollTop:a.offset().top-54},1e3,"easeInOutExpo"),!1}}),e(".js-scroll-trigger").click(function(){e(".navbar-collapse").collapse("hide")}),e("body").scrollspy({target:"#mainNav",offset:56});function a(){100 Date: Thu, 30 Mar 2023 09:23:21 -0400 Subject: [PATCH 119/328] Removing 'Apply perturbation bias correction:' as an option The code has been updated to always employ perturbation bias correciton. Turning this off (mostly inadvertently) leads to biases in ensemble simulations Resolves #1299 --- lis/core/LIS_readConfig.F90 | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/lis/core/LIS_readConfig.F90 b/lis/core/LIS_readConfig.F90 index 419485c90..12f8a5586 100644 --- a/lis/core/LIS_readConfig.F90 +++ b/lis/core/LIS_readConfig.F90 @@ -754,11 +754,12 @@ subroutine LIS_readConfig() call LIS_parseTimeString(time,LIS_rc%pertrestartInterval) - if(npert_forc.ne.0.or.npert_state.ne.0) then - call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%pert_bias_corr,& - label="Apply perturbation bias correction:",rc=rc) - call LIS_verify(rc,'Apply perturbation bias correction: not specified') - endif + LIS_rc%pert_bias_corr = 1 +! if(npert_forc.ne.0.or.npert_state.ne.0) then +! call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%pert_bias_corr,& +! label="Apply perturbation bias correction:",rc=rc) +! call LIS_verify(rc,'Apply perturbation bias correction: not specified') +! endif ! if(npert_forc.ne.0.or.npert_state.ne.0.or.npert_obs.ne.0) then call ESMF_ConfigFindLabel(LIS_config,"Perturbations restart filename:",rc=rc) From 5db2e1480e9e774d46f82647ff7d13db276d30bf Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Fri, 7 Apr 2023 10:44:56 -0400 Subject: [PATCH 120/328] Apply updates to NoahMP 4.0.1 da_tws This updates the NoahMP 4.0.1 support to assimilate terrestrial water storage data from the GRACE mission. These updates came from Sujay Kumar, Bailing Li, Tim Lahmers, and Wanshu Nie. --- .../da_tws/noahmp401_datws_Mod.F90 | 2 - .../da_tws/noahmp401_descale_tws.F90 | 139 +----------- .../noahmp.4.0.1/da_tws/noahmp401_gettws.F90 | 5 - .../noahmp.4.0.1/da_tws/noahmp401_qctws.F90 | 54 +---- .../da_tws/noahmp401_scale_tws.F90 | 67 +----- .../noahmp.4.0.1/da_tws/noahmp401_settws.F90 | 214 ++++++++++++++---- .../da_tws/noahmp401_updatetws.F90 | 50 ++-- .../phys/module_sf_noahmplsm_401.F90 | 10 + 8 files changed, 203 insertions(+), 338 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 index 960ed91d5..0c796f7e2 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 @@ -65,11 +65,9 @@ subroutine noahmp401_datws_init(k) ! !EOP - use LIS_constantsMod, only : LIS_CONST_PATH_LEN implicit none integer :: k integer :: n - character(len=LIS_CONST_PATH_LEN) :: modelcdffile(LIS_rc%nnest) integer :: status integer :: ngrid diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 index 49567ac11..73951985b 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 @@ -20,11 +20,6 @@ subroutine noahmp401_descale_tws(n, LSM_State, LSM_Incr_State) ! !USES: use ESMF - use LIS_coreMod, only : LIS_rc - use LIS_logMod, only : LIS_verify - use noahmp401_lsmMod - use module_sf_noahmplsm_401 - use LIS_constantsMod, only : LIS_CONST_RHOFW ! Natt implicit none ! !ARGUMENTS: @@ -34,7 +29,7 @@ subroutine noahmp401_descale_tws(n, LSM_State, LSM_Incr_State) ! ! !DESCRIPTION: ! -! Descales twsoisture related state prognostic variables for +! Descales tws related state prognostic variables for ! data assimilation ! ! The arguments are: @@ -44,136 +39,4 @@ subroutine noahmp401_descale_tws(n, LSM_State, LSM_Incr_State) ! \end{description} !EOP -!Wanshu - - type(ESMF_Field) :: gwField - real, pointer :: gws(:) - type(ESMF_Field) :: gwIncrField - real, pointer :: gwsIncr(:) - integer :: t - integer :: status - -! Natt - type(ESMF_Field) :: sm1Field - type(ESMF_Field) :: sm2Field - type(ESMF_Field) :: sm3Field - type(ESMF_Field) :: sm4Field - type(ESMF_Field) :: sweField - type(ESMF_Field) :: snodField - type(ESMF_Field) :: sm1IncrField - type(ESMF_Field) :: sm2IncrField - type(ESMF_Field) :: sm3IncrField - type(ESMF_Field) :: sm4IncrField - type(ESMF_Field) :: sweIncrField - type(ESMF_Field) :: snodIncrField - real, pointer :: soilm1(:) - real, pointer :: soilm2(:) - real, pointer :: soilm3(:) - real, pointer :: soilm4(:) - real, pointer :: swe(:) - real, pointer :: snod(:) - real, pointer :: soilmIncr1(:) - real, pointer :: soilmIncr2(:) - real, pointer :: soilmIncr3(:) - real, pointer :: soilmIncr4(:) - real, pointer :: sweincr(:) - real, pointer :: snodincr(:) - integer :: SOILTYP ! soil type index [-] - real :: MAX_THRESHOLD , MIN_THRESHOLD - -#if 0 - ! Natt - ! Descale TWS states - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm1 in noahmp401_descale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 2",sm2Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm2 in noahmp401_descale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 3",sm3Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm3 in noahmp401_descale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 4",sm4Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm4 in noahmp401_descale_tws') - call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for SWE in noahmp401_descale_tws') - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for Snowdepth in noahmp401_descale_tws') - - call ESMF_FieldGet(sm1Field,localDE=0,farrayPtr=soilm1,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm1 in noahmp401_descale_tws') - call ESMF_FieldGet(sm2Field,localDE=0,farrayPtr=soilm2,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm2 in noahmp401_descale_tws') - call ESMF_FieldGet(sm3Field,localDE=0,farrayPtr=soilm3,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm3 in noahmp401_descale_tws') - call ESMF_FieldGet(sm4Field,localDE=0,farrayPtr=soilm4,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm4 in noahmp401_descale_tws') - call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for SWE in noahmp401_descale_tws') - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for Snowdepth in noahmp401_descale_tws') - - ! Natt - ! Descale TWS state increment - call ESMF_StateGet(LSM_Incr_State,"Soil Moisture Layer 1",sm1IncrField,rc=status) - call LIS_verify(status,& - "ESMF_StateGet: Soil Moisture Layer 1 failed in noahmp401_descale_tws") - call ESMF_StateGet(LSM_Incr_State,"Soil Moisture Layer 2",sm2IncrField,rc=status) - call LIS_verify(status,& - "ESMF_StateGet: Soil Moisture Layer 2 failed in noahmp401_descale_tws") - call ESMF_StateGet(LSM_Incr_State,"Soil Moisture Layer 3",sm3IncrField,rc=status) - call LIS_verify(status,& - "ESMF_StateGet: Soil Moisture Layer 3 failed in noahmp401_descale_tws") - call ESMF_StateGet(LSM_Incr_State,"Soil Moisture Layer 4",sm4IncrField,rc=status) - call LIS_verify(status,& - "ESMF_StateGet: Soil Moisture Layer 4 failed in noahmp401_descale_tws") - call ESMF_StateGet(LSM_Incr_State,"SWE",sweIncrField,rc=status) - call LIS_verify(status) - call ESMF_StateGet(LSM_Incr_State,"Snowdepth",snodIncrField,rc=status) - call LIS_verify(status) - - call ESMF_FieldGet(sm1IncrField,localDE=0,farrayPtr=soilmIncr1,rc=status) - call LIS_verify(status,& - "ESMF_FieldGet: Soil Moisture Layer 1 failed in noahmp401_descale_tws") - call ESMF_FieldGet(sm2IncrField,localDE=0,farrayPtr=soilmIncr2,rc=status) - call LIS_verify(status,& - "ESMF_FieldGet: Soil Moisture Layer 2 failed in noahmp401_descale_tws") - call ESMF_FieldGet(sm3IncrField,localDE=0,farrayPtr=soilmIncr3,rc=status) - call LIS_verify(status,& - "ESMF_FieldGet: Soil Moisture Layer 3 failed in noahmp401_descale_tws") - call ESMF_FieldGet(sm4IncrField,localDE=0,farrayPtr=soilmIncr4,rc=status) - call LIS_verify(status,& - "ESMF_FieldGet: Soil Moisture Layer 4 failed in noahmp401_descale_tws") - call ESMF_FieldGet(sweIncrField,localDE=0,farrayPtr=sweincr,rc=status) - call LIS_verify(status) - call ESMF_FieldGet(snodIncrField,localDE=0,farrayPtr=snodincr,rc=status) - call LIS_verify(status) - - - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - !SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype - !MAX_THRESHOLD = MAXSMC (SOILTYP) - !MIN_THRESHOLD = WLTSMC(SOILTYP) - soilm1(t) = soilm1(t) / (NOAHMP401_struc(n)%sldpth(1)*1000.0) ! mm -> m3m-3 - soilm2(t) = soilm2(t) / (NOAHMP401_struc(n)%sldpth(2)*1000.0) ! mm -> m3m-3 - soilm3(t) = soilm3(t) / (NOAHMP401_struc(n)%sldpth(3)*1000.0) ! mm -> m3m-3 - soilm4(t) = soilm4(t) / (NOAHMP401_struc(n)%sldpth(4)*1000.0) ! mm -> m3m-3 - !if (soilm1(t) .lt. MIN_THRESHOLD) soilm1(t) = MIN_THRESHOLD - !if (soilm2(t) .lt. MIN_THRESHOLD) soilm2(t) = MIN_THRESHOLD - !if (soilm3(t) .lt. MIN_THRESHOLD) soilm3(t) = MIN_THRESHOLD - !if (soilm4(t) .lt. MIN_THRESHOLD) soilm4(t) = MIN_THRESHOLD - !if (soilm1(t) .gt. MAX_THRESHOLD) soilm1(t) = MAX_THRESHOLD - !if (soilm2(t) .gt. MAX_THRESHOLD) soilm2(t) = MAX_THRESHOLD - !if (soilm3(t) .gt. MAX_THRESHOLD) soilm3(t) = MAX_THRESHOLD - !if (soilm4(t) .gt. MAX_THRESHOLD) soilm4(t) = MAX_THRESHOLD - swe(t) = swe(t) / 1000.0 ! mm -> m - snod(t) = snod(t) / 1000.0 ! mm -> m - - soilmIncr1(t) = soilmIncr1(t) / (NOAHMP401_struc(n)%sldpth(1)*1000.0) ! mm -> m3m-3 - soilmIncr2(t) = soilmIncr2(t) / (NOAHMP401_struc(n)%sldpth(2)*1000.0) ! mm -> m3m-3 - soilmIncr3(t) = soilmIncr3(t) / (NOAHMP401_struc(n)%sldpth(3)*1000.0) ! mm -> m3m-3 - soilmIncr4(t) = soilmIncr4(t) / (NOAHMP401_struc(n)%sldpth(4)*1000.0) ! mm -> m3m-3 - sweincr(t) = sweincr(t) / 1000.0 ! mm -> m - snodincr(t) = snodincr(t) / 1000.0 ! mm -> m - - enddo -#endif - end subroutine noahmp401_descale_tws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 index d78e2f4ae..b72e00f2a 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 @@ -71,8 +71,6 @@ subroutine noahmp401_gettws(n, LSM_State) call LIS_verify(status,'ESMF_StateGet failed for gw in noahmp401_gettws') call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) call LIS_verify(status,'ESMF_StateGet failed for SWE in noahmp401_gettws') - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for Snowdepth in noahmp401_gettws') call ESMF_FieldGet(sm1Field,localDE=0,farrayPtr=soilm1,rc=status) call LIS_verify(status,'ESMF_FieldGet failed for sm1 in noahmp401_gettws') @@ -86,8 +84,6 @@ subroutine noahmp401_gettws(n, LSM_State) call LIS_verify(status,'ESMF_FieldGet failed for gw in noahmp401_gettws') call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) call LIS_verify(status,'ESMF_FieldGet failed for SWE in noahmp401_gettws') - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for Snowdepth in noahmp401_gettws') do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) !to mm @@ -97,7 +93,6 @@ subroutine noahmp401_gettws(n, LSM_State) soilm4(t) = NOAHMP401_struc(n)%noahmp401(t)%smc(4) gws(t) = NOAHMP401_struc(n)%noahmp401(t)%wa swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv - snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh enddo end subroutine noahmp401_gettws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 index ab1d0be44..f65f4f622 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 @@ -122,22 +122,15 @@ subroutine noahmp401_qctws(n, LSM_State) call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) call LIS_verify(status) - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status) call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) call LIS_verify(status) - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status) + call ESMF_AttributeGet(sweField,"Max Value",swemax,rc=status) call LIS_verify(status) call ESMF_AttributeGet(sweField,"Min Value",swemin,rc=status) call LIS_verify(status) - call ESMF_AttributeGet(snodField,"Max Value",snodmax,rc=status) - call LIS_verify(status) - call ESMF_AttributeGet(snodField,"Min Value",snodmin,rc=status) - call LIS_verify(status) !------- @@ -185,50 +178,11 @@ subroutine noahmp401_qctws(n, LSM_State) if(gws(t).lt.gwsmin) then gws(t) = gwsmin endif - !------ - enddo - - - update_flag = .true. - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - gid = LIS_domain(n)%gindex(& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - - if((snod(t).lt.snodmin) .or. swe(t).lt.swemin) then - update_flag(gid) = .false. + if(swe(t).lt.swemin) then + swe(t) = swemin endif - + !------ enddo - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - gid = LIS_domain(n)%gindex(& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - -!Use the model's snow density from the previous timestep - sndens = 0.0 - if(noahmp401_struc(n)%noahmp401(t)%snowh.gt.0) then - sndens = noahmp401_struc(n)%noahmp401(t)%sneqv/noahmp401_struc(n)%noahmp401(t)%snowh - endif - -!If the update is unphysical, do not update. - if(update_flag(gid)) then - snod(t) = snod(t) - swe(t) = snod(t)*sndens - else ! do not update - snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh - swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv - end if - - if(swe(t).gt.swemax) then - swe(t) = swemax - endif - if(snod(t).gt.snodmax) then - snod(t) = snodmax - endif - - end do - end subroutine noahmp401_qctws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 index 2dfed965a..4fafb99b9 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 @@ -20,10 +20,6 @@ subroutine noahmp401_scale_tws(n, LSM_State) ! !USES: use ESMF - use LIS_coreMod, only : LIS_rc - use LIS_logMod, only : LIS_verify - use noahmp401_lsmMod - use LIS_constantsMod, only : LIS_CONST_RHOFW ! Natt implicit none ! !ARGUMENTS: @@ -32,7 +28,7 @@ subroutine noahmp401_scale_tws(n, LSM_State) ! ! !DESCRIPTION: ! -! Scales twsoisture related state prognostic variables for +! Scales tws related state prognostic variables for ! data assimilation ! ! The arguments are: @@ -41,66 +37,5 @@ subroutine noahmp401_scale_tws(n, LSM_State) ! \item[LSM\_State] ESMF State container for LSM state variables \newline ! \end{description} !EOP - -!Wanshu - - type(ESMF_Field) :: gwField - real, pointer :: gws(:) - integer :: t - integer :: status - -! Natt - type(ESMF_Field) :: sm1Field - type(ESMF_Field) :: sm2Field - type(ESMF_Field) :: sm3Field - type(ESMF_Field) :: sm4Field - type(ESMF_Field) :: sweField - type(ESMF_Field) :: snodField - real, pointer :: soilm1(:) - real, pointer :: soilm2(:) - real, pointer :: soilm3(:) - real, pointer :: soilm4(:) - real, pointer :: swe(:) - real, pointer :: snod(:) - - -#if 0 - ! Natt - ! Scale TWS states to mm (Note, GWS is already in mm) - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm1 in noahmp401_scale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 2",sm2Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm2 in noahmp401_scale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 3",sm3Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm3 in noahmp401_scale_tws') - call ESMF_StateGet(LSM_State,"Soil Moisture Layer 4",sm4Field,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for sm4 in noahmp401_scale_tws') - call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for SWE in noahmp401_scale_tws') - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status,'ESMF_StateGet failed for Snowdepth in noahmp401_scale_tws') - - call ESMF_FieldGet(sm1Field,localDE=0,farrayPtr=soilm1,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm1 in noahmp401_scale_tws') - call ESMF_FieldGet(sm2Field,localDE=0,farrayPtr=soilm2,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm2 in noahmp401_scale_tws') - call ESMF_FieldGet(sm3Field,localDE=0,farrayPtr=soilm3,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm3 in noahmp401_scale_tws') - call ESMF_FieldGet(sm4Field,localDE=0,farrayPtr=soilm4,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for sm4 in noahmp401_scale_tws') - call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for SWE in noahmp401_scale_tws') - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status,'ESMF_FieldGet failed for Snowdepth in noahmp401_scale_tws') - - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - soilm1(t) = soilm1(t) * NOAHMP401_struc(n)%sldpth(1)*1000.0 ! m3m-3 -> mm - soilm2(t) = soilm2(t) * NOAHMP401_struc(n)%sldpth(2)*1000.0 ! m3m-3 -> mm - soilm3(t) = soilm3(t) * NOAHMP401_struc(n)%sldpth(3)*1000.0 ! m3m-3 -> mm - soilm4(t) = soilm4(t) * NOAHMP401_struc(n)%sldpth(4)*1000.0 ! m3m-3 -> mm - swe(t) = swe(t) * 1000.0 ! m -> mm - snod(t) = snod(t) * 1000.0 ! m -> mm - enddo -#endif end subroutine noahmp401_scale_tws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 index 629cdacd3..c7454a6c4 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 @@ -20,6 +20,7 @@ subroutine noahmp401_settws(n, LSM_State) ! !USES: use ESMF use LIS_coreMod + use LIS_constantsMod use LIS_logMod use noahMP401_lsmMod use NOAHMP_TABLES_401, ONLY : SMCMAX_TABLE,SMCWLT_TABLE @@ -35,7 +36,8 @@ subroutine noahmp401_settws(n, LSM_State) ! model space. ! !EOP - real, parameter :: MIN_GWS_THRESHOLD = 0.00 + + real, parameter :: MIN_GWS_THRESHOLD = 0.00 real, parameter :: MAX_GWS_THRESHOLD = 7000.0 real, parameter :: MAX_WA = 7000.0 real, parameter :: ZSOIL = 2 !mm @@ -65,13 +67,16 @@ subroutine noahmp401_settws(n, LSM_State) logical :: diffCheck(LIS_rc%ngrid(n)) logical :: ensCheck(LIS_rc%ngrid(n)) logical :: largeSM(LIS_rc%ngrid(n)) - integer :: i, c,r,t,m + real :: snodens(LIS_rc%npatch(n,LIS_rc%lsm_index)) + integer :: i, c,r,t,m,gid integer :: SOILTYP ! soil type index [-] real :: sh2o_tmp, sh2o_rnd - real :: dsneqv,dsnowh,swe_old, snowh_old + real :: dsneqv,dsnowh, snowh_new + real :: TWS1, TWS2, TWSd,delta1 integer :: status + logical :: update_flag(LIS_rc%ngrid(n)) logical :: rc1,rc2,rc3,rc4,rc5 - + call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) call LIS_verify(status,& @@ -91,10 +96,6 @@ subroutine noahmp401_settws(n, LSM_State) call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) call LIS_verify(status,& "ESMF_StateSet: SWE failed in noahmp401_settws") - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status,& - "ESMF_StateSet: Snowdepth failed in noahmp401_settws") - call ESMF_FieldGet(sm1Field,localDE=0,farrayPtr=soilm1,rc=status) call LIS_verify(status,& @@ -114,11 +115,8 @@ subroutine noahmp401_settws(n, LSM_State) call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) call LIS_verify(status,& "ESMF_FieldGet: SWE failed in noahmp401_settws") - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status,& - "ESMF_FieldGet: Snowdepth failed in noahmp401_settws") - + ensCheck = .true. diffCheck = .false. largeSM = .false. @@ -138,6 +136,14 @@ subroutine noahmp401_settws(n, LSM_State) noahmp401_struc(n)%noahmp401(t)%smc(1).gt.0.50) then largeSM(i) = .true. endif + + if(noahmp401_struc(n)%noahmp401(t)%snowh.gt.0) then + snodens(t) = noahmp401_struc(n)%noahmp401(t)%sneqv/& + noahmp401_struc(n)%noahmp401(t)%snowh + else + snodens(t) = 0.0 + endif + enddo do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) @@ -151,7 +157,6 @@ subroutine noahmp401_settws(n, LSM_State) soilm3(t) = noahmp401_struc(n)%noahmp401(t)%smc(3) soilm4(t) = noahmp401_struc(n)%noahmp401(t)%smc(4) gws(t) = NOAHMP401_struc(n)%noahmp401(t)%wa - snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv endif enddo @@ -230,54 +235,175 @@ subroutine noahmp401_settws(n, LSM_State) soilm3(t) = noahmp401_struc(n)%noahmp401(t)%smc(3) soilm4(t) = noahmp401_struc(n)%noahmp401(t)%smc(4) gws(t) = NOAHMP401_struc(n)%noahmp401(t)%wa - snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv enddo endif enddo + + update_flag = .true. + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + + SOILTYP = noahmp401_struc(n)%noahmp401(t)%soiltype + MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) ! MAXSMC (SOILTYP) + sm_threshold = SMCMAX_TABLE(SOILTYP) - 0.02 ! MAXSMC (SOILTYP) - 0.02 + + gid = LIS_domain(n)%gindex(& + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) + + delta1 = soilm1(t)-noahmp401_struc(n)%noahmp401(t)%smc(1) + + if(noahmp401_struc(n)%noahmp401(t)%sh2o(1)+delta1.gt.MIN_THRESHOLD .and.& + noahmp401_struc(n)%noahmp401(t)%sh2o(1)+delta1.lt.& + sm_threshold) then + update_flag(gid) = update_flag(gid).and.(.true.) + else + update_flag(gid) = update_flag(gid).and.(.false.) + endif + delta1 = soilm2(t)-noahmp401_struc(n)%noahmp401(t)%smc(2) + + if(noahmp401_struc(n)%noahmp401(t)%sh2o(2)+delta1.gt.MIN_THRESHOLD .and.& + noahmp401_struc(n)%noahmp401(t)%sh2o(2)+delta1.lt.& + sm_threshold) then + update_flag(gid) = update_flag(gid).and.(.true.) + else + update_flag(gid) = update_flag(gid).and.(.false.) + endif + + delta1 = soilm3(t)-noahmp401_struc(n)%noahmp401(t)%smc(3) + + if(noahmp401_struc(n)%noahmp401(t)%sh2o(3)+delta1.gt.MIN_THRESHOLD .and.& + noahmp401_struc(n)%noahmp401(t)%sh2o(3)+delta1.lt.& + sm_threshold) then + update_flag(gid) = update_flag(gid).and.(.true.) + else + update_flag(gid) = update_flag(gid).and.(.false.) + endif + + delta1 = soilm4(t)-noahmp401_struc(n)%noahmp401(t)%smc(4) + + if(noahmp401_struc(n)%noahmp401(t)%sh2o(4)+delta1.gt.MIN_THRESHOLD .and.& + noahmp401_struc(n)%noahmp401(t)%sh2o(4)+delta1.lt.& + sm_threshold) then + update_flag(gid) = update_flag(gid).and.(.true.) + else + update_flag(gid) = update_flag(gid).and.(.false.) + endif + enddo + +! if(LIS_localPet.eq.387) then +! gid = LIS_domain(n)%gindex(& +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%col,& +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) +! print*, 'tw1 ',NOAHMP401_struc(n)%noahmp401(16068)%smc,& +! NOAHMP401_struc(n)%noahmp401(16068)%sh2o,& +! NOAHMP401_struc(n)%noahmp401(16068)%sneqv,& +! update_flag(gid) +! endif do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - delta = soilm1(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(1) - NOAHMP401_struc(n)%noahmp401(t)%smc(1) = soilm1(t) - NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) = & - NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) + delta - - delta = soilm2(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(2) - NOAHMP401_struc(n)%noahmp401(t)%smc(2) = soilm2(t) - NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) = & - NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) + delta - - delta = soilm3(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(3) - NOAHMP401_struc(n)%noahmp401(t)%smc(3) = soilm3(t) - NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) = & - NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) + delta - - delta = soilm4(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(4) - NOAHMP401_struc(n)%noahmp401(t)%smc(4) = soilm4(t) - NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) = & - NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) + delta + + gid = LIS_domain(n)%gindex(& + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) + + if(update_flag(gid)) then + delta = soilm1(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(1) + NOAHMP401_struc(n)%noahmp401(t)%smc(1) = soilm1(t) + NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) = & + NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) + delta + + delta = soilm2(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(2) + NOAHMP401_struc(n)%noahmp401(t)%smc(2) = soilm2(t) + NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) = & + NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) + delta + + delta = soilm3(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(3) + NOAHMP401_struc(n)%noahmp401(t)%smc(3) = soilm3(t) + NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) = & + NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) + delta + + delta = soilm4(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(4) + NOAHMP401_struc(n)%noahmp401(t)%smc(4) = soilm4(t) + NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) = & + NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) + delta + + else + + TWS2 =(soilm1(t)*NOAHMP401_struc(n)%sldpth(1)*& + soilm2(t)*NOAHMP401_struc(n)%sldpth(2)*& + soilm3(t)*NOAHMP401_struc(n)%sldpth(3)*& + soilm4(t)*NOAHMP401_struc(n)%sldpth(4))*& + LIS_CONST_RHOFW + + + TWS1 =(Noahmp401_struc(n)%noahmp401(t)%smc(1)*& + NOAHMP401_struc(n)%sldpth(1)*& + noahmp401_struc(n)%noahmp401(t)%smc(2)*& + NOAHMP401_struc(n)%sldpth(2)*& + noahmp401_struc(n)%noahmp401(t)%smc(3)*& + NOAHMP401_struc(n)%sldpth(3)*& + noahmp401_struc(n)%noahmp401(t)%smc(4)*& + NOAHMP401_struc(n)%sldpth(4))*& + LIS_CONST_RHOFW + + TWSd = TWS1 - TWS2 + + if(NOAHMP401_struc(n)%noahmp401(t)%sneqv > 5.and.& + swe(t)+TWSd.gt.0) then +!only add snow if the increment is small + if(TWSd/NOAHMP401_struc(n)%noahmp401(t)%sneqv < 0.10) then + swe(t) = swe(t)+TWSd + endif + else + swe(t) = 0.0 + endif + +! if(LIS_localPet.eq.387.and.t.eq.16068) then +! print*, 'swe ',LIS_localPet, t, swe(t), TWSd +! !since soil moisture update is not accepted, add this to snow +! endif + + endif + NOAHMP401_struc(n)%noahmp401(t)%wa=gws(t) + enddo +! if(LIS_localPet.eq.387) then +! gid = LIS_domain(n)%gindex(& +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%col,& +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) +! print*, 'tw2 ',NOAHMP401_struc(n)%noahmp401(16068)%smc,& +! NOAHMP401_struc(n)%noahmp401(16068)%sh2o,& +! NOAHMP401_struc(n)%noahmp401(16068)%sneqv,& +! update_flag(gid) +! endif + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - swe_old = noahmp401_struc(n)%noahmp401(t)%sneqv - snowh_old = noahmp401_struc(n)%noahmp401(t)%snowh + if(snodens(t).eq.0) then + swe(t) = 0.0 + endif + dsneqv = swe(t) - NOAHMP401_struc(n)%noahmp401(t)%sneqv - dsneqv = swe(t) - noahmp401_struc(n)%noahmp401(t)%sneqv !in mm - dsnowh = snod(t) - noahmp401_struc(n)%noahmp401(t)%snowh !in m + snowh_new = 0 + if(snodens(t).gt.0) then + snowh_new = swe(t)/snodens(t) + endif - !alternate option + dsnowh = snowh_new - NOAHMP401_struc(n)%noahmp401(t)%sneqv + call noahmp401_snow_update(n, t, dsneqv, dsnowh) - - if(noahmp401_struc(n)%noahmp401(t)%sneqv.eq.0.or.& - noahmp401_struc(n)%noahmp401(t)%snowh.eq.0) then - noahmp401_struc(n)%noahmp401(t)%sneqv = 0 - noahmp401_struc(n)%noahmp401(t)%snowh = 0 - endif enddo + + +! write(101,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,10E14.6)') & +! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& +! NOAHMP401_struc(n)%noahmp401(991:1000)%sneqv end subroutine noahmp401_settws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 index e0c031cc9..a8f9d4c3c 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 @@ -92,8 +92,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) call LIS_verify(status) - call ESMF_StateGet(LSM_State,"Snowdepth",snodField,rc=status) - call LIS_verify(status) + call ESMF_StateGet(LSM_Incr_State,"Soil Moisture Layer 1",sm1IncrField,rc=status) @@ -114,8 +113,6 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) "ESMF_StateSet: Groundwater Storage failed in noahmp401_updatetws") call ESMF_StateGet(LSM_Incr_State,"SWE",sweIncrField,rc=status) call LIS_verify(status) - call ESMF_StateGet(LSM_Incr_State,"Snowdepth",snodIncrField,rc=status) - call LIS_verify(status) !------------------- @@ -136,8 +133,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) "ESMF_FieldGet: Groundwater Storage failed in noahmp401_updatetws") call ESMF_FieldGet(sweField,localDE=0,farrayPtr=swe,rc=status) call LIS_verify(status) - call ESMF_FieldGet(snodField,localDE=0,farrayPtr=snod,rc=status) - call LIS_verify(status) + call ESMF_FieldGet(sm1IncrField,localDE=0,farrayPtr=soilmIncr1,rc=status) @@ -157,10 +153,13 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) "ESMF_StateSet: Groundwater Storage failed in noahmp401_updatetws") call ESMF_FieldGet(sweIncrField,localDE=0,farrayPtr=sweincr,rc=status) call LIS_verify(status) - call ESMF_FieldGet(snodIncrField,localDE=0,farrayPtr=snodincr,rc=status) - call LIS_verify(status) + +! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & +! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& +! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) soilm1(t) = soilm1(t) + soilmIncr1(t) @@ -168,8 +167,10 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) soilm3(t) = soilm3(t) + soilmIncr3(t) soilm4(t) = soilm4(t) + soilmIncr4(t) gws(t) = gws(t) + gwsIncr(t) + swe(t) = swe(t) + sweIncr(t) enddo +#if 0 update_flag = .true. perc_violation = 0.0 @@ -182,9 +183,8 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) swetmp = swe(t) + sweincr(t) - snodtmp = snod(t) + snodincr(t) - if((snodtmp.lt.0 .or. swetmp.lt.0)) then + if((swetmp.lt.0)) then update_flag(gid) = .false. perc_violation(gid) = perc_violation(gid) +1 endif @@ -198,29 +198,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) ! For ensembles that are unphysical, compute the ensemble average after excluding them. This ! is done only if the majority of the ensemble members are good (>80%) - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - - gid = LIS_domain(n)%gindex(& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - - if(.not.update_flag(gid)) then ! false - if(perc_violation(gid).lt.0.2) then - if(snod(t)+snodincr(t).ge.0) then - snodmean(gid) = snodmean(gid) + snod(t)+snodincr(t) - nsnodmean(gid) = nsnodmean(gid) + 1 - else - snodmean(gid) = 0.0 - endif - endif - endif - enddo - do gid=1,LIS_rc%ngrid(n) - if(nsnodmean(gid).gt.0) then - snodmean(gid) = snodmean(gid) / real(nsnodmean(gid)) - endif - enddo ! If the update is unphysical, simply set to the average of ! the good ensemble members. If all else fails, do not update. @@ -231,7 +209,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - snodtmp = snod(t) + snodincr(t) + swetmp = swe(t) + sweincr(t) !Use the model's snow density from the previous timestep @@ -257,5 +235,11 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) end if enddo +#endif + +! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & +! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& +! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 + end subroutine noahmp401_updatetws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 index e84d3350c..583e9a0ef 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/phys/module_sf_noahmplsm_401.F90 @@ -1101,7 +1101,12 @@ SUBROUTINE PHENOLOGY (parameters,VEGTYP ,croptype, SNOWH , TV , LAT , YEA IF(parameters%HVT> 0. .AND. parameters%HVT <= 1.0) THEN !MB: change to 1.0 and 0.2 to reflect SNOWHC = parameters%HVT*EXP(-SNOWH/0.2) ! changes to HVT in MPTABLE + IF(SNOWHC>1.E-06) THEN !Wanshu: avoid very small SNOWHC induced floating invalid FB = MIN(SNOWH,SNOWHC)/SNOWHC + ELSE + !print *,"small snowh in phenology=",snowh + FB = 1 + END IF ENDIF ELAI = LAI*(1.-FB) @@ -1824,7 +1829,12 @@ SUBROUTINE ENERGY (parameters,ICE ,VEGTYP ,IST ,NSNOW ,NSOIL , & !in IF(SNOWH.GT.0.) THEN BDSNO = SNEQV / SNOWH FMELT = (BDSNO/100.)**parameters%MFSNO + if (FMELT<0.000001) then !Bailing Li, added this for GRACE DA to catch smaller values + FSNO = 1 + !print *,"small FMELT due to snowh,fmelt,bdsno,para_mfsno",snowh,fmelt,bdsno,parameters%MFSNO + else FSNO = TANH( SNOWH /(2.5* Z0 * FMELT)) + end if ENDIF ! ground roughness length From bc6eb8a388b49ab79eca95b095cab6451ecfd0a8 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Fri, 7 Apr 2023 10:56:06 -0400 Subject: [PATCH 121/328] Clean up whitespace --- .../da_tws/noahmp401_datws_Mod.F90 | 20 +- .../da_tws/noahmp401_descale_tws.F90 | 6 +- .../noahmp.4.0.1/da_tws/noahmp401_gettws.F90 | 6 +- .../noahmp.4.0.1/da_tws/noahmp401_qctws.F90 | 26 +-- .../da_tws/noahmp401_scale_tws.F90 | 8 +- .../noahmp.4.0.1/da_tws/noahmp401_settws.F90 | 172 +++++++++--------- .../da_tws/noahmp401_updatetws.F90 | 28 +-- 7 files changed, 133 insertions(+), 133 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 index 0c796f7e2..1e8bf81af 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 @@ -15,12 +15,12 @@ module noahmp401_datws_Mod ! !MODULE: noahmp401_datws_Mod ! ! !DESCRIPTION: -! +! ! !REVISION HISTORY: ! ! 14 Mar 2017: Sujay Kumar; Initial Specification -! !USES: +! !USES: use ESMF use LIS_coreMod use LIS_dataAssimMod @@ -49,31 +49,31 @@ module noahmp401_datws_Mod integer :: scal end type dasm_dec - + type(dasm_dec), allocatable :: noahmp401_dasm_struc(:) contains !BOP -! +! ! !ROUTINE: noahmp401_datws_init ! \label{noahmp401_datws_init} -! +! ! !INTERFACE: subroutine noahmp401_datws_init(k) ! !USES: -! !DESCRIPTION: +! !DESCRIPTION: ! !EOP - + implicit none integer :: k - integer :: n + integer :: n integer :: status integer :: ngrid - if(.not.allocated(noahmp401_dasm_struc)) then + if(.not.allocated(noahmp401_dasm_struc)) then allocate(noahmp401_dasm_struc(LIS_rc%nnest)) endif - + end subroutine noahmp401_datws_init end module noahmp401_datws_Mod diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 index 73951985b..edca8f7d2 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 @@ -22,7 +22,7 @@ subroutine noahmp401_descale_tws(n, LSM_State, LSM_Incr_State) use ESMF implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State type(ESMF_State) :: LSM_Incr_State @@ -31,8 +31,8 @@ subroutine noahmp401_descale_tws(n, LSM_State, LSM_Incr_State) ! ! Descales tws related state prognostic variables for ! data assimilation -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest \newline ! \item[LSM\_State] ESMF State container for LSM state variables \newline diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 index b72e00f2a..d234bc9b9 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 @@ -26,7 +26,7 @@ subroutine noahmp401_gettws(n, LSM_State) use noahmp401_lsmMod implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State ! @@ -34,8 +34,8 @@ subroutine noahmp401_gettws(n, LSM_State) ! ! Returns the soilmoisture and groundwater related state prognostic variables for ! data assimilation -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest \newline ! \item[LSM\_State] ESMF State container for LSM state variables \newline diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 index f65f4f622..71b7db2b3 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 @@ -13,7 +13,7 @@ ! ! !REVISION HISTORY: ! 14 Mar 2017: Sujay Kumar; Initial Specification -! 29 May 2020: Bailing Li; Created for Noah-MP4.0.1 +! 29 May 2020: Bailing Li; Created for Noah-MP4.0.1 ! ! !INTERFACE: subroutine noahmp401_qctws(n, LSM_State) @@ -27,7 +27,7 @@ subroutine noahmp401_qctws(n, LSM_State) use NOAHMP_TABLES_401, ONLY : SMCMAX_TABLE,SMCWLT_TABLE implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State ! @@ -35,8 +35,8 @@ subroutine noahmp401_qctws(n, LSM_State) ! ! Returns the soilmoisture related state prognostic variables for ! data assimilation -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest \newline ! \item[LSM\_State] ESMF State container for LSM state variables \newline @@ -50,7 +50,7 @@ subroutine noahmp401_qctws(n, LSM_State) real, pointer :: soilm4(:) real :: smmax real :: smmin - + type(ESMF_Field) :: sm1Field type(ESMF_Field) :: sm2Field type(ESMF_Field) :: sm3Field @@ -70,8 +70,8 @@ subroutine noahmp401_qctws(n, LSM_State) real :: swemin,snodmin real :: sndens - logical :: update_flag(LIS_rc%ngrid(n)) -!------- + logical :: update_flag(LIS_rc%ngrid(n)) +!------- call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) call LIS_verify(status,& @@ -96,7 +96,7 @@ subroutine noahmp401_qctws(n, LSM_State) call ESMF_FieldGet(sm1Field,localDE=0,farrayPtr=soilm3,rc=status) call LIS_verify(status,& "ESMF_FieldGet for Soil Moisture Layer 3 failed in noahmp401_qctws") - + call ESMF_StateGet(LSM_State,"Soil Moisture Layer 4",sm4Field,rc=status) call LIS_verify(status,& "ESMF_StateGet for Soil Moisture Layer 4 failed in noahmp401_qctws") @@ -108,7 +108,7 @@ subroutine noahmp401_qctws(n, LSM_State) !Wanshu call ESMF_StateGet(LSM_State,"Groundwater Storage",gwField,rc=status) call LIS_verify(status,'ESMF_StateGet failed for gw in noahmp401_qctws') - + call ESMF_FieldGet(gwField,localDE=0,farrayPtr=gws,rc=status) call LIS_verify(status,'ESMF_FieldGet failed for gw in noahmp401_qctws') @@ -131,22 +131,22 @@ subroutine noahmp401_qctws(n, LSM_State) call LIS_verify(status) call ESMF_AttributeGet(sweField,"Min Value",swemin,rc=status) call LIS_verify(status) - + !------- do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) !Bailing Li: max min soil moisture should be retrieved based on soil type SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype - MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) - MIN_THRESHOLD = SMCWLT_TABLE(SOILTYP) + MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) + MIN_THRESHOLD = SMCWLT_TABLE(SOILTYP) sm_threshold = MAX_THRESHOLD - 0.02 if(soilm1(t).gt.sm_threshold) then soilm1(t) = sm_threshold endif - + if(soilm1(t).lt.MIN_THRESHOLD) then soilm1(t) = MIN_THRESHOLD endif diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 index 4fafb99b9..8d71fb50a 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 @@ -22,7 +22,7 @@ subroutine noahmp401_scale_tws(n, LSM_State) use ESMF implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State ! @@ -30,12 +30,12 @@ subroutine noahmp401_scale_tws(n, LSM_State) ! ! Scales tws related state prognostic variables for ! data assimilation -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest \newline ! \item[LSM\_State] ESMF State container for LSM state variables \newline ! \end{description} !EOP - + end subroutine noahmp401_scale_tws diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 index c7454a6c4..0397497d7 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 @@ -13,7 +13,7 @@ ! ! !REVISION HISTORY: ! 14 Mar 2017: Sujay Kumar; Initial Specification -! 29 May 2020: Bailing Li; created for Noah-MP4.0.1 +! 29 May 2020: Bailing Li; created for Noah-MP4.0.1 ! ! !INTERFACE: subroutine noahmp401_settws(n, LSM_State) @@ -26,25 +26,25 @@ subroutine noahmp401_settws(n, LSM_State) use NOAHMP_TABLES_401, ONLY : SMCMAX_TABLE,SMCWLT_TABLE implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State ! ! !DESCRIPTION: -! +! ! This routine assigns the soil moisture prognostic variables to noah's -! model space. -! +! model space. +! !EOP - real, parameter :: MIN_GWS_THRESHOLD = 0.00 + real, parameter :: MIN_GWS_THRESHOLD = 0.00 real, parameter :: MAX_GWS_THRESHOLD = 7000.0 real, parameter :: MAX_WA = 7000.0 real, parameter :: ZSOIL = 2 !mm real, parameter :: ROUS = 0.2 ! specific yield !Bailing changed this to be WLTSMC -! real, parameter :: MIN_THRESHOLD = 0.02 - real :: MIN_THRESHOLD +! real, parameter :: MIN_THRESHOLD = 0.02 + real :: MIN_THRESHOLD real :: MAX_THRESHOLD real :: sm_threshold type(ESMF_Field) :: sm1Field @@ -70,14 +70,14 @@ subroutine noahmp401_settws(n, LSM_State) real :: snodens(LIS_rc%npatch(n,LIS_rc%lsm_index)) integer :: i, c,r,t,m,gid integer :: SOILTYP ! soil type index [-] - real :: sh2o_tmp, sh2o_rnd + real :: sh2o_tmp, sh2o_rnd real :: dsneqv,dsnowh, snowh_new real :: TWS1, TWS2, TWSd,delta1 integer :: status logical :: update_flag(LIS_rc%ngrid(n)) logical :: rc1,rc2,rc3,rc4,rc5 - + call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) call LIS_verify(status,& "ESMF_StateSet: Soil Moisture Layer 1 failed in noahmp401_settws") @@ -116,42 +116,42 @@ subroutine noahmp401_settws(n, LSM_State) call LIS_verify(status,& "ESMF_FieldGet: SWE failed in noahmp401_settws") - + ensCheck = .true. diffCheck = .false. largeSM = .false. - + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - + c = LIS_domain(n)%tile(t)%col r = LIS_domain(n)%tile(t)%row i = LIS_domain(n)%gindex(c,r) - SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype - MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) + SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype + MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) !locations with large soil moisture values are ice points. !we turn off the increments in such locations. if(noahmp401_struc(n)%noahmp401(t)%smc(1).gt.MAX_THRESHOLD.or.& - noahmp401_struc(n)%noahmp401(t)%smc(1).gt.0.50) then + noahmp401_struc(n)%noahmp401(t)%smc(1).gt.0.50) then largeSM(i) = .true. endif - if(noahmp401_struc(n)%noahmp401(t)%snowh.gt.0) then + if(noahmp401_struc(n)%noahmp401(t)%snowh.gt.0) then snodens(t) = noahmp401_struc(n)%noahmp401(t)%sneqv/& noahmp401_struc(n)%noahmp401(t)%snowh else snodens(t) = 0.0 endif - + enddo do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - + c = LIS_domain(n)%tile(t)%col r = LIS_domain(n)%tile(t)%row i = LIS_domain(n)%gindex(c,r) - if(largeSM(i)) then + if(largeSM(i)) then soilm1(t) = noahmp401_struc(n)%noahmp401(t)%smc(1) soilm2(t) = noahmp401_struc(n)%noahmp401(t)%smc(2) soilm3(t) = noahmp401_struc(n)%noahmp401(t)%smc(3) @@ -160,19 +160,19 @@ subroutine noahmp401_settws(n, LSM_State) swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv endif enddo - - + + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) c = LIS_domain(n)%tile(t)%col r = LIS_domain(n)%tile(t)%row i = LIS_domain(n)%gindex(c,r) - - SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype - MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) + + SOILTYP = NOAHMP401_struc(n)%noahmp401(t)%soiltype + MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) MIN_THRESHOLD = 0.02 !SMCWLT_TABLE(SOILTYP) sm_threshold = MAX_THRESHOLD - 0.02 - + if((soilm1(t).lt.MIN_THRESHOLD.or.& soilm1(t).gt.MAX_THRESHOLD).or.& (soilm2(t).lt.MIN_THRESHOLD.or.& @@ -189,7 +189,7 @@ subroutine noahmp401_settws(n, LSM_State) (soilm2(t).ne.soilm2(i*LIS_rc%nensem(n))).and.& (soilm3(t).ne.soilm3(i*LIS_rc%nensem(n))).and.& (soilm4(t).ne.soilm4(i*LIS_rc%nensem(n))).and.& - (gws(t).ne.gws(i*LIS_rc%nensem(n)))) then + (gws(t).ne.gws(i*LIS_rc%nensem(n)))) then diffCheck(i) = .true. endif enddo @@ -199,7 +199,7 @@ subroutine noahmp401_settws(n, LSM_State) rc2 = .true. rc3 = .true. rc4 = .true. - rc5 = .true. + rc5 = .true. if(.not.ensCheck(i).and.diffCheck(i).and.(.not.largeSM(i))) then call noahmp401_tws_reorderEnsForOutliers(i,& LIS_rc%nensem(n),& @@ -239,25 +239,25 @@ subroutine noahmp401_settws(n, LSM_State) enddo endif enddo - - update_flag = .true. + + update_flag = .true. do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - - SOILTYP = noahmp401_struc(n)%noahmp401(t)%soiltype + + SOILTYP = noahmp401_struc(n)%noahmp401(t)%soiltype MAX_THRESHOLD = SMCMAX_TABLE(SOILTYP) ! MAXSMC (SOILTYP) sm_threshold = SMCMAX_TABLE(SOILTYP) - 0.02 ! MAXSMC (SOILTYP) - 0.02 - + gid = LIS_domain(n)%gindex(& LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) + delta1 = soilm1(t)-noahmp401_struc(n)%noahmp401(t)%smc(1) if(noahmp401_struc(n)%noahmp401(t)%sh2o(1)+delta1.gt.MIN_THRESHOLD .and.& noahmp401_struc(n)%noahmp401(t)%sh2o(1)+delta1.lt.& - sm_threshold) then + sm_threshold) then update_flag(gid) = update_flag(gid).and.(.true.) else update_flag(gid) = update_flag(gid).and.(.false.) @@ -266,17 +266,17 @@ subroutine noahmp401_settws(n, LSM_State) if(noahmp401_struc(n)%noahmp401(t)%sh2o(2)+delta1.gt.MIN_THRESHOLD .and.& noahmp401_struc(n)%noahmp401(t)%sh2o(2)+delta1.lt.& - sm_threshold) then + sm_threshold) then update_flag(gid) = update_flag(gid).and.(.true.) else update_flag(gid) = update_flag(gid).and.(.false.) endif delta1 = soilm3(t)-noahmp401_struc(n)%noahmp401(t)%smc(3) - + if(noahmp401_struc(n)%noahmp401(t)%sh2o(3)+delta1.gt.MIN_THRESHOLD .and.& noahmp401_struc(n)%noahmp401(t)%sh2o(3)+delta1.lt.& - sm_threshold) then + sm_threshold) then update_flag(gid) = update_flag(gid).and.(.true.) else update_flag(gid) = update_flag(gid).and.(.false.) @@ -286,46 +286,46 @@ subroutine noahmp401_settws(n, LSM_State) if(noahmp401_struc(n)%noahmp401(t)%sh2o(4)+delta1.gt.MIN_THRESHOLD .and.& noahmp401_struc(n)%noahmp401(t)%sh2o(4)+delta1.lt.& - sm_threshold) then + sm_threshold) then update_flag(gid) = update_flag(gid).and.(.true.) else update_flag(gid) = update_flag(gid).and.(.false.) - endif + endif enddo ! if(LIS_localPet.eq.387) then ! gid = LIS_domain(n)%gindex(& ! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%col,& -! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) ! print*, 'tw1 ',NOAHMP401_struc(n)%noahmp401(16068)%smc,& ! NOAHMP401_struc(n)%noahmp401(16068)%sh2o,& ! NOAHMP401_struc(n)%noahmp401(16068)%sneqv,& ! update_flag(gid) ! endif - + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) gid = LIS_domain(n)%gindex(& LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) + LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - if(update_flag(gid)) then - delta = soilm1(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(1) + if(update_flag(gid)) then + delta = soilm1(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(1) NOAHMP401_struc(n)%noahmp401(t)%smc(1) = soilm1(t) NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) = & NOAHMP401_struc(n)%noahmp401(t)%sh2o(1) + delta - - delta = soilm2(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(2) + + delta = soilm2(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(2) NOAHMP401_struc(n)%noahmp401(t)%smc(2) = soilm2(t) NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) = & NOAHMP401_struc(n)%noahmp401(t)%sh2o(2) + delta - - delta = soilm3(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(3) + + delta = soilm3(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(3) NOAHMP401_struc(n)%noahmp401(t)%smc(3) = soilm3(t) NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) = & NOAHMP401_struc(n)%noahmp401(t)%sh2o(3) + delta - - delta = soilm4(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(4) + + delta = soilm4(t) - NOAHMP401_struc(n)%noahmp401(t)%smc(4) NOAHMP401_struc(n)%noahmp401(t)%smc(4) = soilm4(t) NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) = & NOAHMP401_struc(n)%noahmp401(t)%sh2o(4) + delta @@ -335,10 +335,10 @@ subroutine noahmp401_settws(n, LSM_State) TWS2 =(soilm1(t)*NOAHMP401_struc(n)%sldpth(1)*& soilm2(t)*NOAHMP401_struc(n)%sldpth(2)*& soilm3(t)*NOAHMP401_struc(n)%sldpth(3)*& - soilm4(t)*NOAHMP401_struc(n)%sldpth(4))*& + soilm4(t)*NOAHMP401_struc(n)%sldpth(4))*& LIS_CONST_RHOFW - - + + TWS1 =(Noahmp401_struc(n)%noahmp401(t)%smc(1)*& NOAHMP401_struc(n)%sldpth(1)*& noahmp401_struc(n)%noahmp401(t)%smc(2)*& @@ -346,21 +346,21 @@ subroutine noahmp401_settws(n, LSM_State) noahmp401_struc(n)%noahmp401(t)%smc(3)*& NOAHMP401_struc(n)%sldpth(3)*& noahmp401_struc(n)%noahmp401(t)%smc(4)*& - NOAHMP401_struc(n)%sldpth(4))*& + NOAHMP401_struc(n)%sldpth(4))*& LIS_CONST_RHOFW TWSd = TWS1 - TWS2 if(NOAHMP401_struc(n)%noahmp401(t)%sneqv > 5.and.& swe(t)+TWSd.gt.0) then -!only add snow if the increment is small - if(TWSd/NOAHMP401_struc(n)%noahmp401(t)%sneqv < 0.10) then +!only add snow if the increment is small + if(TWSd/NOAHMP401_struc(n)%noahmp401(t)%sneqv < 0.10) then swe(t) = swe(t)+TWSd endif else swe(t) = 0.0 endif - + ! if(LIS_localPet.eq.387.and.t.eq.16068) then ! print*, 'swe ',LIS_localPet, t, swe(t), TWSd ! !since soil moisture update is not accepted, add this to snow @@ -368,21 +368,21 @@ subroutine noahmp401_settws(n, LSM_State) endif - + NOAHMP401_struc(n)%noahmp401(t)%wa=gws(t) enddo - + ! if(LIS_localPet.eq.387) then ! gid = LIS_domain(n)%gindex(& ! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%col,& -! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) +! LIS_surface(n,LIS_rc%lsm_index)%tile(16068)%row) ! print*, 'tw2 ',NOAHMP401_struc(n)%noahmp401(16068)%smc,& ! NOAHMP401_struc(n)%noahmp401(16068)%sh2o,& ! NOAHMP401_struc(n)%noahmp401(16068)%sneqv,& ! update_flag(gid) ! endif - + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) if(snodens(t).eq.0) then swe(t) = 0.0 @@ -390,82 +390,82 @@ subroutine noahmp401_settws(n, LSM_State) dsneqv = swe(t) - NOAHMP401_struc(n)%noahmp401(t)%sneqv snowh_new = 0 - if(snodens(t).gt.0) then + if(snodens(t).gt.0) then snowh_new = swe(t)/snodens(t) endif dsnowh = snowh_new - NOAHMP401_struc(n)%noahmp401(t)%sneqv - + call noahmp401_snow_update(n, t, dsneqv, dsnowh) enddo - - + + ! write(101,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,10E14.6)') & ! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& -! NOAHMP401_struc(n)%noahmp401(991:1000)%sneqv +! NOAHMP401_struc(n)%noahmp401(991:1000)%sneqv end subroutine noahmp401_settws subroutine noahmp401_tws_reorderEnsForOutliers(i,nensem, statevec, & minvalue,maxvalue, status) - + use LIS_coreMod - + implicit none integer :: i integer :: nensem real :: statevec(nensem) real :: minvalue,maxvalue logical :: status - + real :: minvT, maxvT, minvG, maxvG integer :: k real :: spread_total, spread_good, spread_ratio - + !Ensemble spread (total and with 'good' ensemble members minvT = 1E10 maxvT = -1E10 minvG = 1E10 maxvG = -1E10 - status = .true. - + status = .true. + do k=1,nensem - if(statevec(k).lt.minvT) then + if(statevec(k).lt.minvT) then minvT = statevec(k) endif - if(statevec(k).gt.maxvT) then + if(statevec(k).gt.maxvT) then maxvT = statevec(k) endif - if(statevec(k).gt.minvalue.and.statevec(k).lt.maxvalue) then - if(statevec(k).lt.minvG) then + if(statevec(k).gt.minvalue.and.statevec(k).lt.maxvalue) then + if(statevec(k).lt.minvG) then minvG = statevec(k) endif - if(statevec(k).gt.maxvG) then + if(statevec(k).gt.maxvG) then maxvG = statevec(k) endif endif enddo - + if(minvG.eq.1E10.and.maxvG.eq.-1E10) then !all members are unphysical. statevec = minvalue status = .false. - + else spread_total = (maxvT - minvT) spread_good = (maxvG - minvG) - + spread_ratio = spread_good/spread_total - - !rescale the ensemble - + + !rescale the ensemble + do k=1,nensem-1 statevec(k) = statevec(nensem) + & - (statevec(k) - statevec(nensem))*spread_ratio + (statevec(k) - statevec(nensem))*spread_ratio enddo endif diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 index a8f9d4c3c..97314c58f 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 @@ -13,7 +13,7 @@ ! ! !REVISION HISTORY: ! 14 Mar 2017: Sujay Kumar; Initial Specification -! 29 May 2020: Bailing Li; created for Noah-MP4.0.1 +! 29 May 2020: Bailing Li; created for Noah-MP4.0.1 ! ! !INTERFACE: subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) @@ -24,16 +24,16 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) use noahmp401_lsmMod implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n type(ESMF_State) :: LSM_State type(ESMF_State) :: LSM_Incr_State ! ! !DESCRIPTION: -! +! ! This routine assigns the soil moisture prognostic variables to noah's -! model space. -! +! model space. +! !EOP type(ESMF_Field) :: sm1Field @@ -51,7 +51,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) type(ESMF_Field) :: gwField type(ESMF_Field) :: gwIncrField real, pointer :: gws(:) - real, pointer :: gwsIncr(:) + real, pointer :: gwsIncr(:) real, pointer :: soilm1(:) real, pointer :: soilm2(:) @@ -71,7 +71,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) real :: snodmean(LIS_rc%ngrid(n)) integer :: nsnodmean(LIS_rc%ngrid(n)) - + call ESMF_StateGet(LSM_State,"Soil Moisture Layer 1",sm1Field,rc=status) call LIS_verify(status,& @@ -89,7 +89,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) call ESMF_StateGet(LSM_State,"Groundwater Storage",gwField,rc=status) call LIS_verify(status,& "ESMF_StateSet: Groundwater Storage failed in noahmp401_updatetws") - + call ESMF_StateGet(LSM_State,"SWE",sweField,rc=status) call LIS_verify(status) @@ -159,7 +159,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) ! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & ! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& ! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 - + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) soilm1(t) = soilm1(t) + soilmIncr1(t) @@ -170,14 +170,14 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) swe(t) = swe(t) + sweIncr(t) enddo -#if 0 - +#if 0 + update_flag = .true. perc_violation = 0.0 snodmean = 0.0 nsnodmean = 0 - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) + do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) gid = LIS_domain(n)%gindex(& LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) @@ -233,10 +233,10 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv end if - + enddo #endif - + ! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & ! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& ! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 From 37a3416a13359a292df9d97086e32ac4827f30cc Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Fri, 7 Apr 2023 11:02:38 -0400 Subject: [PATCH 122/328] Remove commented out code --- .../da_tws/noahmp401_updatetws.F90 | 79 ------------------- 1 file changed, 79 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 index 97314c58f..50a3df816 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 @@ -155,13 +155,7 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) call LIS_verify(status) - -! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & -! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& -! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - soilm1(t) = soilm1(t) + soilmIncr1(t) soilm2(t) = soilm2(t) + soilmIncr2(t) soilm3(t) = soilm3(t) + soilmIncr3(t) @@ -169,77 +163,4 @@ subroutine noahmp401_updatetws(n, LSM_State, LSM_Incr_State) gws(t) = gws(t) + gwsIncr(t) swe(t) = swe(t) + sweIncr(t) enddo - -#if 0 - - update_flag = .true. - perc_violation = 0.0 - snodmean = 0.0 - nsnodmean = 0 - - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - gid = LIS_domain(n)%gindex(& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - - swetmp = swe(t) + sweincr(t) - - if((swetmp.lt.0)) then - update_flag(gid) = .false. - perc_violation(gid) = perc_violation(gid) +1 - endif - - enddo - - do gid=1,LIS_rc%ngrid(n) - perc_violation(gid) = perc_violation(gid) / real(LIS_rc%nensem(n)) - enddo - -! For ensembles that are unphysical, compute the ensemble average after excluding them. This -! is done only if the majority of the ensemble members are good (>80%) - - - -! If the update is unphysical, simply set to the average of -! the good ensemble members. If all else fails, do not update. - - do t=1,LIS_rc%npatch(n,LIS_rc%lsm_index) - gid = LIS_domain(n)%gindex(& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%col,& - LIS_surface(n,LIS_rc%lsm_index)%tile(t)%row) - - - - swetmp = swe(t) + sweincr(t) - -!Use the model's snow density from the previous timestep - sndens = 0.0 - if(noahmp401_struc(n)%noahmp401(t)%snowh.gt.0) then - sndens = noahmp401_struc(n)%noahmp401(t)%sneqv/noahmp401_struc(n)%noahmp401(t)%snowh - endif - - if(update_flag(gid)) then - snod(t) = snodtmp - swe(t) = swetmp - elseif(perc_violation(gid).lt.0.2) then - if(snodtmp.lt.0.0) then ! average of the good ensemble members - snod(t) = snodmean(gid) - swe(t) = snodmean(gid)*sndens - else - snod(t) = snodtmp - swe(t) = swetmp - endif - else ! do not update - snod(t) = noahmp401_struc(n)%noahmp401(t)%snowh - swe(t) = noahmp401_struc(n)%noahmp401(t)%sneqv - end if - - enddo -#endif - -! write(*,fmt='(I4.4, 1x, I2.2, 1x, I2.2, 1x, I2.2, 1x, I2.2,1x,2E14.6)') & -! LIS_rc%yr, LIS_rc%mo, LIS_rc%da, LIS_rc%hr,LIS_rc%mn,& -! sum(swe(991:1000))/10.0, sum(sweincr(991:1000))/10.0 - - end subroutine noahmp401_updatetws From 3a1aae28513ce64b9f6eae9ecbd0213d015384a0 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 10 Apr 2023 17:48:56 -0400 Subject: [PATCH 123/328] Add license documentation for the EIS Visualization Portal files --- ...0.13-v5.0.14-v5.0.15_CC_BY_4.0_License.txt | 116 +++++++ .../Font_Awesome_Free_v5.9.0_MIT_License.txt | 29 ++ .../GIBS-leaflet_MIT_License.txt | 44 +++ .../Ionic_Framework_MIT_License.txt | 35 ++ .../Labelgun_MIT_License.txt | 21 ++ .../Leaflet_BSD_License.txt | 93 ++++++ .../MDBootstrap_v4.7.5_MIT_License.txt | 36 +++ .../RBush_MIT_License.txt | 37 +++ .../ReactiveRaven_MIT_License.txt | 38 +++ .../W3.CSS_v.15_Free_License.txt | 21 ++ .../boodstrap_v4.2.1_v4.3.1_MIT_License.txt | 49 +++ .../gmaps-labels_Free_License.txt | 17 + .../jQuery_Easing_v1.4.1_BSD_License.txt | 51 +++ .../jQuery_v3.3.1_v3.4.1_MIT_License.txt | 40 +++ .../popper_MIT_License.txt | 19 ++ .../qgis2web_GPL_License.txt | 300 ++++++++++++++++++ .../skel.js_v2.0.2_MIT_License.txt | 26 ++ .../templatedco_CC_BY_3_License.txt | 108 +++++++ 18 files changed, 1080 insertions(+) create mode 100644 lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.0.13-v5.0.14-v5.0.15_CC_BY_4.0_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.9.0_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/GIBS-leaflet_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/Ionic_Framework_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/Labelgun_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/Leaflet_BSD_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/MDBootstrap_v4.7.5_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/RBush_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/ReactiveRaven_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/W3.CSS_v.15_Free_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/boodstrap_v4.2.1_v4.3.1_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/gmaps-labels_Free_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/jQuery_Easing_v1.4.1_BSD_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/jQuery_v3.3.1_v3.4.1_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/popper_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/qgis2web_GPL_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/skel.js_v2.0.2_MIT_License.txt create mode 100644 lis/LICENSES/EIS_Visualization_Portal/templatedco_CC_BY_3_License.txt diff --git a/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.0.13-v5.0.14-v5.0.15_CC_BY_4.0_License.txt b/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.0.13-v5.0.14-v5.0.15_CC_BY_4.0_License.txt new file mode 100644 index 000000000..e3ce215b6 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.0.13-v5.0.14-v5.0.15_CC_BY_4.0_License.txt @@ -0,0 +1,116 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Font Awesome Free + +POC: + +https://fontawesome.com +https://github.com/FortAwesome/Font-Awesome + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/icons.css +lis/utils/eis_visualization_portal/eis-freshwater/css/icons.css +lis/utils/eis_visualization_portal/eis-sealevel/css/icons.css +lis/utils/eis_visualization_portal/eis-toplanding/css/all.css +lis/utils/eis_visualization_portal/eis-toplanding/css/animate.min.css +lis/utils/eis_visualization_portal/eis-toplanding/css/application.css + +License: + +Creative Commons Attribution 4.0 International Public License + +By exercising the Licensed Rights (defined below), You accept and agree to be bound by the terms and conditions of this Creative Commons Attribution 4.0 International Public License ("Public License"). To the extent this Public License may be interpreted as a contract, You are granted the Licensed Rights in consideration of Your acceptance of these terms and conditions, and the Licensor grants You such rights in consideration of benefits the Licensor receives from making the Licensed Material available under these terms and conditions. + +Section 1 – Definitions. + + Adapted Material means material subject to Copyright and Similar Rights that is derived from or based upon the Licensed Material and in which the Licensed Material is translated, altered, arranged, transformed, or otherwise modified in a manner requiring permission under the Copyright and Similar Rights held by the Licensor. For purposes of this Public License, where the Licensed Material is a musical work, performance, or sound recording, Adapted Material is always produced where the Licensed Material is synched in timed relation with a moving image. + Adapter's License means the license You apply to Your Copyright and Similar Rights in Your contributions to Adapted Material in accordance with the terms and conditions of this Public License. + Copyright and Similar Rights means copyright and/or similar rights closely related to copyright including, without limitation, performance, broadcast, sound recording, and Sui Generis Database Rights, without regard to how the rights are labeled or categorized. For purposes of this Public License, the rights specified in Section 2(b)(1)-(2) are not Copyright and Similar Rights. + Effective Technological Measures means those measures that, in the absence of proper authority, may not be circumvented under laws fulfilling obligations under Article 11 of the WIPO Copyright Treaty adopted on December 20, 1996, and/or similar international agreements. + Exceptions and Limitations means fair use, fair dealing, and/or any other exception or limitation to Copyright and Similar Rights that applies to Your use of the Licensed Material. + Licensed Material means the artistic or literary work, database, or other material to which the Licensor applied this Public License. + Licensed Rights means the rights granted to You subject to the terms and conditions of this Public License, which are limited to all Copyright and Similar Rights that apply to Your use of the Licensed Material and that the Licensor has authority to license. + Licensor means the individual(s) or entity(ies) granting rights under this Public License. + Share means to provide material to the public by any means or process that requires permission under the Licensed Rights, such as reproduction, public display, public performance, distribution, dissemination, communication, or importation, and to make material available to the public including in ways that members of the public may access the material from a place and at a time individually chosen by them. + Sui Generis Database Rights means rights other than copyright resulting from Directive 96/9/EC of the European Parliament and of the Council of 11 March 1996 on the legal protection of databases, as amended and/or succeeded, as well as other essentially equivalent rights anywhere in the world. + You means the individual or entity exercising the Licensed Rights under this Public License. Your has a corresponding meaning. + +Section 2 – Scope. + + License grant. + Subject to the terms and conditions of this Public License, the Licensor hereby grants You a worldwide, royalty-free, non-sublicensable, non-exclusive, irrevocable license to exercise the Licensed Rights in the Licensed Material to: + reproduce and Share the Licensed Material, in whole or in part; and + produce, reproduce, and Share Adapted Material. + Exceptions and Limitations. For the avoidance of doubt, where Exceptions and Limitations apply to Your use, this Public License does not apply, and You do not need to comply with its terms and conditions. + Term. The term of this Public License is specified in Section 6(a). + Media and formats; technical modifications allowed. The Licensor authorizes You to exercise the Licensed Rights in all media and formats whether now known or hereafter created, and to make technical modifications necessary to do so. The Licensor waives and/or agrees not to assert any right or authority to forbid You from making technical modifications necessary to exercise the Licensed Rights, including technical modifications necessary to circumvent Effective Technological Measures. For purposes of this Public License, simply making modifications authorized by this Section 2(a)(4) never produces Adapted Material. + Downstream recipients. + Offer from the Licensor – Licensed Material. Every recipient of the Licensed Material automatically receives an offer from the Licensor to exercise the Licensed Rights under the terms and conditions of this Public License. + No downstream restrictions. You may not offer or impose any additional or different terms or conditions on, or apply any Effective Technological Measures to, the Licensed Material if doing so restricts exercise of the Licensed Rights by any recipient of the Licensed Material. + No endorsement. Nothing in this Public License constitutes or may be construed as permission to assert or imply that You are, or that Your use of the Licensed Material is, connected with, or sponsored, endorsed, or granted official status by, the Licensor or others designated to receive attribution as provided in Section 3(a)(1)(A)(i). + + Other rights. + Moral rights, such as the right of integrity, are not licensed under this Public License, nor are publicity, privacy, and/or other similar personality rights; however, to the extent possible, the Licensor waives and/or agrees not to assert any such rights held by the Licensor to the limited extent necessary to allow You to exercise the Licensed Rights, but not otherwise. + Patent and trademark rights are not licensed under this Public License. + To the extent possible, the Licensor waives any right to collect royalties from You for the exercise of the Licensed Rights, whether directly or through a collecting society under any voluntary or waivable statutory or compulsory licensing scheme. In all other cases the Licensor expressly reserves any right to collect such royalties. + +Section 3 – License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the following conditions. + + Attribution. + + If You Share the Licensed Material (including in modified form), You must: + retain the following if it is supplied by the Licensor with the Licensed Material: + identification of the creator(s) of the Licensed Material and any others designated to receive attribution, in any reasonable manner requested by the Licensor (including by pseudonym if designated); + a copyright notice; + a notice that refers to this Public License; + a notice that refers to the disclaimer of warranties; + a URI or hyperlink to the Licensed Material to the extent reasonably practicable; + indicate if You modified the Licensed Material and retain an indication of any previous modifications; and + indicate the Licensed Material is licensed under this Public License, and include the text of, or the URI or hyperlink to, this Public License. + You may satisfy the conditions in Section 3(a)(1) in any reasonable manner based on the medium, means, and context in which You Share the Licensed Material. For example, it may be reasonable to satisfy the conditions by providing a URI or hyperlink to a resource that includes the required information. + If requested by the Licensor, You must remove any of the information required by Section 3(a)(1)(A) to the extent reasonably practicable. + If You Share Adapted Material You produce, the Adapter's License You apply must not prevent recipients of the Adapted Material from complying with this Public License. + +Section 4 – Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that apply to Your use of the Licensed Material: + + for the avoidance of doubt, Section 2(a)(1) grants You the right to extract, reuse, reproduce, and Share all or a substantial portion of the contents of the database; + if You include all or a substantial portion of the database contents in a database in which You have Sui Generis Database Rights, then the database in which You have Sui Generis Database Rights (but not its individual contents) is Adapted Material; and + You must comply with the conditions in Section 3(a) if You Share all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not replace Your obligations under this Public License where the Licensed Rights include other Copyright and Similar Rights. + +Section 5 – Disclaimer of Warranties and Limitation of Liability. + + Unless otherwise separately undertaken by the Licensor, to the extent possible, the Licensor offers the Licensed Material as-is and as-available, and makes no representations or warranties of any kind concerning the Licensed Material, whether express, implied, statutory, or other. This includes, without limitation, warranties of title, merchantability, fitness for a particular purpose, non-infringement, absence of latent or other defects, accuracy, or the presence or absence of errors, whether or not known or discoverable. Where disclaimers of warranties are not allowed in full or in part, this disclaimer may not apply to You. + To the extent possible, in no event will the Licensor be liable to You on any legal theory (including, without limitation, negligence) or otherwise for any direct, special, indirect, incidental, consequential, punitive, exemplary, or other losses, costs, expenses, or damages arising out of this Public License or use of the Licensed Material, even if the Licensor has been advised of the possibility of such losses, costs, expenses, or damages. Where a limitation of liability is not allowed in full or in part, this limitation may not apply to You. + + The disclaimer of warranties and limitation of liability provided above shall be interpreted in a manner that, to the extent possible, most closely approximates an absolute disclaimer and waiver of all liability. + +Section 6 – Term and Termination. + + This Public License applies for the term of the Copyright and Similar Rights licensed here. However, if You fail to comply with this Public License, then Your rights under this Public License terminate automatically. + + Where Your right to use the Licensed Material has terminated under Section 6(a), it reinstates: + automatically as of the date the violation is cured, provided it is cured within 30 days of Your discovery of the violation; or + upon express reinstatement by the Licensor. + For the avoidance of doubt, this Section 6(b) does not affect any right the Licensor may have to seek remedies for Your violations of this Public License. + For the avoidance of doubt, the Licensor may also offer the Licensed Material under separate terms or conditions or stop distributing the Licensed Material at any time; however, doing so will not terminate this Public License. + Sections 1, 5, 6, 7, and 8 survive termination of this Public License. + +Section 7 – Other Terms and Conditions. + + The Licensor shall not be bound by any additional or different terms or conditions communicated by You unless expressly agreed. + Any arrangements, understandings, or agreements regarding the Licensed Material not stated herein are separate from and independent of the terms and conditions of this Public License. + +Section 8 – Interpretation. + + For the avoidance of doubt, this Public License does not, and shall not be interpreted to, reduce, limit, restrict, or impose conditions on any use of the Licensed Material that could lawfully be made without permission under this Public License. + To the extent possible, if any provision of this Public License is deemed unenforceable, it shall be automatically reformed to the minimum extent necessary to make it enforceable. If the provision cannot be reformed, it shall be severed from this Public License without affecting the enforceability of the remaining terms and conditions. + No term or condition of this Public License will be waived and no failure to comply consented to unless expressly agreed to by the Licensor. + Nothing in this Public License constitutes or may be interpreted as a limitation upon, or waiver of, any privileges and immunities that apply to the Licensor or You, including from the legal processes of any jurisdiction or authority. + diff --git a/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.9.0_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.9.0_MIT_License.txt new file mode 100644 index 000000000..f40ad92c9 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/Font_Awesome_Free_v5.9.0_MIT_License.txt @@ -0,0 +1,29 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Font Awesome Free + +POC: + +https://fontawesome.com +https://github.com/FortAwesome/Font-Awesome + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/all.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/all.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/brands.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/brands.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/fontawesome.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/fontawesome.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/regular.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/regular.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/solid.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/solid.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/svg-with-js.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/svg-with-js.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/v4-shims.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/fontawesome-free/css/v4-shims.min.css + +License: + +MIT License (https://opensource.org/licenses/MIT) diff --git a/lis/LICENSES/EIS_Visualization_Portal/GIBS-leaflet_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/GIBS-leaflet_MIT_License.txt new file mode 100644 index 000000000..a19135c20 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/GIBS-leaflet_MIT_License.txt @@ -0,0 +1,44 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: gcoro/GIBS-leaflet + +POC: + +https://github.com/gcoro/gibs-leaflet + +Files: + +lis/utils/eis_visualization_portal/eis-fire/js/GIBSLayer.js +lis/utils/eis_visualization_portal/eis-fire/js/GIBSMetadata.js +lis/utils/eis_visualization_portal/eis-fire/js/GeoMixerGIBSLayer.js +lis/utils/eis_visualization_portal/eis-freshwater/js/GIBSLayer.js +lis/utils/eis_visualization_portal/eis-freshwater/js/GIBSMetadata.js +lis/utils/eis_visualization_portal/eis-freshwater/js/GeoMixerGIBSLayer.js +lis/utils/eis_visualization_portal/eis-sealevel/js/GIBSLayer.js +lis/utils/eis_visualization_portal/eis-sealevel/js/GIBSMetadata.js +lis/utils/eis_visualization_portal/eis-sealevel/js/GeoMixerGIBSLayer.js + +License: + +MIT License + +Copyright (c) 2018 Giulia + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/lis/LICENSES/EIS_Visualization_Portal/Ionic_Framework_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/Ionic_Framework_MIT_License.txt new file mode 100644 index 000000000..2f01b8f6e --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/Ionic_Framework_MIT_License.txt @@ -0,0 +1,35 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Ionic Framework + +POC: + +https://github.com/ionic-team/ionicons + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/css/ionicons.min.css + +License: + +The MIT License (MIT) + +Copyright (c) 2015-present Ionic (http://ionic.io/) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/Labelgun_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/Labelgun_MIT_License.txt new file mode 100644 index 000000000..0c0a1a8ff --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/Labelgun_MIT_License.txt @@ -0,0 +1,21 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Geovation/Labelgun + + +POC: + +https://github.com/Geovation/labelgun + +Files: + +lis/utils/eis_visualization_portal/eis-fire/js/labelgun.min.js +lis/utils/eis_visualization_portal/eis-fire/js/labels.js +lis/utils/eis_visualization_portal/eis-freshwater/js/labelgun.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/labels.js +lis/utils/eis_visualization_portal/eis-sealevel/js/labelgun.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/labels.js + +License: + +MIT License (https://opensource.org/licenses/MIT) diff --git a/lis/LICENSES/EIS_Visualization_Portal/Leaflet_BSD_License.txt b/lis/LICENSES/EIS_Visualization_Portal/Leaflet_BSD_License.txt new file mode 100644 index 000000000..ff4eae7f9 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/Leaflet_BSD_License.txt @@ -0,0 +1,93 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Leaflet + +POC: + +https://leafletjs.com +https://github.com/Leaflet/Leaflet + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/styledLayerControl.css +lis/utils/eis_visualization_portal/eis-fire/js/Autolinker.min.js +lis/utils/eis_visualization_portal/eis-fire/js/Control.Opacity.js +lis/utils/eis_visualization_portal/eis-fire/js/OSMBuildings-Leaflet.js +lis/utils/eis_visualization_portal/eis-fire/js/createLayersList.js +lis/utils/eis_visualization_portal/eis-fire/js/multi-style-layer.js +lis/utils/eis_visualization_portal/eis-fire/js/slidercontrol.js +lis/utils/eis_visualization_portal/eis-fire/js/spin.min.js +lis/utils/eis_visualization_portal/eis-fire/js/styledLayerControl.js +lis/utils/eis_visualization_portal/eis-freshwater/css/L.Control.Opacity.css +lis/utils/eis_visualization_portal/eis-freshwater/css/Leaflet.Coordinates-0.1.3.css +lis/utils/eis_visualization_portal/eis-freshwater/css/MarkerCluster.Default.css +lis/utils/eis_visualization_portal/eis-freshwater/css/MarkerCluster.css +lis/utils/eis_visualization_portal/eis-freshwater/css/leaflet-panel-layers.css +lis/utils/eis_visualization_portal/eis-freshwater/css/leaflet-search.css +lis/utils/eis_visualization_portal/eis-freshwater/css/leaflet.css +lis/utils/eis_visualization_portal/eis-freshwater/css/leaflet.fullscreen.css +lis/utils/eis_visualization_portal/eis-freshwater/css/styledLayerControl.css +lis/utils/eis_visualization_portal/eis-freshwater/js/Autolinker.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/Control.Opacity.js +lis/utils/eis_visualization_portal/eis-freshwater/js/L.Control.HtmlLegend.js +lis/utils/eis_visualization_portal/eis-freshwater/js/L.Control.Opacity.js +lis/utils/eis_visualization_portal/eis-freshwater/js/Leaflet.Coordinates-0.1.3.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/Leaflet.VectorGrid.js +lis/utils/eis_visualization_portal/eis-freshwater/js/OSMBuildings-Leaflet.js +lis/utils/eis_visualization_portal/eis-freshwater/js/createLayersList.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-hash.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-heat.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-search.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-side-by-side.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-side-by-side_overlays.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-svg-shape-markers.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet-tilelayer-wmts.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.canvaslayer.field.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.markercluster.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.pattern.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.rotatedMarker.js +lis/utils/eis_visualization_portal/eis-freshwater/js/leaflet.wms.js +lis/utils/eis_visualization_portal/eis-freshwater/js/multi-style-layer.js +lis/utils/eis_visualization_portal/eis-freshwater/js/slidercontrol.js +lis/utils/eis_visualization_portal/eis-freshwater/js/spin.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/styledLayerControl.js +lis/utils/eis_visualization_portal/eis-sealevel/css/styledLayerControl.css +lis/utils/eis_visualization_portal/eis-sealevel/js/Autolinker.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/Control.Opacity.js +lis/utils/eis_visualization_portal/eis-sealevel/js/OSMBuildings-Leaflet.js +lis/utils/eis_visualization_portal/eis-sealevel/js/createLayersList.js +lis/utils/eis_visualization_portal/eis-sealevel/js/multi-style-layer.js +lis/utils/eis_visualization_portal/eis-sealevel/js/slidercontrol.js +lis/utils/eis_visualization_portal/eis-sealevel/js/spin.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/styledLayerControl.js + +License: + +BSD 2-Clause License + +Copyright (c) 2010-2023, Volodymyr Agafonkin +Copyright (c) 2010-2011, CloudMade +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + diff --git a/lis/LICENSES/EIS_Visualization_Portal/MDBootstrap_v4.7.5_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/MDBootstrap_v4.7.5_MIT_License.txt new file mode 100644 index 000000000..786aace1f --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/MDBootstrap_v4.7.5_MIT_License.txt @@ -0,0 +1,36 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: MDBootstrap + +POC: + +https://mdbootstrap.com/ +https://github.com/mdbootstrap/mdb-ui-kit + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/css/mdb.css + +License: + +MIT License + +Copyright (c) 2021 MDBootstrap + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/RBush_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/RBush_MIT_License.txt new file mode 100644 index 000000000..24c89db6d --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/RBush_MIT_License.txt @@ -0,0 +1,37 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: mourner/RBush + +POC: + +https://github.com/mourner/rbush + +Files: + +lis/utils/eis_visualization_portal/eis-fire/js/rbush.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/rbush.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/rbush.min.js + +License: + +MIT License + +Copyright (c) 2016 Vladimir Agafonkin + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/ReactiveRaven_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/ReactiveRaven_MIT_License.txt new file mode 100644 index 000000000..f9da0ce91 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/ReactiveRaven_MIT_License.txt @@ -0,0 +1,38 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: ReactiveRaven/jqBootstrapValidation + +POC: + +https://reactiveraven.github.io/jqBootstrapValidation +https://github.com/ReactiveRaven/jqBootstrapValidation + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/js/jqBootstrapValidation.js + +License: + +Copyright (c) 2013 David Godfrey + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. + diff --git a/lis/LICENSES/EIS_Visualization_Portal/W3.CSS_v.15_Free_License.txt b/lis/LICENSES/EIS_Visualization_Portal/W3.CSS_v.15_Free_License.txt new file mode 100644 index 000000000..535b2227a --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/W3.CSS_v.15_Free_License.txt @@ -0,0 +1,21 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: W3.CSS + +POC: + +https://www.w3schools.com/w3css/default.asp + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/w3.css +lis/utils/eis_visualization_portal/eis-freshwater/css/w3.css +lis/utils/eis_visualization_portal/eis-sealevel/css/w3.css + +License: + +From website https://www.w3schools.com/w3css/default.asp: + +W3.CSS is Free + +W3.CSS is free to use. No license is necessary. diff --git a/lis/LICENSES/EIS_Visualization_Portal/boodstrap_v4.2.1_v4.3.1_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/boodstrap_v4.2.1_v4.3.1_MIT_License.txt new file mode 100644 index 000000000..82e38d11e --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/boodstrap_v4.2.1_v4.3.1_MIT_License.txt @@ -0,0 +1,49 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Bootstap + +POC: + +https://getbootstrap.com +https://github.com/twbs/bootstrap + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/Control.Opacity.css +lis/utils/eis_visualization_portal/eis-freshwater/css/Control.Opacity.css +lis/utils/eis_visualization_portal/eis-sealevel/css/Control.Opacity.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap-grid.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap-grid.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap-reboot.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap-reboot.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/css/bootstrap.min.css +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/js/bootstrap.bundle.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/js/bootstrap.bundle.min.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/js/bootstrap.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/bootstrap/js/bootstrap.min.js +lis/utils/eis_visualization_portal/eis-toplanding/js/jqBootstrapValidation.js + +License: + +The MIT License (MIT) + +Copyright (c) 2011-2023 The Bootstrap Authors + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/gmaps-labels_Free_License.txt b/lis/LICENSES/EIS_Visualization_Portal/gmaps-labels_Free_License.txt new file mode 100644 index 000000000..197703fc4 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/gmaps-labels_Free_License.txt @@ -0,0 +1,17 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: iamcal/gmaps-labels + +POC: + +https://github.com/iamcal/gmaps-labels + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/gmaps-labels.css +lis/utils/eis_visualization_portal/eis-freshwater/css/gmaps-labels.css +lis/utils/eis_visualization_portal/eis-sealevel/css/gmaps-labels.css + +License: + +None provided. This is a public GitHub repository. diff --git a/lis/LICENSES/EIS_Visualization_Portal/jQuery_Easing_v1.4.1_BSD_License.txt b/lis/LICENSES/EIS_Visualization_Portal/jQuery_Easing_v1.4.1_BSD_License.txt new file mode 100644 index 000000000..8c85a0a16 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/jQuery_Easing_v1.4.1_BSD_License.txt @@ -0,0 +1,51 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: gdsmith/jquery.easing + +POC: + +http://gsgd.co.uk/sandbox/jquery/easing +https://github.com/gdsmith/jquery.easing + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery-easing/jquery.easing.compatibility.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery-easing/jquery.easing.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery-easing/jquery.easing.min.js + +License: + +jQuery Easing - http://gsgd.co.uk/sandbox/jquery/easing/ + +Uses the built in easing capabilities added In jQuery 1.1 +to offer multiple easing options + +TERMS OF USE - jQuery Easing + +Open source under the 3-Clause BSD License. + +Copyright © 2008 George McGinley Smith +All rights reserved. + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: + +Redistributions of source code must retain the above copyright notice, this list of +conditions and the following disclaimer. + +Redistributions in binary form must reproduce the above copyright notice, this list +of conditions and the following disclaimer in the documentation and/or other +materials provided with the distribution. Neither the name of the author nor the +names of contributors may be used to endorse or promote products derived from this +software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. +IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, +INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT +NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR +PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/jQuery_v3.3.1_v3.4.1_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/jQuery_v3.3.1_v3.4.1_MIT_License.txt new file mode 100644 index 000000000..be4727510 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/jQuery_v3.3.1_v3.4.1_MIT_License.txt @@ -0,0 +1,40 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: jQuery + +POC: + +https://openjsf.org +https://github.com/jquery/jquery + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/js/jquery-3.js +lis/utils/eis_visualization_portal/eis-toplanding/js/mdb.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery/jquery.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery/jquery.min.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery/jquery.slim.js +lis/utils/eis_visualization_portal/eis-toplanding/vendor/jquery/jquery.slim.min.js + +License: + +Copyright OpenJS Foundation and other contributors, https://openjsf.org/ + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/popper_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/popper_MIT_License.txt new file mode 100644 index 000000000..906ad6186 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/popper_MIT_License.txt @@ -0,0 +1,19 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: Federico Zivolo / floating-ui/floating-ui / mdbootstrap/mdb-ui-kit + +POC: + +https://popper.js.org +https://github.com/floating-ui/floating-ui +https://github.com/mdbootstrap/mdb-ui-kit +https://github.com/FezVrasta + +Files: + +lis/utils/eis_visualization_portal/eis-toplanding/js/popper.js +../..//utils/eis_visualization_portal/eis-toplanding/js/popper.js + +License: + +Distributed under the MIT License (license terms are at http://opensource.org/licenses/MIT). diff --git a/lis/LICENSES/EIS_Visualization_Portal/qgis2web_GPL_License.txt b/lis/LICENSES/EIS_Visualization_Portal/qgis2web_GPL_License.txt new file mode 100644 index 000000000..78ff94e50 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/qgis2web_GPL_License.txt @@ -0,0 +1,300 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: tomchadwin/qgis2web + +POC: + +https://github.com/tomchadwin/qgis2web + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/qgis2web.css +lis/utils/eis_visualization_portal/eis-fire/js/qgis2web_expressions.js +lis/utils/eis_visualization_portal/eis-freshwater/css/qgis2web.css +lis/utils/eis_visualization_portal/eis-freshwater/js/qgis2web_expressions.js +lis/utils/eis_visualization_portal/eis-sealevel/css/qgis2web.css +lis/utils/eis_visualization_portal/eis-sealevel/js/qgis2web_expressions.js + +License: + +GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Lesser General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + diff --git a/lis/LICENSES/EIS_Visualization_Portal/skel.js_v2.0.2_MIT_License.txt b/lis/LICENSES/EIS_Visualization_Portal/skel.js_v2.0.2_MIT_License.txt new file mode 100644 index 000000000..074477af9 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/skel.js_v2.0.2_MIT_License.txt @@ -0,0 +1,26 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: ajlkn/skel + +POC: + +https://github.com/ajlkn/skel + +Files: + +lis/utils/eis_visualization_portal/eis-fire/js/skel-layers.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/skel-layers.min.js +lis/utils/eis_visualization_portal/eis-fire/js/skel.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/skel.min.js + +License: + +Skel, Layout, Viewport, and Skel.scss are released under the MIT license. + +Copyright (c) skel.io + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/lis/LICENSES/EIS_Visualization_Portal/templatedco_CC_BY_3_License.txt b/lis/LICENSES/EIS_Visualization_Portal/templatedco_CC_BY_3_License.txt new file mode 100644 index 000000000..75122ea64 --- /dev/null +++ b/lis/LICENSES/EIS_Visualization_Portal/templatedco_CC_BY_3_License.txt @@ -0,0 +1,108 @@ +Component name(s): EIS Freshwater Visualization Portal support files + +Contributing organization/individuals: templated.co + +POC: + +templated.co + +Files: + +lis/utils/eis_visualization_portal/eis-fire/css/sidebar-main.css +lis/utils/eis_visualization_portal/eis-fire/css/sidebar-themes.css +lis/utils/eis_visualization_portal/eis-fire/css/skel.css +lis/utils/eis_visualization_portal/eis-fire/css/style-large.css +lis/utils/eis_visualization_portal/eis-fire/css/style-medium.css +lis/utils/eis_visualization_portal/eis-fire/css/style-xlarge.css +lis/utils/eis_visualization_portal/eis-fire/css/style-xsmall.css +lis/utils/eis_visualization_portal/eis-fire/css/style.css +lis/utils/eis_visualization_portal/eis-fire/css/style__.css +lis/utils/eis_visualization_portal/eis-fire/js/init.js +lis/utils/eis_visualization_portal/eis-fire/js/jquery.min.js +lis/utils/eis_visualization_portal/eis-fire/js/sidebar-main.js +lis/utils/eis_visualization_portal/eis-freshwater/css/sidebar-main.css +lis/utils/eis_visualization_portal/eis-freshwater/css/sidebar-themes.css +lis/utils/eis_visualization_portal/eis-freshwater/css/skel.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style-large.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style-medium.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style-xlarge.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style-xsmall.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style.css +lis/utils/eis_visualization_portal/eis-freshwater/css/style__.css +lis/utils/eis_visualization_portal/eis-freshwater/js/init.js +lis/utils/eis_visualization_portal/eis-freshwater/js/jquery.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/sidebar-main.js +lis/utils/eis_visualization_portal/eis-freshwater/js/skel-layers.min.js +lis/utils/eis_visualization_portal/eis-freshwater/js/skel.min.js +lis/utils/eis_visualization_portal/eis-sealevel/css/sidebar-main.css +lis/utils/eis_visualization_portal/eis-sealevel/css/sidebar-themes.css +lis/utils/eis_visualization_portal/eis-sealevel/css/skel.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style-large.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style-medium.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style-xlarge.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style-xsmall.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style.css +lis/utils/eis_visualization_portal/eis-sealevel/css/style__.css +lis/utils/eis_visualization_portal/eis-sealevel/js/init.js +lis/utils/eis_visualization_portal/eis-sealevel/js/jquery.min.js +lis/utils/eis_visualization_portal/eis-sealevel/js/sidebar-main.js + +License: + +THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED. + +BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO BE BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE CONSIDERED TO BE A CONTRACT, THE LICENSOR GRANTS YOU THE RIGHTS CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS. + +1. Definitions + + "Adaptation" means a work based upon the Work, or upon the Work and other pre-existing works, such as a translation, adaptation, derivative work, arrangement of music or other alterations of a literary or artistic work, or phonogram or performance and includes cinematographic adaptations or any other form in which the Work may be recast, transformed, or adapted including in any form recognizably derived from the original, except that a work that constitutes a Collection will not be considered an Adaptation for the purpose of this License. For the avoidance of doubt, where the Work is a musical work, performance or phonogram, the synchronization of the Work in timed-relation with a moving image ("synching") will be considered an Adaptation for the purpose of this License. + "Collection" means a collection of literary or artistic works, such as encyclopedias and anthologies, or performances, phonograms or broadcasts, or other works or subject matter other than works listed in Section 1(f) below, which, by reason of the selection and arrangement of their contents, constitute intellectual creations, in which the Work is included in its entirety in unmodified form along with one or more other contributions, each constituting separate and independent works in themselves, which together are assembled into a collective whole. A work that constitutes a Collection will not be considered an Adaptation (as defined above) for the purposes of this License. + "Distribute" means to make available to the public the original and copies of the Work or Adaptation, as appropriate, through sale or other transfer of ownership. + "Licensor" means the individual, individuals, entity or entities that offer(s) the Work under the terms of this License. + "Original Author" means, in the case of a literary or artistic work, the individual, individuals, entity or entities who created the Work or if no individual or entity can be identified, the publisher; and in addition (i) in the case of a performance the actors, singers, musicians, dancers, and other persons who act, sing, deliver, declaim, play in, interpret or otherwise perform literary or artistic works or expressions of folklore; (ii) in the case of a phonogram the producer being the person or legal entity who first fixes the sounds of a performance or other sounds; and, (iii) in the case of broadcasts, the organization that transmits the broadcast. + "Work" means the literary and/or artistic work offered under the terms of this License including without limitation any production in the literary, scientific and artistic domain, whatever may be the mode or form of its expression including digital form, such as a book, pamphlet and other writing; a lecture, address, sermon or other work of the same nature; a dramatic or dramatico-musical work; a choreographic work or entertainment in dumb show; a musical composition with or without words; a cinematographic work to which are assimilated works expressed by a process analogous to cinematography; a work of drawing, painting, architecture, sculpture, engraving or lithography; a photographic work to which are assimilated works expressed by a process analogous to photography; a work of applied art; an illustration, map, plan, sketch or three-dimensional work relative to geography, topography, architecture or science; a performance; a broadcast; a phonogram; a compilation of data to the extent it is protected as a copyrightable work; or a work performed by a variety or circus performer to the extent it is not otherwise considered a literary or artistic work. + "You" means an individual or entity exercising rights under this License who has not previously violated the terms of this License with respect to the Work, or who has received express permission from the Licensor to exercise rights under this License despite a previous violation. + "Publicly Perform" means to perform public recitations of the Work and to communicate to the public those public recitations, by any means or process, including by wire or wireless means or public digital performances; to make available to the public Works in such a way that members of the public may access these Works from a place and at a place individually chosen by them; to perform the Work to the public by any means or process and the communication to the public of the performances of the Work, including by public digital performance; to broadcast and rebroadcast the Work by any means including signs, sounds or images. + "Reproduce" means to make copies of the Work by any means including without limitation by sound or visual recordings and the right of fixation and reproducing fixations of the Work, including storage of a protected performance or phonogram in digital form or other electronic medium. + +2. Fair Dealing Rights. Nothing in this License is intended to reduce, limit, or restrict any uses free from copyright or rights arising from limitations or exceptions that are provided for in connection with the copyright protection under copyright law or other applicable laws. + +3. License Grant. Subject to the terms and conditions of this License, Licensor hereby grants You a worldwide, royalty-free, non-exclusive, perpetual (for the duration of the applicable copyright) license to exercise the rights in the Work as stated below: + + to Reproduce the Work, to incorporate the Work into one or more Collections, and to Reproduce the Work as incorporated in the Collections; + to create and Reproduce Adaptations provided that any such Adaptation, including any translation in any medium, takes reasonable steps to clearly label, demarcate or otherwise identify that changes were made to the original Work. For example, a translation could be marked "The original work was translated from English to Spanish," or a modification could indicate "The original work has been modified."; + to Distribute and Publicly Perform the Work including as incorporated in Collections; and, + to Distribute and Publicly Perform Adaptations. + + For the avoidance of doubt: + Non-waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme cannot be waived, the Licensor reserves the exclusive right to collect such royalties for any exercise by You of the rights granted under this License; + Waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme can be waived, the Licensor waives the exclusive right to collect such royalties for any exercise by You of the rights granted under this License; and, + Voluntary License Schemes. The Licensor waives the right to collect royalties, whether individually or, in the event that the Licensor is a member of a collecting society that administers voluntary licensing schemes, via that society, from any exercise by You of the rights granted under this License. + +The above rights may be exercised in all media and formats whether now known or hereafter devised. The above rights include the right to make such modifications as are technically necessary to exercise the rights in other media and formats. Subject to Section 8(f), all rights not expressly granted by Licensor are hereby reserved. + +4. Restrictions. The license granted in Section 3 above is expressly made subject to and limited by the following restrictions: + + You may Distribute or Publicly Perform the Work only under the terms of this License. You must include a copy of, or the Uniform Resource Identifier (URI) for, this License with every copy of the Work You Distribute or Publicly Perform. You may not offer or impose any terms on the Work that restrict the terms of this License or the ability of the recipient of the Work to exercise the rights granted to that recipient under the terms of the License. You may not sublicense the Work. You must keep intact all notices that refer to this License and to the disclaimer of warranties with every copy of the Work You Distribute or Publicly Perform. When You Distribute or Publicly Perform the Work, You may not impose any effective technological measures on the Work that restrict the ability of a recipient of the Work from You to exercise the rights granted to that recipient under the terms of the License. This Section 4(a) applies to the Work as incorporated in a Collection, but this does not require the Collection apart from the Work itself to be made subject to the terms of this License. If You create a Collection, upon notice from any Licensor You must, to the extent practicable, remove from the Collection any credit as required by Section 4(b), as requested. If You create an Adaptation, upon notice from any Licensor You must, to the extent practicable, remove from the Adaptation any credit as required by Section 4(b), as requested. + If You Distribute, or Publicly Perform the Work or any Adaptations or Collections, You must, unless a request has been made pursuant to Section 4(a), keep intact all copyright notices for the Work and provide, reasonable to the medium or means You are utilizing: (i) the name of the Original Author (or pseudonym, if applicable) if supplied, and/or if the Original Author and/or Licensor designate another party or parties (e.g., a sponsor institute, publishing entity, journal) for attribution ("Attribution Parties") in Licensor's copyright notice, terms of service or by other reasonable means, the name of such party or parties; (ii) the title of the Work if supplied; (iii) to the extent reasonably practicable, the URI, if any, that Licensor specifies to be associated with the Work, unless such URI does not refer to the copyright notice or licensing information for the Work; and (iv) , consistent with Section 3(b), in the case of an Adaptation, a credit identifying the use of the Work in the Adaptation (e.g., "French translation of the Work by Original Author," or "Screenplay based on original Work by Original Author"). The credit required by this Section 4 (b) may be implemented in any reasonable manner; provided, however, that in the case of a Adaptation or Collection, at a minimum such credit will appear, if a credit for all contributing authors of the Adaptation or Collection appears, then as part of these credits and in a manner at least as prominent as the credits for the other contributing authors. For the avoidance of doubt, You may only use the credit required by this Section for the purpose of attribution in the manner set out above and, by exercising Your rights under this License, You may not implicitly or explicitly assert or imply any connection with, sponsorship or endorsement by the Original Author, Licensor and/or Attribution Parties, as appropriate, of You or Your use of the Work, without the separate, express prior written permission of the Original Author, Licensor and/or Attribution Parties. + Except as otherwise agreed in writing by the Licensor or as may be otherwise permitted by applicable law, if You Reproduce, Distribute or Publicly Perform the Work either by itself or as part of any Adaptations or Collections, You must not distort, mutilate, modify or take other derogatory action in relation to the Work which would be prejudicial to the Original Author's honor or reputation. Licensor agrees that in those jurisdictions (e.g. Japan), in which any exercise of the right granted in Section 3(b) of this License (the right to make Adaptations) would be deemed to be a distortion, mutilation, modification or other derogatory action prejudicial to the Original Author's honor and reputation, the Licensor will waive or not assert, as appropriate, this Section, to the fullest extent permitted by the applicable national law, to enable You to reasonably exercise Your right under Section 3(b) of this License (right to make Adaptations) but not otherwise. + +5. Representations, Warranties and Disclaimer + +UNLESS OTHERWISE MUTUALLY AGREED TO BY THE PARTIES IN WRITING, LICENSOR OFFERS THE WORK AS-IS AND MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND CONCERNING THE WORK, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, INCLUDING, WITHOUT LIMITATION, WARRANTIES OF TITLE, MERCHANTIBILITY, FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT OR OTHER DEFECTS, ACCURACY, OR THE PRESENCE OF ABSENCE OF ERRORS, WHETHER OR NOT DISCOVERABLE. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF IMPLIED WARRANTIES, SO SUCH EXCLUSION MAY NOT APPLY TO YOU. + +6. Limitation on Liability. EXCEPT TO THE EXTENT REQUIRED BY APPLICABLE LAW, IN NO EVENT WILL LICENSOR BE LIABLE TO YOU ON ANY LEGAL THEORY FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, PUNITIVE OR EXEMPLARY DAMAGES ARISING OUT OF THIS LICENSE OR THE USE OF THE WORK, EVEN IF LICENSOR HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + +7. Termination + + This License and the rights granted hereunder will terminate automatically upon any breach by You of the terms of this License. Individuals or entities who have received Adaptations or Collections from You under this License, however, will not have their licenses terminated provided such individuals or entities remain in full compliance with those licenses. Sections 1, 2, 5, 6, 7, and 8 will survive any termination of this License. + Subject to the above terms and conditions, the license granted here is perpetual (for the duration of the applicable copyright in the Work). Notwithstanding the above, Licensor reserves the right to release the Work under different license terms or to stop distributing the Work at any time; provided, however that any such election will not serve to withdraw this License (or any other license that has been, or is required to be, granted under the terms of this License), and this License will continue in full force and effect unless terminated as stated above. + +8. Miscellaneous + + Each time You Distribute or Publicly Perform the Work or a Collection, the Licensor offers to the recipient a license to the Work on the same terms and conditions as the license granted to You under this License. + Each time You Distribute or Publicly Perform an Adaptation, Licensor offers to the recipient a license to the original Work on the same terms and conditions as the license granted to You under this License. + If any provision of this License is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this License, and without further action by the parties to this agreement, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable. + No term or provision of this License shall be deemed waived and no breach consented to unless such waiver or consent shall be in writing and signed by the party to be charged with such waiver or consent. + This License constitutes the entire agreement between the parties with respect to the Work licensed here. There are no understandings, agreements or representations with respect to the Work not specified here. Licensor shall not be bound by any additional provisions that may appear in any communication from You. This License may not be modified without the mutual written agreement of the Licensor and You. + The rights granted under, and the subject matter referenced, in this License were drafted utilizing the terminology of the Berne Convention for the Protection of Literary and Artistic Works (as amended on September 28, 1979), the Rome Convention of 1961, the WIPO Copyright Treaty of 1996, the WIPO Performances and Phonograms Treaty of 1996 and the Universal Copyright Convention (as revised on July 24, 1971). These rights and subject matter take effect in the relevant jurisdiction in which the License terms are sought to be enforced according to the corresponding provisions of the implementation of those treaty provisions in the applicable national law. If the standard suite of rights granted under applicable copyright law includes additional rights not granted under this License, such additional rights are deemed to be included in the License; this License is not intended to restrict the license of any rights under applicable law. From 33807a34658477826dd69e78dc7ee10d0bc8c17b Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 17 Apr 2023 13:45:09 -0400 Subject: [PATCH 124/328] Initialize fldsto This corrects a typo in noah36_lsm_ini that caused fldsto to be uninitialized, which caused runoff (QS) to have unphysical values. This was noticed when compiling LIS with GNU compilers with "-O2" optimization. --- lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 b/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 index 8ea3db57c..92fd1dbf6 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 @@ -228,7 +228,7 @@ subroutine noah36_lsm_ini() !ag(05Jan2021) noah36_struc(n)%noah(i)%rivsto = 0.0 - noah36_struc(n)%noah(i)%fldfrc = 0.0 + noah36_struc(n)%noah(i)%fldsto = 0.0 noah36_struc(n)%noah(i)%fldfrc = 0.0 enddo From 8d421f828565a9633b70810d99ea09433f949d3e Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 18 Apr 2023 09:39:00 -0400 Subject: [PATCH 125/328] Fix release docs action (cherry picked from commit 05b17847f9dcca8386f74909874e3e544f6e60fb) --- .github/workflows/build-release-docs.yaml | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/.github/workflows/build-release-docs.yaml b/.github/workflows/build-release-docs.yaml index 47af82907..cf12fffa9 100644 --- a/.github/workflows/build-release-docs.yaml +++ b/.github/workflows/build-release-docs.yaml @@ -19,21 +19,26 @@ jobs: - name: Install Ruby uses: ruby/setup-ruby@v1 with: - ruby-version: 2.7.6 # Not needed with a .ruby-version file - bundler-cache: true # runs 'bundle install' and caches installed gems automatically + ruby-version: 2.7 # Not needed with a .ruby-version file + + - name: Configure Bundler + run: bundle config --local path .bundle/gems - name: Install Asciidoctor-Mathematical dependencies run: | # below command from: https://github.com/asciidoctor/asciidoctor-mathematical/#installation - sudo apt-get -qq -y install bison flex libffi-dev libxml2-dev libgdk-pixbuf2.0-dev libcairo2-dev libpango1.0-dev fonts-lyx cmake + sudo apt-get update -y + sudo apt-get -qq -y install bison flex libffi-dev libxml2-dev libgdk-pixbuf2.0-dev libcairo2-dev libpango1.0-dev libwebp-dev fonts-lyx cmake - name: Install Asciidoctor-PDF run: | gem install asciidoctor-pdf - gem install asciidoctor-mathematical - asciidoctor-pdf --version + - name: Install asciidoctor-mathematical + run: | + gem install asciidoctor-mathematical + - name: Store tag in environment run : echo "RELEASE_TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV From 546966fa9eb55ebca811ba8874ae108ddc113230 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 20 Apr 2023 12:37:18 -0400 Subject: [PATCH 126/328] Add worklow to build LISF AppImage --- .github/scripts/appimage/AppRun | 138 +++++++++++++++++++++++++ .github/scripts/appimage/Dockerfile | 18 ++++ .github/scripts/appimage/LISF.desktop | 6 ++ .github/scripts/appimage/LISF.png | Bin 0 -> 28851 bytes .github/scripts/appimage/compile_lisf | 83 +++++++++++++++ .github/scripts/appimage/lisf.env | 130 +++++++++++++++++++++++ .github/scripts/appimage/make_appimage | 7 ++ .github/scripts/appimage/prep_appdir | 36 +++++++ .github/workflows/build-appimage.yaml | 84 +++++++++++++++ 9 files changed, 502 insertions(+) create mode 100755 .github/scripts/appimage/AppRun create mode 100644 .github/scripts/appimage/Dockerfile create mode 100644 .github/scripts/appimage/LISF.desktop create mode 100644 .github/scripts/appimage/LISF.png create mode 100755 .github/scripts/appimage/compile_lisf create mode 100644 .github/scripts/appimage/lisf.env create mode 100755 .github/scripts/appimage/make_appimage create mode 100755 .github/scripts/appimage/prep_appdir create mode 100644 .github/workflows/build-appimage.yaml diff --git a/.github/scripts/appimage/AppRun b/.github/scripts/appimage/AppRun new file mode 100755 index 000000000..447686771 --- /dev/null +++ b/.github/scripts/appimage/AppRun @@ -0,0 +1,138 @@ +#!/bin/bash + +SELF=$(readlink -f "${0}") +HERE=${SELF%/*} + +LISF_LIBS_OPENJPEG=${HERE}/usr/lib/openjpeg/2.4.0_gnu-11.2.0 +LISF_LIBS_ECCODES=${HERE}/usr/lib/eccodes/2.22.0_gnu-11.2.0 +LISF_LIBS_NETCDF=${HERE}/usr/lib/netcdf/4.7.4_gnu-11.2.0 +LISF_LIBS_HDF4=${HERE}/usr/lib/hdf4/4.2.15_gnu-11.2.0 +LISF_LIBS_HDFEOS=${HERE}/usr/lib/hdfeos2/3.0_gnu-11.2.0 +LISF_LIBS_HDF5=${HERE}/usr/lib/hdf5/1.12.0_gnu-11.2.0 +LISF_LIBS_ESMF=${HERE}/usr/lib/esmf/8.1.1_gnu-11.2.0_mpich-3.4 +LISF_LIBS_GDAL=${HERE}/usr/lib/gdal/3.5.2_gnu-11.2.0 +LISF_LIBS_FORTRANGIS=${HERE}/usr/lib/fortrangis/2.6-6_gnu-11.2.0 +LISF_LIBS_LIBGEOTIFF=${HERE}/usr/lib/geotiff/1.7.0_gnu-11.2.0 +LISF_LIBS_PROJ=${HERE}/usr/lib/proj/9.1.0_gnu-11.2.0 +LISF_LIBS_TIFF=${HERE}/usr/lib/tiff/4.0.9_gnu-11.2.0 + +LISF_LIBS_PATH="" +LISF_LIBS_PATH+=":${LISF_LIBS_ECCODES}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_NETCDF}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_ESMF}/lib/libO/Linux.gfortran.64.mpich3.default" +LISF_LIBS_PATH+=":${LISF_LIBS_HDF5}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_HDF4}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_GDAL}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_LIBGEOTIFF}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_FORTRANGIS}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_OPENJPEG}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_PROJ}/lib" +LISF_LIBS_PATH+=":${LISF_LIBS_TIFF}/lib" +export LISF_LIBS_PATH + +export LANG=C +export LD_LIBRARY_PATH=${LISF_LIBS_PATH}:${LD_LIBRARY_PATH} +export ECCODES_DEFINITION_PATH=${LISF_LIBS_ECCODES}/share/eccodes/definitions +export ECCODES_SAMPLES_PATH=${LISF_LIBS_ECCODES}/share/eccodes/samples + +export PATH=${HERE}/usr/bin:${PATH} + +function lisf_usage { + echo "Usage: $(basename ${0}) [options] [-- LISF options]" + echo "" + echo " where [options] are:" + echo " -h show this help message" + echo " -v show revision info about LISF" + echo " -i show configuration info about LISF" + echo " -a specify which app to run" + echo "" + echo " where [LISF options] are options to pass to LISF;" + echo " these must be preceeded by --" + echo "" + echo " Examples:" + echo " $(basename ${0}) -a LDT ldt.config" + echo " mpirun -n N $(basename ${0}) -a LIS -- --file lis.config" + echo " $(basename ${0}) -a LVT lvt.config" +} + +function lisf_version { + echo "## Revision info" + echo "" + cat "${HERE}/info/revision.log" +} + +function lisf_info { + lisf_version + echo "" + echo "## LDT info" + echo "" + echo "### LDT_NetCDF_inc.h" + cat "${HERE}/info/ldt/LDT_NetCDF_inc.h" + echo "" + echo "### LDT_misc.h" + cat "${HERE}/info/ldt/LDT_misc.h" + echo "" + echo "### configure.ldt" + cat "${HERE}/info/ldt/configure.ldt" + echo "" + echo "## LIS info" + echo "" + echo "### LIS_NetCDF_inc.h" + cat "${HERE}/info/lis/LIS_NetCDF_inc.h" + echo "" + echo "### LIS_misc.h" + cat "${HERE}/info/lis/LIS_misc.h" + echo "" + echo "### LIS_plugins.h" + cat "${HERE}/info/lis/LIS_plugins.h" + echo "" + echo "### configure.lis" + cat "${HERE}/info/lis/configure.lis" + echo "" + echo "## LVT info" + echo "" + echo "### LVT_misc.h" + cat "${HERE}/info/lvt/LVT_NetCDF_inc.h" + echo "" + echo "### LVT_misc.h" + cat "${HERE}/info/lvt/LVT_misc.h" + echo "" + echo "### configure.lvt" + cat "${HERE}/info/lvt/configure.lvt" +} + +if [[ ${#} -eq 0 ]] +then + lisf_usage +fi + +optstring=":hvia:" +while getopts ${optstring} arg +do + case ${arg} in + h) + lisf_usage + exit 0 + ;; + v) + lisf_version + exit 0 + ;; + i) + lisf_info + exit 0 + ;; + a) + APP="${OPTARG}" + ;; + ?) + echo "Invalid option: -${OPTARG}" + echo "" + lisf_usage + exit 1 + ;; + esac +done + +shift $((${OPTIND} - 1)) +exec "${HERE}/usr/bin/${APP}" "${@}" diff --git a/.github/scripts/appimage/Dockerfile b/.github/scripts/appimage/Dockerfile new file mode 100644 index 000000000..1bf04a709 --- /dev/null +++ b/.github/scripts/appimage/Dockerfile @@ -0,0 +1,18 @@ +FROM lisf_libraries + +# LISF {{{ +WORKDIR /home/workdir +COPY LISF ./LISF +RUN cp ./LISF/.github/scripts/appimage/lisf.env . +RUN cp ./LISF/.github/scripts/appimage/compile_lisf . +RUN ./compile_lisf +# }}} + +# AppImage {{{ +WORKDIR /home/workdir +COPY ./LISF/.github/scripts/appimage/AppRun . +COPY ./LISF/.github/scripts/appimage/LISF.png . +COPY ./LISF/.github/scripts/appimage/LISF.desktop . +COPY ./LISF/.github/scripts/appimage/prep_appdir . +RUN ./prep_appdir +# }}} diff --git a/.github/scripts/appimage/LISF.desktop b/.github/scripts/appimage/LISF.desktop new file mode 100644 index 000000000..94bd62a76 --- /dev/null +++ b/.github/scripts/appimage/LISF.desktop @@ -0,0 +1,6 @@ +[Desktop Entry] +Name=LISF +Exec=LISF +Icon=LISF +Type=Application +Categories=Utility; diff --git a/.github/scripts/appimage/LISF.png b/.github/scripts/appimage/LISF.png new file mode 100644 index 0000000000000000000000000000000000000000..1c56f5b5aaee120597fee5b63c303298daba4264 GIT binary patch literal 28851 zcmV*QKwrO!P)&SP2qZvgAp{775PCuagb?`C2_+QMY>IpD zK40%;_qMNAUGqJX_V$YJjP2YR$mjRb?W5C5Bdzq)`~KcCGXz2i9FZe3(t`ca7jQ)W zH{}Shj>xFU5nvsWQIR9SIwGSYM}T!iMn#SQ>xhhs90Ar585KDKtRpfias*gMWK`q` zu#U*6$Pr*2kx`K&z&awMB1eFAL`Fr3ANm4*0>W}iG^X_5Lf|mnL;i4A^b?RHz)DJ| zPuNq-Hnebi>l1a2iH>eD6p=y^sV5)}cZk)3yPTxcM&xAC6(#2EOs1m5TvA}FD6x

O}kena;`z>;H#1 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 Miphyq34{Fq2PecV7XSbN literal 0 HcmV?d00001 diff --git a/.github/scripts/appimage/compile_lisf b/.github/scripts/appimage/compile_lisf new file mode 100755 index 000000000..4614a6032 --- /dev/null +++ b/.github/scripts/appimage/compile_lisf @@ -0,0 +1,83 @@ +#!/usr/bin/env bash + +source lisf.env +cd LISF + +# +# Revision +# + +git log -n 1 --oneline --decorate >revision.log + +# +# LDT +# + +# Parallelism (0-serial, 1-dmpar, default=0): 0 +# Optimization level (-3=strict checks with warnings, -2=strict checks, -1=debug, 0,1,2,3, default=2): 2 +# Assume little/big_endian data format (1-little, 2-big, default=2): 2 +# Use GRIBAPI/ECCODES? (0-neither, 1-gribapi, 2-eccodes, default=2): 2 +# NETCDF version (3 or 4, default=4)?: 4 +# NETCDF use shuffle filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate level? (1 to 9-yes, 0-no, default = 9): 1 +# Use HDF4? (1-yes, 0-no, default=1): 1 +# Use HDF5? (1-yes, 0-no, default=1): 1 +# Use HDFEOS? (1-yes, 0-no, default=1): 1 +# Enable GeoTIFF support? (1-yes, 0-no, default=1): 1 +# Enable LIBGEOTIFF support? (1-yes, 0-no, default=1): 1 +# Include date/time stamp history? (1-yes, 0-no, default=1): 1 + +cd ldt +printf '%s\n' "0" "2" "2" "2" "4" "1" "1" "1" "1" "1" "1" "1" "1" "1" | ./configure +./compile -j 2 + +# +# LIS +# + +# Parallelism (0-serial, 1-dmpar, default=1): 1 +# Optimization level (-3=strict checks with warnings, -2=strict checks, -1=debug, 0,1,2,3, default=2): 2 +# Assume little/big_endian data format (1-little, 2-big, default=2): 2 +# Use GRIBAPI/ECCODES? (0-neither, 1-gribapi, 2-eccodes, default=2): 2 +# Enable AFWA-specific grib configuration settings? (1-yes, 0-no, default=0): 0 +# Use NETCDF? (1-yes, 0-no, default=1): 1 +# NETCDF version (3 or 4, default=4): 4 +# NETCDF use shuffle filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate level? (1 to 9-yes, 0-no, default = 9): 1 +# Use HDF4? (1-yes, 0-no, default=1): 1 +# Use HDF5? (1-yes, 0-no, default=1): 1 +# Use HDFEOS? (1-yes, 0-no, default=1): 1 +# Use MINPACK? (1-yes, 0-no, default=0): 0 +# Use LIS-CRTM? (1-yes, 0-no, default=0): 0 +# Use LIS-CMEM? (1-yes, 0-no, default=0): 0 +# Use LIS-LAPACK? (1-yes, 0-no, default=0): 0 +# Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): 0 + +cd ../lis +printf '%s\n' "1" "2" "2" "2" "0" "1" "4" "1" "1" "1" "1" "1" "1" "0" "0" "0" "0" "0" | ./configure +./compile -j 2 + +# +# LVT +# + +# Optimization level (-3=strict checks with warnings, -2=strict checks, -1=debug, 0,1,2,3, default=2): 2 +# Assume little/big_endian data format (1-little, 2-big, default=2): 2 +# Use GRIBAPI/ECCODES? (1-gribapi, 2-eccodes, default=2): 2 +# Use NETCDF? (1-yes, 0-no, default=1): 1 +# NETCDF version (3 or 4, default=4): 4 +# NETCDF use shuffle filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate filter? (1-yes, 0-no, default = 1): 1 +# NETCDF use deflate level? (1 to 9-yes, 0-no, default = 9): 1 +# Use HDF4? (1-yes, 0-no, default=1): 1 +# Use HDF5? (1-yes, 0-no, default=1): 1 +# Use HDFEOS? (1-yes, 0-no, default=1): 1 +# Enable AFWA-specific grib configuration settings? (1-yes, 0-no, default=0): 0 +# Enable GeoTIFF support? (1-yes, 0-no, default=1): 1 +# Use MATLAB support? (1-yes, 0-no, default=0): 0 + +cd ../lvt +printf '%s\n' "2" "2" "2" "1" "4" "1" "1" "1" "1" "1" "1" "0" "1" "0" | ./configure +./compile -j 2 diff --git a/.github/scripts/appimage/lisf.env b/.github/scripts/appimage/lisf.env new file mode 100644 index 000000000..9b6368e32 --- /dev/null +++ b/.github/scripts/appimage/lisf.env @@ -0,0 +1,130 @@ +LISF_LIBS_MPICH=/home/workdir/lib/mpich/3.4_gnu-11.2.0 +LISF_LIBS_OPENJPEG=/home/workdir/lib/openjpeg/2.4.0_gnu-11.2.0 +LISF_LIBS_ECCODES=/home/workdir/lib/eccodes/2.22.0_gnu-11.2.0 +LISF_LIBS_NETCDF=/home/workdir/lib/netcdf/4.7.4_gnu-11.2.0 +LISF_LIBS_HDF4=/home/workdir/lib/hdf4/4.2.15_gnu-11.2.0 +LISF_LIBS_HDFEOS=/home/workdir/lib/hdfeos2/3.0_gnu-11.2.0 +LISF_LIBS_HDF5=/home/workdir/lib/hdf5/1.12.0_gnu-11.2.0 +LISF_LIBS_ESMF=/home/workdir/lib/esmf/8.1.1_gnu-11.2.0_mpich-3.4 +LISF_LIBS_PROJ=/home/workdir/lib/proj/9.1.0_gnu-11.2.0 +LISF_LIBS_GDAL=/home/workdir/lib/gdal/3.5.2_gnu-11.2.0 +LISF_LIBS_FORTRANGIS=/home/workdir/lib/fortrangis/2.6-6_gnu-11.2.0 +LISF_LIBS_LIBGEOTIFF=/home/workdir/lib/geotiff/1.7.0_gnu-11.2.0 +LISF_LIBS_TIFF=/home/workdir/lib/tiff/4.0.9_gnu-11.2.0 + +LISF_LIBS_PATH="$LISF_LIBS_MPICH/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_ECCODES/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_NETCDF/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_ESMF/lib/libO/Linux.gfortran.64.mpich3.default" +LISF_LIBS_PATH+=":$LISF_LIBS_HDF5/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_HDF4/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_PROJ/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_GDAL/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_LIBGEOTIFF/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_OPENJPEG/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_TIFF/lib" +export LISF_LIBS_PATH + +def_lis_jpeg="" +def_lis_openjpeg=$LISF_LIBS_OPENJPEG +def_lis_eccodes=$LISF_LIBS_ECCODES +def_lis_netcdf=$LISF_LIBS_NETCDF +def_lis_hdf4=$LISF_LIBS_HDF4 +def_lis_hdfeos=$LISF_LIBS_HDFEOS +def_lis_hdf5=$LISF_LIBS_HDF5 +def_lis_modesmf=$LISF_LIBS_ESMF/mod/modO/Linux.gfortran.64.mpich3.default +def_lis_libesmf=$LISF_LIBS_ESMF/lib/libO/Linux.gfortran.64.mpich3.default +def_lis_minpack="" +def_lis_crtm="" +def_lis_crtm_prof="" +def_lis_cmem="" +def_lis_lapack="" +def_lvt_gdal=$LISF_LIBS_GDAL +def_lvt_fortrangis=$LISF_LIBS_FORTRANGIS +def_ldt_libgeotiff=$LISF_LIBS_LIBGEOTIFF + +export LIS_ARCH=linux_gfortran +export LIS_SPMD=parallel +export LIS_FC=mpif90 +export LIS_CC=mpicc +export LIS_CPPC=mpiCC +export LIS_JPEG=$def_lis_jpeg +export LIS_OPENJPEG=$def_lis_openjpeg +export LIS_ECCODES=$def_lis_eccodes +export LIS_NETCDF=$def_lis_netcdf +export LIS_HDF4=$def_lis_hdf4 +export LIS_HDFEOS=$def_lis_hdfeos +export LIS_HDF5=$def_lis_hdf5 +export LIS_MODESMF=$def_lis_modesmf +export LIS_LIBESMF=$def_lis_libesmf +export LIS_MINPACK=$def_lis_minpack +export LIS_CRTM=$def_lis_crtm +export LIS_CRTM_PROF=$def_lis_crtm_prof +export LIS_CMEM=$def_lis_cmem +export LIS_LAPACK=$def_lis_lapack + +export LDT_ARCH=linux_gfortran +export LDT_FC=mpif90 +export LDT_CC=mpicc +export LDT_JPEG=$def_lis_jpeg +export LDT_OPENJPEG=$def_lis_openjpeg +export LDT_ECCODES=$def_lis_eccodes +export LDT_NETCDF=$def_lis_netcdf +export LDT_HDF4=$def_lis_hdf4 +export LDT_HDFEOS=$def_lis_hdfeos +export LDT_HDF5=$def_lis_hdf5 +export LDT_MODESMF=$def_lis_modesmf +export LDT_LIBESMF=$def_lis_libesmf +export LDT_GDAL=$def_lvt_gdal +export LDT_FORTRANGIS=$def_lvt_fortrangis +export LDT_LIBGEOTIFF=$def_ldt_libgeotiff + +export LVT_ARCH=linux_gfortran +export LVT_FC=mpif90 +export LVT_CC=mpicc +export LVT_JPEG=$def_lis_jpeg +export LVT_OPENJPEG=$def_lis_openjpeg +export LVT_ECCODES=$def_lis_eccodes +export LVT_NETCDF=$def_lis_netcdf +export LVT_HDF4=$def_lis_hdf4 +export LVT_HDFEOS=$def_lis_hdfeos +export LVT_HDF5=$def_lis_hdf5 +export LVT_MODESMF=$def_lis_modesmf +export LVT_LIBESMF=$def_lis_libesmf +export LVT_GDAL=$def_lvt_gdal +export LVT_FORTRANGIS=$def_lvt_fortrangis + +export LANG=C +export PATH=$LISF_LIBS_MPICH/bin:$PATH +export LD_LIBRARY_PATH=$LISF_LIBS_PATH:$LD_LIBRARY_PATH + +unset def_lis_jpeg +unset def_lis_openjpeg +unset def_lis_eccodes +unset def_lis_netcdf +unset def_lis_hdf4 +unset def_lis_hdfeos +unset def_lis_hdf5 +unset def_lis_modesmf +unset def_lis_libesmf +unset def_lis_minpack +unset def_lis_crtm +unset def_lis_crtm_prof +unset def_lis_cmem +unset def_lis_lapack +unset def_lvt_gdal +unset def_lvt_fortrangis +unset def_ldt_libgeotiff +unset LISF_LIBS_MPICH +unset LISF_LIBS_OPENJPEG +unset LISF_LIBS_ECCODES +unset LISF_LIBS_NETCDF +unset LISF_LIBS_HDF4 +unset LISF_LIBS_HDFEOS +unset LISF_LIBS_HDF5 +unset LISF_LIBS_ESMF +unset LISF_LIBS_PROJ +unset LISF_LIBS_GDAL +unset LISF_LIBS_FORTRANGIS +unset LISF_LIBS_LIBGEOTIFF +unset LISF_LIBS_TIFF diff --git a/.github/scripts/appimage/make_appimage b/.github/scripts/appimage/make_appimage new file mode 100755 index 000000000..8a757fb48 --- /dev/null +++ b/.github/scripts/appimage/make_appimage @@ -0,0 +1,7 @@ +#!/usr/bin/env bash + +sudo docker create --name dummy lisf_appdir +sudo docker cp dummy:/home/workdir/LISF.AppDir . +sudo docker rm -f dummy + +sudo appimagetool LISF.AppDir diff --git a/.github/scripts/appimage/prep_appdir b/.github/scripts/appimage/prep_appdir new file mode 100755 index 000000000..d2b7efcf1 --- /dev/null +++ b/.github/scripts/appimage/prep_appdir @@ -0,0 +1,36 @@ +#!/usr/bin/env bash + +mkdir -p LISF.AppDir/usr/bin +mkdir -p LISF.AppDir/usr/lib +mkdir -p LISF.AppDir/info/ldt +mkdir -p LISF.AppDir/info/lis +mkdir -p LISF.AppDir/info/lvt +cd LISF.AppDir +cp /home/workdir/AppRun . +cp /home/workdir/LISF.png . +cp /home/workdir/LISF.desktop . +cp /home/workdir/LISF/ldt/LDT usr/bin +cp /home/workdir/LISF/lis/LIS usr/bin +cp /home/workdir/LISF/lvt/LVT usr/bin +cp /home/workdir/LISF/revision.log info +cp /home/workdir/LISF/ldt/make/LDT_NetCDF_inc.h info/ldt +cp /home/workdir/LISF/ldt/make/LDT_misc.h info/ldt +cp /home/workdir/LISF/ldt/make/configure.ldt info/ldt +cp /home/workdir/LISF/lis/make/LIS_NetCDF_inc.h info/lis +cp /home/workdir/LISF/lis/make/LIS_misc.h info/lis +cp /home/workdir/LISF/lis/make/LIS_plugins.h info/lis +cp /home/workdir/LISF/lis/make/configure.lis info/lis +cp /home/workdir/LISF/lvt/make/LVT_NetCDF_inc.h info/lvt +cp /home/workdir/LISF/lvt/make/LVT_misc.h info/lvt +cp /home/workdir/LISF/lvt/make/configure.lvt info/lvt +cd usr/lib +cp -R /home/workdir/lib/* . +rm -rf mpich + +cd /home/workdir/LISF.AppDir +patchelf --clear-symbol-version expf --clear-symbol-version logf --clear-symbol-version powf usr/bin/LDT +patchelf --clear-symbol-version expf --clear-symbol-version glob --clear-symbol-version logf --clear-symbol-version powf usr/bin/LIS +patchelf --clear-symbol-version expf --clear-symbol-version logf --clear-symbol-version powf usr/bin/LVT +patchelf --clear-symbol-version powf usr/lib/hdf5/1.12.0_gnu-11.2.0/lib/libhdf5.so +patchelf --clear-symbol-version logf usr/lib/esmf/8.1.1_gnu-11.2.0_mpich-3.4/lib/libO/Linux.gfortran.64.mpich3.default/libesmf.so +patchelf --clear-symbol-version logf usr/lib/gdal/3.5.2_gnu-11.2.0/lib/libgdal.so diff --git a/.github/workflows/build-appimage.yaml b/.github/workflows/build-appimage.yaml new file mode 100644 index 000000000..162d99ce7 --- /dev/null +++ b/.github/workflows/build-appimage.yaml @@ -0,0 +1,84 @@ +name: LISF AppImage +on: + push: + branches: + - master + release: + types: + - published + #workflow_dispatch: + +jobs: + build_and_publish: + name: Build and publish AppImage + runs-on: ubuntu-22.04 + if: ${{ !contains(github.ref_name, 'support/lisf-557ww') }} + steps: + - if: github.event_name == 'release' + run: echo "DEV_IMAGE=${{ github.event.release.target_commitish }}" >>$GITHUB_ENV + - if: github.event_name == 'push' #|| github.event_name == 'workflow_dispatch' + run: echo "DEV_IMAGE=master" >>$GITHUB_ENV + - name: Get LISF libraries image + run: curl --insecure --no-progress-meter -O https://portal.nccs.nasa.gov/lisdata_pub/TESTING/dev-images/$DEV_IMAGE/lisf_libraries.tar.gz + - name: Load LISF libraries image + run: docker image load --input lisf_libraries.tar.gz + - name: Checkout LISF source code + uses: actions/checkout@v3 + - name: Compile LISF + run: docker build --build-arg LISF_SOURCE=$GITHUB_WORKSPACE --tag lisf_appdir --file ./.github/scripts/appimage/Dockerfile $GITHUB_WORKSPACE/.. + - name: Make AppImage + run: | + sudo apt-get update + sudo apt-get install -y --no-install-recommends fuse + wget https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage + chmod 755 appimagetool-x86_64.AppImage + mv appimagetool-x86_64.AppImage /usr/local/bin/appimagetool + ./.github/scripts/appimage/make_appimage + - name: Prepare release notes (if necessary) + if: github.event_name == 'push' #|| github.event_name == 'workflow_dispatch' + run: | + cat <$RUNNER_TEMP/notes.md + This AppImage is compatible with: + + * Linux: x86_64 machines (as reported by \`uname -s -m\`) + * GLIBC: 2.22 or newer (as reported by \`ldd --version\`) + * MPI: MPICH, Intel MPI, or Cray MPI + + After downloading the AppImage, run: + + \`\`\` + chmod 755 ./LISF-x86_64.AppImage + \`\`\` + + To get started with the AppImage, run: + + \`\`\` + ./LISF-x86_64.AppImage -h + \`\`\` + + Note: + + This AppImage requires FUSE to run. If you get an error, then try: + \`\`\` + mkdir LISF-x86_64 + cd LISF-x86_64 + ../LISF-x86_64.AppImage --appimage-extract + cd .. + ./LISF-x86_64/squashfs-root/AppRun -h + \`\`\` + EOB + - name: Create pre-release (if necessary) + if: github.event_name == 'push' #|| github.event_name == 'workflow_dispatch' + env: + GH_TOKEN: ${{ github.token }} + LISF_TAG: master-latest + TITLE: "LISF master (pre-release) image" + run: | + gh release delete $LISF_TAG --yes || true + git push origin :$LISF_TAG || true + gh release create $LISF_TAG --prerelease --notes-file "$RUNNER_TEMP/notes.md" --title "$TITLE" --target $GITHUB_SHA ./LISF-x86_64.AppImage + - name: Upload asset (if necessary) + if: github.event_name == 'release' + env: + GH_TOKEN: ${{ github.token }} + run: gh release upload ${{ github.event.release.tag_name }} ./LISF-x86_64.AppImage From 43c0d4b08e9408a65a99bc476d9902388ab9b1b1 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 20 Apr 2023 14:28:22 -0400 Subject: [PATCH 127/328] Set name of AppImage in AppRun script --- .github/scripts/appimage/AppRun | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/.github/scripts/appimage/AppRun b/.github/scripts/appimage/AppRun index 447686771..175c78d38 100755 --- a/.github/scripts/appimage/AppRun +++ b/.github/scripts/appimage/AppRun @@ -38,7 +38,8 @@ export ECCODES_SAMPLES_PATH=${LISF_LIBS_ECCODES}/share/eccodes/samples export PATH=${HERE}/usr/bin:${PATH} function lisf_usage { - echo "Usage: $(basename ${0}) [options] [-- LISF options]" + NAME="LISF-x86_64.AppImage" + echo "Usage: $NAME [options] [-- LISF options]" echo "" echo " where [options] are:" echo " -h show this help message" @@ -50,9 +51,9 @@ function lisf_usage { echo " these must be preceeded by --" echo "" echo " Examples:" - echo " $(basename ${0}) -a LDT ldt.config" - echo " mpirun -n N $(basename ${0}) -a LIS -- --file lis.config" - echo " $(basename ${0}) -a LVT lvt.config" + echo " $NAME -a LDT ldt.config" + echo " mpirun -n N $NAME -a LIS -- --file lis.config" + echo " $NAME -a LVT lvt.config" } function lisf_version { From b158b3b155dfd29200e781493fe5bc989c57a62b Mon Sep 17 00:00:00 2001 From: David Mocko Date: Thu, 20 Apr 2023 15:01:46 -0400 Subject: [PATCH 128/328] Add GEOS-IT as a metforcing for LIS This pull request adds the GEOS-IT hourly surface products as a metforcing into LIS. There are options available to use forcings at different heights above the ground. Resolves #1320 --- lis/configs/lis.config.adoc | 46 +- lis/make/default.cfg | 5 + lis/metforcing/geos_it/0Intro_geosit.txt | 14 + lis/metforcing/geos_it/finalize_geosit.F90 | 72 +++ lis/metforcing/geos_it/geosit_forcingMod.F90 | 292 +++++++++++ lis/metforcing/geos_it/get_geosit.F90 | 309 ++++++++++++ lis/metforcing/geos_it/read_geosit.F90 | 487 +++++++++++++++++++ lis/metforcing/geos_it/read_geosit_elev.F90 | 78 +++ lis/metforcing/geos_it/readcrd_geosit.F90 | 75 +++ lis/metforcing/geos_it/reset_geosit.F90 | 43 ++ lis/metforcing/geos_it/timeinterp_geosit.F90 | 294 +++++++++++ lis/plugins/LIS_metforcing_pluginMod.F90 | 21 + lis/plugins/LIS_pluginIndices.F90 | 1 + 13 files changed, 1736 insertions(+), 1 deletion(-) create mode 100644 lis/metforcing/geos_it/0Intro_geosit.txt create mode 100644 lis/metforcing/geos_it/finalize_geosit.F90 create mode 100644 lis/metforcing/geos_it/geosit_forcingMod.F90 create mode 100644 lis/metforcing/geos_it/get_geosit.F90 create mode 100644 lis/metforcing/geos_it/read_geosit.F90 create mode 100644 lis/metforcing/geos_it/read_geosit_elev.F90 create mode 100644 lis/metforcing/geos_it/readcrd_geosit.F90 create mode 100644 lis/metforcing/geos_it/reset_geosit.F90 create mode 100644 lis/metforcing/geos_it/timeinterp_geosit.F90 diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index d740f57d3..75965f281 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -351,6 +351,7 @@ Acceptable values for the sources are: |"`GLDAS`" | GLDAS |"`GFS`" | GFS |"`MERRA2`" | MERRA2 +|"`GEOS-IT`" | GEOS-IT |"`CMAP`" | CMAP |"`TRMM 3B42RT`" | TRMM 3B42RT |"`TRMM 3B42RTV7`" | TRMM 3B42RTV7 @@ -5580,7 +5581,6 @@ GFS domain y-dimension size: 256 GFS number of forcing variables: 10 .... - [[sssec_forcings_MERRA2,MERRA2]] ==== MERRA2 @@ -5636,6 +5636,50 @@ MERRA2 use 2m wind fields: 0 MERRA2 use corrected total precipitation: 1 .... +[[sssec_forcings_GEOS-IT,GEOS-IT]] +==== GEOS-IT + +`GEOS-IT forcing directory:` specifies the location of +the GEOS-IT forcing files. + +Please note that GEOS-IT is currently in production and is +not complete for all calendar years. Also, it is not yet +available outside of NASA`'s NCCS computing platforms. +Also, the topographic or elevation correction option is +supported through the MERRA-2 geopotential terrain height +file. Please also see the latest LDT notes for updates on +how to use this option. + +`GEOS-IT use lowest model level forcing:` specifies whether +to use the lowest model level forcing. +Acceptable values are: + +|==== +|Value | Description + +|0 | Do not use the lowest model level forcing. +|1 | Use the lowest model level forcing. +|==== + +`GEOS-IT use 2m wind fields:` specifies whether to use the +2m diagnosed wind fields. This option will only work if +the lowest model level forcing option is turned off. +Acceptable values are: + +|==== +|Value | Description + +|0 | Do not use the 2m diagnosed wind speed fields. +|1 | Use the 2m diagnosed wind speed fields. +|==== + +.Example _lis.config_ entry +.... +GEOS-IT forcing directory: ./GEOS-IT +GEOS-IT use lowest model level forcing: 1 +GEOS-IT use 2m wind fields: 0 +.... + [[sssec_forcings_ERA5,ERA5]] ==== ERA5 diff --git a/lis/make/default.cfg b/lis/make/default.cfg index e62461e53..363a09167 100644 --- a/lis/make/default.cfg +++ b/lis/make/default.cfg @@ -282,6 +282,11 @@ enabled: True macro: MF_MERRA2 path: metforcing/merra2 +[GEOS-IT] +enabled: True +macro: MF_GEOS_IT +path: metforcing/geos_it + [ERA5] enabled: True macro: MF_ERA5 diff --git a/lis/metforcing/geos_it/0Intro_geosit.txt b/lis/metforcing/geos_it/0Intro_geosit.txt new file mode 100644 index 000000000..55b2f8f29 --- /dev/null +++ b/lis/metforcing/geos_it/0Intro_geosit.txt @@ -0,0 +1,14 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +! +!BOP +!\section{GEOS-IT} +!This section describes the implementation of the GEOS-IT forcing data. +!EOP diff --git a/lis/metforcing/geos_it/finalize_geosit.F90 b/lis/metforcing/geos_it/finalize_geosit.F90 new file mode 100644 index 000000000..565a97409 --- /dev/null +++ b/lis/metforcing/geos_it/finalize_geosit.F90 @@ -0,0 +1,72 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: finalize_geosit +! \label{finalize_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine finalize_geosit(findex) + +! !USES: + use LIS_coreMod, only : LIS_rc + use geosit_forcingMod, only : geosit_struc +! +! !DESCRIPTION: +! Routine to cleanup GEOS-IT forcing related memory allocations. +! +!EOP + implicit none + + integer :: findex + integer :: n + + do n = 1,LIS_rc%nnest + select case( LIS_rc%met_interp(findex) ) + + case( "bilinear" ) + deallocate(geosit_struc(n)%n111) + deallocate(geosit_struc(n)%n121) + deallocate(geosit_struc(n)%n211) + deallocate(geosit_struc(n)%n221) + deallocate(geosit_struc(n)%w111) + deallocate(geosit_struc(n)%w121) + deallocate(geosit_struc(n)%w211) + deallocate(geosit_struc(n)%w221) + + case( "budget-bilinear" ) + deallocate(geosit_struc(n)%n111) + deallocate(geosit_struc(n)%n121) + deallocate(geosit_struc(n)%n211) + deallocate(geosit_struc(n)%n221) + deallocate(geosit_struc(n)%w111) + deallocate(geosit_struc(n)%w121) + deallocate(geosit_struc(n)%w211) + deallocate(geosit_struc(n)%w221) + deallocate(geosit_struc(n)%n112) + deallocate(geosit_struc(n)%n122) + deallocate(geosit_struc(n)%n212) + deallocate(geosit_struc(n)%n222) + deallocate(geosit_struc(n)%w112) + deallocate(geosit_struc(n)%w122) + deallocate(geosit_struc(n)%w212) + deallocate(geosit_struc(n)%w222) + + case( "neighbor" ) + deallocate(geosit_struc(n)%n113) + end select + enddo + deallocate(geosit_struc) + + end subroutine finalize_geosit + diff --git a/lis/metforcing/geos_it/geosit_forcingMod.F90 b/lis/metforcing/geos_it/geosit_forcingMod.F90 new file mode 100644 index 000000000..f271caf0c --- /dev/null +++ b/lis/metforcing/geos_it/geosit_forcingMod.F90 @@ -0,0 +1,292 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- + module geosit_forcingMod +!BOP +! !MODULE: geosit_forcingMod +! +! !DESCRIPTION: +! This module contains variables and data structures that are used +! for the implementation of the GEOS-IT forcing data. +! The data is global 0.625-degree lon. by 0.5-degree lat, in latlon +! projection, and at 1 hourly intervals. The derived data type +! {\tt geosit\_struc} +! includes the variables that specify the runtime options, and the +! weights and neighbor information to be used for spatial interpolation. +! They are described below: +! \begin{description} +! \item[ncold] +! Number of columns (along the east west dimension) for the input data +! \item[nrold] +! Number of rows (along the north south dimension) for the input data +! \item[nmif] +! Number of forcing variables in the data +! \item[geosittime1] +! The nearest, previous 1 hour instance of the incoming +! data (as a real time). +! \item[geosittime2] +! The nearest, next 1 hour instance of the incoming +! data (as a real time). +! \item[geositdir] +! Directory containing the input data +! \item[mi] +! Number of points in the input grid +! \item[n111,n121,n211,n221] +! Arrays containing the neighbor information of the input grid +! for each grid point in LIS, for bilinear interpolation. +! \item[w111,w121,w211,w221] +! Arrays containing the weights of the input grid +! for each grid point in LIS, for bilinear interpolation. +! \item[n122,n122,n212,n222] +! Arrays containing the neighbor information of the input grid +! for each grid point in LIS, for conservative interpolation. +! \item[w112,w122,w212,w222] +! Arrays containing the weights of the input grid +! for each grid point in LIS, for conservative interpolation. +! \item[n113] +! Arrays containing the neighbor information of the input grid +! for each grid point in LIS, for n. neighbor interpolation. +! \item[findtime1, findtime2] +! boolean flags to indicate which time is to be read for +! temporal interpolation. +! \end{description} +! +! !USES: + use LIS_constantsMod, only : LIS_CONST_PATH_LEN + + implicit none + + PRIVATE +!----------------------------------------------------------------------------- +! !PUBLIC MEMBER FUNCTIONS: +!----------------------------------------------------------------------------- + public :: init_geosit ! defines the native resolution of the input data +!----------------------------------------------------------------------------- +! !PUBLIC TYPES: +!----------------------------------------------------------------------------- + public :: geosit_struc + +!EOP + type, public :: geosit_type_dec + real :: ts + integer :: ncold, nrold + character(len=LIS_CONST_PATH_LEN) :: geositdir ! GEOS-IT Forcing Directory + real*8 :: geosittime1,geosittime2 + logical :: reset_flag + + integer :: mi + integer, allocatable :: n111(:) + integer, allocatable :: n121(:) + integer, allocatable :: n211(:) + integer, allocatable :: n221(:) + real, allocatable :: w111(:),w121(:) + real, allocatable :: w211(:),w221(:) + + integer, allocatable :: n112(:,:) + integer, allocatable :: n122(:,:) + integer, allocatable :: n212(:,:) + integer, allocatable :: n222(:,:) + real, allocatable :: w112(:,:),w122(:,:) + real, allocatable :: w212(:,:),w222(:,:) + integer, allocatable :: n113(:) + integer :: findtime1,findtime2 + logical :: startFlag,dayFlag + real, allocatable :: geositforc1(:,:,:),geositforc2(:,:,:) + + integer :: nvars + integer :: uselml + real*8 :: ringtime + integer :: nIter,st_iterid,en_iterid + + real, allocatable :: metdata1(:,:,:) + real, allocatable :: metdata2(:,:,:) + + integer :: use2mwind + character(len=LIS_CONST_PATH_LEN) :: scaleffile + integer, allocatable :: rseed(:,:) + end type geosit_type_dec + + type(geosit_type_dec), allocatable :: geosit_struc(:) + + contains + +!BOP +! +! !ROUTINE: init_geosit +! \label{init_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine init_geosit(findex) + +! !USES: + use LIS_coreMod + use LIS_timeMgrMod + use LIS_logMod + use LIS_spatialDownscalingMod, only : LIS_init_pcpclimo_native + + implicit none +! !AGRUMENTS: + integer, intent(in) :: findex + +! !DESCRIPTION: +! Defines the native resolution of the input forcing for GEOS-IT +! data. The grid description arrays are based on the decoding +! schemes used by NCEP and followed in the LIS interpolation +! schemes (see Section~\ref{interp}). +! +! The routines invoked are: +! \begin{description} +! \item[readcrd\_geosit](\ref{readcrd_geosit}) \newline +! reads the runtime options specified for GEOS-IT data +! \item[bilinear\_interp\_input](\ref{bilinear_interp_input}) \newline +! computes the neighbor, weights for bilinear interpolation +! \item[conserv\_interp\_input](\ref{conserv_interp_input}) \newline +! computes the neighbor, weights for conservative interpolation +! \end{description} +!EOP + real :: gridDesci(LIS_rc%nnest,50) + integer :: updoy,yr1,mo1,da1,hr1,mn1,ss1 + real :: upgmt + integer :: n + + allocate(geosit_struc(LIS_rc%nnest)) + + do n = 1,LIS_rc%nnest + geosit_struc(n)%ncold = 576 + geosit_struc(n)%nrold = 361 + enddo + + call readcrd_geosit() + LIS_rc%met_nf(findex) = 14 + + geosit_struc%reset_flag = .false. + + do n = 1, LIS_rc%nnest + geosit_struc(n)%ts = 3600 !check + call LIS_update_timestep(LIS_rc,n,geosit_struc(n)%ts) + enddo + + gridDesci = 0 + + do n = 1,LIS_rc%nnest + gridDesci(n,1) = 0 + gridDesci(n,2) = geosit_struc(n)%ncold + gridDesci(n,3) = geosit_struc(n)%nrold + gridDesci(n,4) = -90.000 + gridDesci(n,5) = -180.000 + gridDesci(n,6) = 128 + gridDesci(n,7) = 90.000 + gridDesci(n,8) = 179.375 + gridDesci(n,9) = 0.625 + gridDesci(n,10) = 0.5 + gridDesci(n,20) = 0 + + geosit_struc(n)%mi = geosit_struc(n)%ncold*geosit_struc(n)%nrold + + ! Setting up weights for Interpolation + if (trim(LIS_rc%met_interp(findex)).eq."bilinear") then + allocate(geosit_struc(n)%n111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + call bilinear_interp_input(n,gridDesci(n,:), & + geosit_struc(n)%n111,geosit_struc(n)%n121, & + geosit_struc(n)%n211,geosit_struc(n)%n221, & + geosit_struc(n)%w111,geosit_struc(n)%w121, & + geosit_struc(n)%w211,geosit_struc(n)%w221) + + elseif (trim(LIS_rc%met_interp(findex)).eq."budget-bilinear") then + allocate(geosit_struc(n)%n111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%n221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%w221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + call bilinear_interp_input(n,gridDesci(n,:), & + geosit_struc(n)%n111,geosit_struc(n)%n121, & + geosit_struc(n)%n211,geosit_struc(n)%n221, & + geosit_struc(n)%w111,geosit_struc(n)%w121, & + geosit_struc(n)%w211,geosit_struc(n)%w221) + + allocate(geosit_struc(n)%n112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%n122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%n212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%n222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%w112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%w122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%w212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(geosit_struc(n)%w222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + call conserv_interp_input(n,gridDesci(n,:), & + geosit_struc(n)%n112,geosit_struc(n)%n122, & + geosit_struc(n)%n212,geosit_struc(n)%n222, & + geosit_struc(n)%w112,geosit_struc(n)%w122, & + geosit_struc(n)%w212,geosit_struc(n)%w222) + + elseif (trim(LIS_rc%met_interp(findex)).eq."neighbor") then + allocate(geosit_struc(n)%n113(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + call neighbor_interp_input(n,gridDesci(n,:), & + geosit_struc(n)%n113) + + else + write(LIS_logunit,*) '[ERR] Interpolation option '// & + trim(LIS_rc%met_interp(findex))// & + ' for GEOS-IT forcing is not supported' + call LIS_endrun() + endif + + call LIS_registerAlarm("GEOS-IT forcing alarm",86400.0,86400.0) + geosit_struc(n)%startFlag = .true. + geosit_struc(n)%dayFlag = .true. + + geosit_struc(n)%nvars = 14 + + allocate(geosit_struc(n)%geositforc1(1, & + geosit_struc(n)%nvars, LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(geosit_struc(n)%geositforc2(1,& + geosit_struc(n)%nvars, LIS_rc%lnc(n)*LIS_rc%lnr(n))) + geosit_struc(n)%st_iterid = 1 + geosit_struc(n)%en_iterId = 1 + geosit_struc(n)%nIter = 1 + + allocate(geosit_struc(n)%metdata1(1,LIS_rc%met_nf(findex), & + LIS_rc%ngrid(n))) + allocate(geosit_struc(n)%metdata2(1,LIS_rc%met_nf(findex), & + LIS_rc%ngrid(n))) + + geosit_struc(n)%metdata1 = 0 + geosit_struc(n)%metdata2 = 0 + + geosit_struc(n)%geositforc1 = LIS_rc%udef + geosit_struc(n)%geositforc2 = LIS_rc%udef + + if ((LIS_rc%met_ecor(findex).eq."lapse-rate").or. & + (LIS_rc%met_ecor(findex).eq."lapse-rate and slope-aspect")) then + call read_geosit_elev(n,findex) + endif + +! Set up precipitation climate downscaling: + if (LIS_rc%pcp_downscale(findex).ne.0) then + call LIS_init_pcpclimo_native(n,findex,geosit_struc(n)%ncold,& + geosit_struc(n)%nrold) + endif + enddo ! End nest loop + + end subroutine init_geosit + end module geosit_forcingMod + diff --git a/lis/metforcing/geos_it/get_geosit.F90 b/lis/metforcing/geos_it/get_geosit.F90 new file mode 100644 index 000000000..bd5b1eaa2 --- /dev/null +++ b/lis/metforcing/geos_it/get_geosit.F90 @@ -0,0 +1,309 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: get_geosit +! \label{get_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 08 Dec 2015: James Geiger, update timing logic +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine get_geosit(n,findex) +! !USES: + use LIS_coreMod + use LIS_timeMgrMod + use LIS_logMod + use LIS_metforcingMod + use geosit_forcingMod + use LIS_constantsMod, only : LIS_CONST_PATH_LEN + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex +! +! !DESCRIPTION: +! Opens, reads, and interpolates 1-hourly GEOS-IT forcing. +! +! The GEOS-IT forcing data are organized into hourly files. +! The data are considered valid at the mid-point of the hourly interval. +! +! In general, metforcing readers read the forcing data before the +! current time, referred to as bookend1, and after the current time, +! referred to as bookend2. Then the readers temporally interpolate +! between bookend1 and bookend2. +! +! Below are some examples to illustrate the timing logic of the +! GEOS-IT reader. +! +! \begin{verbatim} +! ---*---|---*---|---*---|---*---|---*---|---*---|---*---|---*--- +! hour 21 22 23 0 1 2 3 +! hr_int <---22--X--23---X--24---X---1---X---2---X---3---> +! +! where: +! hour is the hour UTC +! hr_int is the hour-interval +! * marks the valid point for the interval <--- hr_int ---> +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[findex] +! forcing dataset index +! \end{description} +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_tick](\ref{LIS_tick}) \newline +! call to advance or retract time +! \item[geositfiles](\ref{geositfiles}) \newline +! Puts together appropriate file name for 1 hour intervals +! \item[read\_geosit](\ref{read_geosit}) \newline +! call to read the GEOS-IT data and perform spatial interpolation +! \end{description} +!EOP + integer :: order + integer :: ferror + character(len=LIS_CONST_PATH_LEN) :: slvname,flxname,lfoname,radname + integer :: c,f,r,kk + integer :: yr1,mo1,da1,hr1,mn1,ss1,doy1 + integer :: yr2,mo2,da2,hr2,mn2,ss2,doy2 + real*8 :: time1,time2,timenow + real :: gmt1,gmt2 + real :: ts1,ts2 + integer :: hr_int1,hr_int2 + integer :: movetime ! Flag to move bookend2 files to bookend1 + +! _________________________________________________________ +! + + if (LIS_rc%nts(n).gt.3600) then ! > 1-hr timestep + write(LIS_logunit,*) '[ERR] When running LIS with GEOS-IT,' + write(LIS_logunit,*) '[ERR] the clock should run with a time' + write(LIS_logunit,*) '[ERR] step less than or equal to 1 hr.' + call LIS_endrun() + endif + + geosit_struc(n)%findtime1 = 0 + geosit_struc(n)%findtime2 = 0 + movetime = 0 + +!---------------------------------------------------------- +! Determine current time +!---------------------------------------------------------- + yr1 = LIS_rc%yr + mo1 = LIS_rc%mo + da1 = LIS_rc%da + hr1 = LIS_rc%hr + mn1 = LIS_rc%mn + ss1 = 0 + ts1 = 0 + call LIS_tick(timenow,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + + if (LIS_rc%ts.gt.3600.0) then + write(LIS_logunit,*) & + '[ERR] The model timestep is > forcing data timestep' + write(LIS_logunit,*) & + '[ERR] LIS does not support this mode currently' + write(LIS_logunit,*) '[ERR] Program stopping ...' + call LIS_endrun() + endif + + if (mod(nint(LIS_rc%ts),3600).eq.0) then + if (timenow.ge.geosit_struc(n)%geosittime2) then + yr1 = LIS_rc%yr + mo1 = LIS_rc%mo + da1 = LIS_rc%da + hr1 = LIS_rc%hr + mn1 = 0 + ss1 = 0 + ts1 = -60*60 + call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + + yr2 = LIS_rc%yr !next hour + mo2 = LIS_rc%mo + da2 = LIS_rc%da + hr2 = LIS_rc%hr + mn2 = 0 + ss2 = 0 + ts2 = 0 + call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + endif + else + if (timenow.ge.geosit_struc(n)%geosittime2) then + yr1 = LIS_rc%yr + mo1 = LIS_rc%mo + da1 = LIS_rc%da + hr1 = LIS_rc%hr + mn1 = 0 + ss1 = 0 + ts1 = 0 + call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + geosit_struc(n)%findtime1 = 1 + + yr2 = LIS_rc%yr !next hour + mo2 = LIS_rc%mo + da2 = LIS_rc%da + hr2 = LIS_rc%hr + mn2 = 0 + ss2 = 0 + ts2 = 60*60 + call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + geosit_struc(n)%geosittime2 = time2 + endif + endif + +! Beginning of the run + if ((LIS_rc%tscount(n).eq.1).or.(LIS_rc%rstflag(n).eq.1)) then + geosit_struc(n)%findtime1 = 1 + geosit_struc(n)%geosittime2 = time2 + LIS_rc%rstflag(n) = 0 + endif + +! Read GEOS-IT - Bookend 1 files: + if (geosit_struc(n)%findtime1.eq.1) then + order = 1 + do kk = geosit_struc(n)%st_iterid,geosit_struc(n)%en_iterid + call geositfiles(n,kk,findex,geosit_struc(n)%geositdir, & + doy1,yr1,mo1,da1,hr1, & + slvname,flxname,lfoname,radname) + call read_geosit(n,order,mo1,findex, & + slvname,flxname,lfoname,radname, & + geosit_struc(n)%geositforc1(kk,:,:),ferror) + enddo + geosit_struc(n)%geosittime1 = time1 + endif + +! Assign GEOS-IT forcing fields to two LIS time-interp placeholders: + do r = 1,LIS_rc%lnr(n) + do c = 1,LIS_rc%lnc(n) + if (LIS_domain(n)%gindex(c,r).ne.-1) then + geosit_struc(n)%metdata1(:,:,LIS_domain(n)%gindex(c,r)) = & + geosit_struc(n)%geositforc1(:,:,(c+(r-1)*LIS_rc%lnc(n))) + geosit_struc(n)%metdata2(:,:,LIS_domain(n)%gindex(c,r)) = & + geosit_struc(n)%geositforc2(:,:,(c+(r-1)*LIS_rc%lnc(n))) + endif + enddo + enddo + + end subroutine get_geosit + +!BOP +! !ROUTINE: geositfiles +! \label{geositfiles} +! +! !INTERFACE: + subroutine geositfiles(n,kk,findex,geositdir,doy,yr,mo,da,hr, & + slvname,flxname,lfoname,radname) + +! !USES: + use LIS_coreMod + use LIS_logMod + use LIS_timeMgrMod + + implicit none +! !ARGUMENTS: + integer :: n + integer :: kk + integer :: findex + character(len=*), intent(in) :: geositdir + integer, intent(in) :: doy,yr,mo,da,hr + character(len=*), intent(out) :: slvname + character(len=*), intent(out) :: flxname + character(len=*), intent(out) :: lfoname + character(len=*), intent(out) :: radname + +! !DESCRIPTION: +! This subroutine puts together GEOS-IT file names for +! hourly netCDF files. +! +! The arguments are: +! \begin{description} +! \item[geositdir] +! Name of the GEOS-IT directory +! \item[doy] +! day of year +! \item[yr] +! year +! \item[mo] +! month +! \item[da] +! day of month +! \item[hr] +! hour +! \item[slvname] +! name of the timestamped single level file +! \item[flxname] +! name of the timestamped flux file +! \item[lfoname] +! name of the timestamped land surface forcings file +! \item[radname] +! name of the timestamped radiation forcings file +! \end{description} +! +!EOP + + character*4 :: cyear + character*2 :: cyr,cmo,cdy,chr + character*16 :: prefix + character*31 :: slv_spec,flx_spec,lfo_spec,rad_spec + + write(unit=cyear,fmt='(i4.4)') yr + write(unit=cmo, fmt='(i2.2)') mo + write(unit=chr, fmt='(i2.2)') hr + write(unit=cdy, fmt='(i2.2)') da + + prefix = 'd5294_geosit_jan' + if (yr.lt.1998) then + write(LIS_logunit,*) '[ERR] GEOS-IT data starts 1 Jan 1998.' + call LIS_endrun() + else + cyr = '98' + endif + if (yr.ge.2008) then + cyr = '08' + endif + if (yr.ge.2018) then + cyr = '18' + endif + + slv_spec = '.slv_tavg_1hr_glo_L576x361_slv.' + flx_spec = '.flx_tavg_1hr_glo_L576x361_slv.' + lfo_spec = '.lfo_tavg_1hr_glo_L576x361_slv.' + rad_spec = '.rad_tavg_1hr_glo_L576x361_slv.' + +! Single level fields: + slvname = trim(geositdir)//'/'//prefix//cyr//'/diag/Y'//cyear// & + '/M'//cmo//'/'//prefix//cyr//slv_spec//cyear//'-'// & + cmo//'-'//cdy//'T'//chr//'30Z.nc4' + +! Flux fields: + flxname = trim(geositdir)//'/'//prefix//cyr//'/diag/Y'//cyear// & + '/M'//cmo//'/'//prefix//cyr//flx_spec//cyear//'-'// & + cmo//'-'//cdy//'T'//chr//'30Z.nc4' + +! Land surface forcing level: + lfoname = trim(geositdir)//'/'//prefix//cyr//'/diag/Y'//cyear// & + '/M'//cmo//'/'//prefix//cyr//lfo_spec//cyear//'-'// & + cmo//'-'//cdy//'T'//chr//'30Z.nc4' + +! Radiation fields: + radname = trim(geositdir)//'/'//prefix//cyr//'/diag/Y'//cyear// & + '/M'//cmo//'/'//prefix//cyr//rad_spec//cyear//'-'// & + cmo//'-'//cdy//'T'//chr//'30Z.nc4' + + end subroutine geositfiles + diff --git a/lis/metforcing/geos_it/read_geosit.F90 b/lis/metforcing/geos_it/read_geosit.F90 new file mode 100644 index 000000000..8e34b9381 --- /dev/null +++ b/lis/metforcing/geos_it/read_geosit.F90 @@ -0,0 +1,487 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: read_geosit +! \label{read_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine read_geosit(n,order,month,findex, & + slvname,flxname,lfoname,radname, & + geositforc,ferror) +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_domain, LIS_masterproc + use LIS_logMod + use LIS_FORC_AttributesMod + use LIS_metforcingMod, only : LIS_forc + use geosit_forcingMod, only : geosit_struc +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: order + integer, intent(in) :: month + integer, intent(in) :: findex + character(len=*), intent(in) :: slvname + character(len=*), intent(in) :: flxname + character(len=*), intent(in) :: lfoname + character(len=*), intent(in) :: radname + real, intent(inout) :: geositforc(geosit_struc(n)%nvars,& + LIS_rc%lnc(n)*LIS_rc%lnr(n)) + integer, intent(out) :: ferror + +! !DESCRIPTION: +! For the given time, reads parameters from GEOS-IT data, transforms +! into 9 LIS forcing parameters and interpolates to the LIS domain. \newline +! +! GEOS-IT FORCING VARIABLES: \newline +! 1. tair Temperature of air at 2-m, 10-m, or LML [$K$] \newline +! 2. qair Specific humidity of air at 2-m, 10-m, or LML [$kg/kg$] \newline +! 3. swgdn Downward shortwave radiation at the ground [$W/m^2$] \newline +! 4. lwgab Downward longwave radiation at the ground [$W/m^2$] \newline +! 5. uwind Zonal wind at 2-m, 10-m, or LML [$m/s$] \newline +! 6. vwind Meridional wind at 2-m, 10-m, or LML [$m/s$] \newline +! 7. ps Instantaneous Surface Pressure [$Pa$] \newline +! 8. pretot Total precipitation [$mm/s$] \newline +! 9. precon Convective precipitation [$mm/s$] \newline +! 10. presno Precipitation falling as snow [$mm/s$] \newline +! 11. swland Net shortwave radiation at the ground [$W/m^2$] \newline +! 12. pardr Surface downward PAR beam flux [$W/m^2$] \newline +! 13. pardf Surface downward PAR diffuse flux [$W/m^2$] \newline +! 14. hlml Height of center of lowest model layer (LML) [$m$] \newline +! +! The arguments are: +! \begin{description} +! \item[order] +! flag indicating which data to be read (order=1, read the previous +! 1 hourly instance, order=2, read the next 1 hourly instance) +! \item[n] +! index of the nest +! \item[name] +! name of the 1 hour GEOS-IT analysis file +! \item[tscount] +! time step count +! \item[ferror] +! return error code (0 indicates success) +! \end{description} +! +! The routines invoked are: +! \begin{description} +! \item[bilinear\_interp](\ref{bilinear_interp}) \newline +! spatially interpolate the forcing data using bilinear interpolation +! \item[conserv\_interp](\ref{conserv_interp}) \newline +! spatially interpolate the forcing data using conservative interpolation +! \end{description} +!EOP + + integer :: ftn_slv,ftn_flx,ftn_lfo,ftn_rad + integer :: tmpId,qId,uId,vId,psId + integer :: prectotId,precconId,swgdnId,lwgabId + integer :: precsnoId,hlmlID + integer :: swlandId,pardrId,pardfId + integer :: nr_index,nc_index + logical :: file_exists,file_exists1 + integer :: c,r,t,k,iret + integer :: mo + logical :: read_lnd + + real :: tair(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: qair(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: uwind(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: vwind(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: ps(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: prectot(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: precsno(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: preccon(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: swgdn(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: lwgab(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: swland(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: pardr(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: pardf(geosit_struc(n)%ncold,geosit_struc(n)%nrold) + real :: hlml(geosit_struc(n)%ncold,geosit_struc(n)%nrold) +! __________________________________________________________________________ + +#if (defined USE_NETCDF3) + write(LIS_logunit,*) "[ERR] GEOS-IT reader requires NetCDF4" + call LIS_endrun() +#endif + +#if (defined USE_NETCDF4) + ferror = 0 + nr_index = geosit_struc(n)%nrold + nc_index = geosit_struc(n)%ncold + mo = LIS_rc%lnc(n)*LIS_rc%lnr(n) + +! Read single layer file (*slv) fields: + inquire(file=slvname,exist=file_exists) + if (file_exists) then + write(LIS_logunit,*) & + '[INFO] Reading GEOS-IT file: ',trim(slvname) + call LIS_verify(nf90_open(path=trim(slvname), & + mode=NF90_NOWRITE,ncid=ftn_slv), & + 'nf90_open failed for slvfile in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_slv,'PS',psId), & + 'nf90_inq_varid failed for ps in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,psId,ps), & + 'nf90_get_var failed for ps in read_geosit') + +! If using the GEOS-IT lowest model level forcing (*flx): + if (geosit_struc(n)%uselml.eq.1) then + inquire(file=flxname,exist=file_exists1) + if (.not.file_exists1) then + write(LIS_logunit,*) & + '[ERR] ',trim(flxname)//' does not exist' + call LIS_endrun() + endif + + write(LIS_logunit,*) & + '[INFO] Reading GEOS-IT file: ',trim(flxname) + write(LIS_logunit,*) ' (for lowest model level fields)' + call LIS_verify(nf90_open(path=trim(flxname), & + mode=NF90_NOWRITE,ncid=ftn_flx), & + 'nf90_open failed for flxfile in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_flx,'TLML',tmpId), & + 'nf90_inq_varid failed for tlml in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,tmpId,tair), & + 'nf90_get_var failed for tlml in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_flx,'QLML',qId), & + 'nf90_inq_varid failed for qlml in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,qId,qair), & + 'nf90_get_var failed for qlml in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_flx,'ULML',uId), & + 'nf90_inq_varid failed for ulml in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,uId,uwind), & + 'nf90_get_var failed for ulml in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_flx,'VLML',vId), & + 'nf90_inq_varid failed for vlml in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,vId,vwind), & + 'nf90_get_var failed for vlml in read_geosit') + + call LIS_verify(nf90_close(ftn_flx), & + '[WARN] Failed to close flxfile in read_geosit.') + +! Else use the single-layer fields (e.g., 2-m ref. height): + else + call LIS_verify(nf90_inq_varid(ftn_slv,'T2M',tmpId), & + 'nf90_inq_varid failed for t2m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,tmpId,tair), & + 'nf90_get_var failed for t2m in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_slv,'QV2M',qId), & + 'nf90_inq_varid failed for qv2m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,qId,qair), & + 'nf90_get_var failed for qv2m in read_geosit') + +! Use either 2-m winds or 10-m winds: + if (geosit_struc(n)%use2mwind.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_slv,'U2M',uId), & + 'nf90_inq_varid failed for u2m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,uId,uwind), & + 'nf90_get_var failed for u2m in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_slv,'V2M',vId), & + 'nf90_inq_varid failed for v2m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,vId,vwind), & + 'nf90_get_var failed for v2m in read_geosit') + else + call LIS_verify(nf90_inq_varid(ftn_slv,'U10M',uId), & + 'nf90_inq_varid failed for u10m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,uId,uwind), & + 'nf90_get_var failed for u10m in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_slv,'V10M',vId), & + 'nf90_inq_varid failed for v10m in read_geosit') + call LIS_verify(nf90_get_var(ftn_slv,vId,vwind), & + 'nf90_get_var failed for v10m in read_geosit') + endif + endif + + call LIS_verify(nf90_close(ftn_slv), & + '[WARN] Failed to close slvfile in read_geosit.') + + call interp_geosit_var(n,findex,month,tair, 1,.false.,geositforc) + call interp_geosit_var(n,findex,month,qair, 2,.false.,geositforc) + call interp_geosit_var(n,findex,month,uwind, 5,.false.,geositforc) + call interp_geosit_var(n,findex,month,vwind, 6,.false.,geositforc) + call interp_geosit_var(n,findex,month,ps, 7,.false.,geositforc) + else + write(LIS_logunit,*) '[ERR] ',trim(slvname)//' does not exist' + call LIS_endrun() + endif + +! Read in the flux file fields (*flx): + inquire(file=flxname,exist=file_exists) + if (file_exists) then + write(LIS_logunit,*) & + '[INFO] Reading GEOS-IT file: ',trim(flxname) + call LIS_verify(nf90_open(path=trim(flxname), & + mode=NF90_NOWRITE,ncid=ftn_flx), & + 'nf90_open failed for flxfile in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_flx,'PRECTOT',prectotId), & + 'nf90_inq_varid failed for prectot in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,prectotId,prectot), & + 'nf90_get_var failed for prectot in read_geosit') + + call interp_geosit_var(n,findex,month,prectot,8,.true.,geositforc) + +! Read in the convective precipitation, if selected in the forcing table: + if (LIS_FORC_CRainf%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_flx,'PRECCON',precconId),& + 'nf90_inq_varid failed for preccon in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,precconId,preccon), & + 'nf90_get_var failed for preccon in read_geosit') + + call interp_geosit_var(n,findex,month,preccon,9,.true.,geositforc) + endif + +! Read in the snowfall field, if selected in the forcing input table: + if (LIS_FORC_Snowf%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_flx,'PRECSNO',precsnoId),& + 'nf90_inq_varid failed for precsno in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,precsnoId,precsno), & + 'nf90_get_var failed for precsno in read_geosit') + + call interp_geosit_var(n,findex,month,precsno,10,.true.,geositforc) + endif + +! Read in Forcing Height, if selected in the forcing input table: + if (LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_flx,'HLML',hlmlId), & + 'nf90_inq_varid failed for hlml in read_geosit') + call LIS_verify(nf90_get_var(ftn_flx,hlmlId,hlml), & + 'nf90_get_var failed for hlml in read_geosit') + + call interp_geosit_var(n,findex,month,hlml,14,.false.,geositforc) + endif + + call LIS_verify(nf90_close(ftn_flx), & + '[WARN] Failed to close flxfile in read_geosit.') + + else + write(LIS_logunit,*) '[ERR] ',trim(flxname)//' does not exist' + call LIS_endrun() + endif + +! Read in the radiation file fields (*rad): + inquire(file=radname,exist=file_exists) + if (file_exists) then + write(LIS_logunit,*) & + '[INFO] Reading GEOS-IT file: ',trim(radname) + call LIS_verify(nf90_open(path=trim(radname), & + mode=NF90_NOWRITE,ncid=ftn_rad), & + 'nf90_open failed for radfile in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_rad,'SWGDN',swgdnId), & + 'nf90_inq_varid failed for swgdn in read_geosit') + call LIS_verify(nf90_get_var(ftn_rad,swgdnId,swgdn), & + 'nf90_get_var failed for swgdn in read_geosit') + + call LIS_verify(nf90_inq_varid(ftn_rad,'LWGAB',lwgabId), & + 'nf90_inq_varid failed for lwgab in read_geosit') + call LIS_verify(nf90_get_var(ftn_rad,lwgabId,lwgab), & + 'nf90_get_var failed for lwgab in read_geosit') + + call interp_geosit_var(n,findex,month,swgdn,3,.false.,geositforc) + call interp_geosit_var(n,findex,month,lwgab,4,.false.,geositforc) + + call LIS_verify(nf90_close(ftn_rad), & + '[WARN] Failed to close radfile in read_geosit.') + else + write(LIS_logunit,*) '[ERR] ',trim(radname)//' does not exist' + call LIS_endrun() + endif + +! Checks: For reading in the surface layer file fields (*lfo): + read_lnd = .false. + if ((LIS_FORC_Pardr%selectOpt.eq.1).or. & + (LIS_FORC_Pardf%selectOpt.eq.1).or. & + (LIS_FORC_SWnet%selectOpt.eq.1)) then + read_lnd = .true. + endif + +! Read in the surface layer fields (*lfo): + if (read_lnd) then + inquire(file=lfoname,exist=file_exists) + if (file_exists) then + write(LIS_logunit,*) & + '[INFO] Reading GEOS-IT file: ',trim(radname) + call LIS_verify(nf90_open(path=trim(radname), & + mode=NF90_NOWRITE,ncid=ftn_rad), & + 'nf90_open failed for radfile in read_geosit') + + if (LIS_FORC_SWnet%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_lfo,'SWLAND',swlandId),& + 'nf90_inq_varid failed for swland in read_geosit') + call LIS_verify(nf90_get_var(ftn_lfo,swlandId,swland), & + 'nf90_get_var failed for swland in read_geosit') + + call interp_geosit_var(n,findex,month,swland,11,.false.,geositforc) + endif + + if (LIS_FORC_Pardr%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_lfo,'PARDR',pardrId),& + 'nf90_inq_varid failed for pardr in read_geosit') + call LIS_verify(nf90_get_var(ftn_lfo,pardrId,pardr), & + 'nf90_get_var failed for pardr in read_geosit') + + call interp_geosit_var(n,findex,month,pardr,12,.false.,geositforc) + endif + + if (LIS_FORC_Pardf%selectOpt.eq.1) then + call LIS_verify(nf90_inq_varid(ftn_lfo,'PARDF',pardfId),& + 'nf90_inq_varid failed for pardf in read_geosit') + call LIS_verify(nf90_get_var(ftn_lfo,pardfId,pardf), & + 'nf90_get_var failed for pardf in read_geosit') + + call interp_geosit_var(n,findex,month,pardf,13,.false.,geositforc) + endif + + call LIS_verify(nf90_close(ftn_lfo), & + '[WARN] Failed to close lfofile in read_geosit.') + + else + write(LIS_logunit,*) '[ERR] ',trim(lfoname)// & + ' does not exist' + call LIS_endrun() + endif + endif +#endif + + end subroutine read_geosit + +!BOP +! +! !ROUTINE: interp_geosit_var +! \label{interp_geosit_var} +! +! !INTERFACE: + subroutine interp_geosit_var(n,findex,month,input_var,var_index, & + pcp_flag,geositforc) + +! !USES: + use LIS_coreMod + use LIS_logMod + use LIS_spatialDownscalingMod + use geosit_forcingMod, only : geosit_struc +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex + integer, intent(in) :: month + real, intent(in) :: input_var(geosit_struc(n)%ncold, & + geosit_struc(n)%nrold) + integer, intent(in) :: var_index + logical, intent(in) :: pcp_flag + real, intent(inout) :: geositforc(geosit_struc(n)%nvars, & + LIS_rc%lnc(n)*LIS_rc%lnr(n)) + +! !DESCRIPTION: +! This subroutine spatially interpolates a GEOS-IT field +! to the LIS running domain +! +!EOP + integer :: t,c,r,k,iret + integer :: doy + integer :: ftn + integer :: pcp1Id,pcp2Id,pcp3Id,pcp4Id,pcp5Id,pcp6Id + real :: f (geosit_struc(n)%ncold*geosit_struc(n)%nrold) + logical*1 :: lb(geosit_struc(n)%ncold*geosit_struc(n)%nrold) + logical*1 :: lo(LIS_rc%lnc(n)*LIS_rc%lnr(n)) + integer :: input_size + logical :: scal_read_flag +! _____________________________________________________________ + + input_size = geosit_struc(n)%ncold*geosit_struc(n)%nrold + +!----------------------------------------------------------------------- +! Apply downscaling +!----------------------------------------------------------------------- + lb = .true. + do r = 1,geosit_struc(n)%nrold + do c = 1,geosit_struc(n)%ncold + k = c+(r-1)*geosit_struc(n)%ncold + f(k) = input_var(c,r) + if (f(k).eq.1.e+15) then + f(k) = LIS_rc%udef + lb(k) = .false. + endif + enddo + enddo + + if (pcp_flag.and.(LIS_rc%pcp_downscale(findex).ne.0)) then +! input_data becomes the ratio field. + call LIS_generatePcpClimoRatioField(n,findex,"GEOS-IT", & + month,input_size,f,lb) + endif + + if (pcp_flag.and. & + (trim(LIS_rc%met_interp(findex)).eq."budget-bilinear")) then + + call conserv_interp(LIS_rc%gridDesc(n,:),lb,f,lo, & + geositforc(var_index,:), & + geosit_struc(n)%mi,LIS_rc%lnc(n)*LIS_rc%lnr(n), & + LIS_domain(n)%lat,LIS_domain(n)%lon, & + geosit_struc(n)%w112,geosit_struc(n)%w122, & + geosit_struc(n)%w212,geosit_struc(n)%w222, & + geosit_struc(n)%n112,geosit_struc(n)%n122, & + geosit_struc(n)%n212,geosit_struc(n)%n222, & + LIS_rc%udef,iret) + + elseif ((trim(LIS_rc%met_interp(findex)).eq."bilinear").or. & + (trim(LIS_rc%met_interp(findex)).eq."budget-bilinear")) then + call bilinear_interp(LIS_rc%gridDesc(n,:),lb,f,lo, & + geositforc(var_index,:), & + geosit_struc(n)%mi,LIS_rc%lnc(n)*LIS_rc%lnr(n), & + LIS_domain(n)%lat,LIS_domain(n)%lon, & + geosit_struc(n)%w111,geosit_struc(n)%w121, & + geosit_struc(n)%w211,geosit_struc(n)%w221, & + geosit_struc(n)%n111,geosit_struc(n)%n121, & + geosit_struc(n)%n211,geosit_struc(n)%n221, & + LIS_rc%udef,iret) + + elseif (trim(LIS_rc%met_interp(findex)).eq."neighbor") then + call neighbor_interp(LIS_rc%gridDesc(n,:),lb,f,lo, & + geositforc(var_index,:), & + geosit_struc(n)%mi,LIS_rc%lnc(n)*LIS_rc%lnr(n), & + LIS_domain(n)%lat,LIS_domain(n)%lon, & + geosit_struc(n)%n113,LIS_rc%udef,iret) + + else + write(LIS_logunit,*) '[ERR] Spatial interpolation option '// & + trim(LIS_rc%met_interp(findex))// & + ' not supported for GEOS-IT.' + call LIS_endrun() + endif + + if (pcp_flag.and.(LIS_rc%pcp_downscale(findex).ne.0)) then + call LIS_pcpClimoDownscaling(n,findex,month, & + LIS_rc%lnc(n)*LIS_rc%lnr(n),geositforc(var_index,:),lo) + endif + + end subroutine interp_geosit_var + diff --git a/lis/metforcing/geos_it/read_geosit_elev.F90 b/lis/metforcing/geos_it/read_geosit_elev.F90 new file mode 100644 index 000000000..8660048f7 --- /dev/null +++ b/lis/metforcing/geos_it/read_geosit_elev.F90 @@ -0,0 +1,78 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: read_geosit_elev +! \label{read_geosit_elev} +! +! !REVISION HISTORY: +! +! 22 Sep 2016: James Geiger; Initial Specification +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine read_geosit_elev(n,findex) +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_metforcingMod, only : LIS_forc + use LIS_fileIOMod, only : LIS_read_param + use LIS_logMod, only : LIS_logunit + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex + +! !DESCRIPTION: +! +! Opens and reads MERRA-2 model elevation to the LIS grid. +! The MERRA-2 elevation is the same as the GEOS-IT elevation. +! The data will be used to perform any topographical adjustments +! to the forcing. +! +! The elevation file needs to be preprocessed to fit the running +! resolution and domain. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[findex] +! index of the forcing source +! \end{description} +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_readData](\ref{LIS_readData}) \newline +! Abstract method to read the elevation of the forcing +! data in the same map projection used in LIS. +! \end{description} +!EOP + + integer :: c,r + real :: go(LIS_rc%lnc(n),LIS_rc%lnr(n)) + + if (trim(LIS_rc%met_ecor(findex)).ne."none") then + write(LIS_logunit,*) & + 'Reading the GEOS-IT/MERRA-2 elevation map ...' + + call LIS_read_param(n,"ELEV_MERRA2",go) + + do r = 1,LIS_rc%lnr(n) + do c = 1,LIS_rc%lnc(n) + if (LIS_domain(n)%gindex(c,r).ne.-1) then + LIS_forc(n,findex)%modelelev(LIS_domain(n)%gindex(c,r)) = go(c,r) + endif + enddo + enddo + endif + + end subroutine read_geosit_elev + diff --git a/lis/metforcing/geos_it/readcrd_geosit.F90 b/lis/metforcing/geos_it/readcrd_geosit.F90 new file mode 100644 index 000000000..12c2d7a73 --- /dev/null +++ b/lis/metforcing/geos_it/readcrd_geosit.F90 @@ -0,0 +1,75 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: readcrd_geosit +! \label{readcrd_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine readcrd_geosit() +! !USES: + use ESMF + use LIS_logMod + use LIS_coreMod, only : LIS_rc,LIS_config + use geosit_forcingMod, only : geosit_struc +! +! !DESCRIPTION: +! +! This routine reads the options specific to GEOS-IT forcing +! from the LIS configuration file. +! +!EOP + implicit none + + integer :: n,t,rc + + call ESMF_ConfigFindLabel(LIS_config, & + "GEOS-IT forcing directory:",rc=rc) + do n = 1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + geosit_struc(n)%geositdir,rc=rc) + call LIS_verify(rc,'GEOS-IT forcing directory: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config, & + "GEOS-IT use lowest model level forcing:",rc=rc) + do n = 1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + geosit_struc(n)%uselml,rc=rc) + call LIS_verify(rc, & + 'GEOS-IT use lowest model level forcing: not defined') + enddo + + if (geosit_struc(n)%uselml.eq.0) then + call ESMF_ConfigFindLabel(LIS_config, & + "GEOS-IT use 2m wind fields:",rc=rc) + do n = 1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + geosit_struc(n)%use2mwind,rc=rc) + call LIS_verify(rc, & + 'GEOS-IT use 2m wind fields: not defined') + enddo + endif + + do n = 1,LIS_rc%nnest + write(LIS_logunit,*) '[INFO] Using GEOS-IT forcing' + write(LIS_logunit,*) '[INFO] GEOS-IT forcing directory: ', & + trim(geosit_struc(n)%geositdir) + + geosit_struc(n)%geosittime1 = 3000.0 + geosit_struc(n)%geosittime2 = 0.0 + enddo + + end subroutine readcrd_geosit + diff --git a/lis/metforcing/geos_it/reset_geosit.F90 b/lis/metforcing/geos_it/reset_geosit.F90 new file mode 100644 index 000000000..e1032bc2a --- /dev/null +++ b/lis/metforcing/geos_it/reset_geosit.F90 @@ -0,0 +1,43 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !MODULE: reset_geosit +! \label{reset_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine reset_geosit +! !USES: + use LIS_coreMod, only : LIS_rc + use LIS_timeMgrMod, only : LIS_date2time + use geosit_forcingMod +! +! !DESCRIPTION: +! Routine to cleanup allocated structures for GEOS-IT forcing. +! +!EOP + implicit none + + integer :: n + + do n = 1,LIS_rc%nnest + geosit_struc(n)%startFlag = .true. + geosit_struc(n)%dayFlag = .true. + geosit_struc(n)%geosittime1 = 3000.0 + geosit_struc(n)%geosittime2 = 0.0 + geosit_struc(n)%ringtime = 0.0 + geosit_struc(n)%reset_flag = .true. + enddo + + end subroutine reset_geosit + diff --git a/lis/metforcing/geos_it/timeinterp_geosit.F90 b/lis/metforcing/geos_it/timeinterp_geosit.F90 new file mode 100644 index 000000000..d62624b60 --- /dev/null +++ b/lis/metforcing/geos_it/timeinterp_geosit.F90 @@ -0,0 +1,294 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !ROUTINE: timeinterp_geosit +! \label{timeinterp_geosit} +! +! !REVISION HISTORY: +! 18 Mar 2015: James Geiger, initial code (based on merra-land) +! 20 Apr 2023: David Mocko, initial code (based on merra2) +! +! !INTERFACE: + subroutine timeinterp_geosit(n,findex) + +! !USES: + use ESMF + use LIS_FORC_AttributesMod + use LIS_coreMod, only : LIS_rc,LIS_domain,LIS_localPet + use LIS_metforcingMod, only : LIS_forc,LIS_FORC_Base_State + use LIS_constantsMod, only : LIS_CONST_SOLAR + use LIS_timeMgrMod, only : LIS_tick + use LIS_logMod, only : LIS_logunit,LIS_verify,LIS_endrun + use geosit_forcingMod, only : geosit_struc + use LIS_forecastMod, only : LIS_get_iteration_index + use LIS_ran2_gasdev + + implicit none + +! !ARGUMENTS: + integer, intent(in):: n + integer, intent(in):: findex +! +! !DESCRIPTION: +! Temporally interpolates the forcing data to the current model +! timestep. Because all variables are a 1-hourly time average, +! no interpolation in time is actually performed. The identical +! data is used for all timesteps within the hourly input file. +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_time2date](\ref{LIS_time2date}) \newline +! converts the time to a date format +! \item[zterp](\ref{zterp}) \newline +! zenith-angle based interpolation +! \end{description} +!EOP + integer :: t,zdoy,k,kk + integer :: index1 + integer :: bdoy,byr,bmo + integer :: bda,bhr,bmn + integer :: bss + real*8 :: btime + real :: wt1,wt2,czb,cze,czm,gmt1,gmt2 + real :: zw1,zw2,bts + integer :: status + integer :: mfactor,m + type(ESMF_Field) :: tairField,qairField,swgdnField,lwgabField + type(ESMF_Field) :: uwindField,vwindField,psField + type(ESMF_Field) :: prectotField,precconField,precsnoField + type(ESMF_Field) :: swlandField,pardrField,pardfField,hlmlField + real,pointer :: tair(:),qair(:),swgdn(:),lwgab(:) + real,pointer :: uwind(:),vwind(:),ps(:) + real,pointer :: prectot(:),preccon(:),precsno(:) + real,pointer :: swland(:),pardr(:),pardf(:),hlml(:) + + btime = geosit_struc(n)%geosittime1 + byr = LIS_rc%yr + bmo = LIS_rc%mo + bda = LIS_rc%da + bhr = LIS_rc%hr + bmn = 30 + bss = 0 + if (LIS_rc%mn.lt.30) then + bts = -(60*60) + else + bts = 0 + endif + call LIS_tick(btime,bdoy,gmt1,byr,bmo,bda,bhr,bmn,bss,bts) + + btime = geosit_struc(n)%geosittime2 + byr = LIS_rc%yr !next hour + bmo = LIS_rc%mo + bda = LIS_rc%da + bhr = LIS_rc%hr + bmn = 30 + bss = 0 + if (LIS_rc%mn.lt.30) then + bts = 0 + else + bts = 60*60 + endif + call LIS_tick(btime,bdoy,gmt2,byr,bmo,bda,bhr,bmn,bss,bts) + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Tair%varname(1),tairField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Tair in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Qair%varname(1),QairField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Qair in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_SWdown%varname(1),swgdnField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable SWdown in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_LWdown%varname(1),lwgabField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable LWdown in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Wind_E%varname(1),uwindField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Wind_E in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Wind_N%varname(1),vwindField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Wind_N in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Psurf%varname(1),psField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Psurf in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Rainf%varname(1),prectotField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Rainf in the forcing variables list') + + if (LIS_FORC_CRainf%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_CRainf%varname(1),precconField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable CRainf in the forcing variables list') + endif + + if (LIS_FORC_Snowf%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Snowf%varname(1),precsnoField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Snowf in the forcing variables list') + endif + + if (LIS_FORC_Swnet%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Swnet%varname(1),swlandField,& + rc=status) + call LIS_verify(status, & + 'Error: Enable SWnet in the forcing variables list') + endif + + if (LIS_FORC_Pardr%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Pardr%varname(1),pardrField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable PARDR in the forcing variables list') + endif + + if (LIS_FORC_Pardf%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Pardf%varname(1),pardfField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable PARDF in the forcing variables list') + endif + + if (LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Forc_Hgt%varname(1),hlmlField, & + rc=status) + call LIS_verify(status, & + 'Error: Enable Forc_Hgt in the forcing variables list') + endif + + call ESMF_FieldGet(tairField,localDE=0,farrayPtr=tair,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(qairField,localDE=0,farrayPtr=qair,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(swgdnField,localDE=0,farrayPtr=swgdn,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(lwgabField,localDE=0,farrayPtr=lwgab,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(uwindField,localDE=0,farrayPtr=uwind,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(vwindField,localDE=0,farrayPtr=vwind,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(psField,localDE=0,farrayPtr=ps,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(prectotField,localDE=0,farrayPtr=prectot,rc=status) + call LIS_verify(status) + + if (LIS_FORC_CRainf%selectOpt.eq.1) then + call ESMF_FieldGet(precconField,localDE=0,farrayPtr=preccon,rc=status) + call LIS_verify(status) + endif + + if (LIS_FORC_Snowf%selectOpt.eq.1) then + call ESMF_FieldGet(precsnoField,localDE=0,farrayPtr=precsno,rc=status) + call LIS_verify(status) + endif + + if (LIS_FORC_Swnet%selectOpt.eq.1) then + call ESMF_FieldGet(swlandField,localDE=0,farrayPtr=swland,rc=status) + call LIS_verify(status) + endif + + if (LIS_FORC_Pardr%selectOpt.eq.1) then + call ESMF_FieldGet(pardrField,localDE=0,farrayPtr=pardr,rc=status) + call LIS_verify(status) + endif + + if (LIS_FORC_Pardf%selectOpt.eq.1) then + call ESMF_FieldGet(pardfField,localDE=0,farrayPtr=pardf,rc=status) + call LIS_verify(status) + endif + + if (LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + call ESMF_FieldGet(hlmlField,localDE=0,farrayPtr=hlml,rc=status) + call LIS_verify(status) + endif + + mfactor = LIS_rc%nensem(n)/geosit_struc(n)%nIter + + do k = 1,LIS_rc%ntiles(n)/mfactor + do m = 1,mfactor + t = m + (k-1)*mfactor + index1 = LIS_domain(n)%tile(t)%index + kk = LIS_get_iteration_index(n,k,index1,mfactor) + + tair(t) = geosit_struc(n)%metdata1(kk,1,index1) + qair(t) = geosit_struc(n)%metdata1(kk,2,index1) + swgdn(t) = geosit_struc(n)%metdata1(kk,3,index1) + if (swgdn(t).gt.LIS_CONST_SOLAR) then + swgdn(t) = LIS_CONST_SOLAR + endif + lwgab(t) = geosit_struc(n)%metdata1(kk,4,index1) + uwind(t) = geosit_struc(n)%metdata1(kk,5,index1) + vwind(t) = geosit_struc(n)%metdata1(kk,6,index1) + ps(t) = geosit_struc(n)%metdata1(kk,7,index1) + prectot(t) = geosit_struc(n)%metdata1(kk,8,index1) + if (prectot(t).lt.0.0) then + prectot(t) = 0.0 + endif + if (LIS_FORC_CRainf%selectOpt.eq.1) then + preccon(t) = geosit_struc(n)%metdata1(kk,9,index1) + endif + if (LIS_FORC_Snowf%selectOpt.eq.1) then + precsno(t) = geosit_struc(n)%metdata1(kk,10,index1) + endif + if (LIS_FORC_Swnet%selectOpt.eq.1) then + swland(t) = geosit_struc(n)%metdata1(kk,11,index1) + endif + if (LIS_FORC_Pardr%selectOpt.eq.1) then + pardr(t) = geosit_struc(n)%metdata1(kk,12,index1) + endif + if (LIS_FORC_Pardf%selectOpt.eq.1) then + pardf(t) = geosit_struc(n)%metdata1(kk,13,index1) + endif + if (LIS_FORC_Forc_Hgt%selectOpt.eq.1) then + hlml(t) = geosit_struc(n)%metdata1(kk,14,index1) + endif + enddo + enddo + + end subroutine timeinterp_geosit + diff --git a/lis/plugins/LIS_metforcing_pluginMod.F90 b/lis/plugins/LIS_metforcing_pluginMod.F90 index 0d2c148d3..a4f06a4cd 100644 --- a/lis/plugins/LIS_metforcing_pluginMod.F90 +++ b/lis/plugins/LIS_metforcing_pluginMod.F90 @@ -136,6 +136,10 @@ subroutine LIS_metforcing_plugin use merra2_forcingMod #endif +#if ( defined MF_GEOS_IT ) + use geosit_forcingMod +#endif + #if ( defined MF_ERA5 ) use era5_forcingMod #endif @@ -380,6 +384,13 @@ subroutine LIS_metforcing_plugin external reset_merra2 #endif +#if ( defined MF_GEOS_IT ) + external get_geosit + external timeinterp_geosit + external finalize_geosit + external reset_geosit +#endif + #if ( defined MF_ERA5 ) external get_era5 external timeinterp_era5 @@ -778,6 +789,16 @@ subroutine LIS_metforcing_plugin call registerfinalmetforc(trim(LIS_merra2Id)//char(0),finalize_merra2) #endif +#if ( defined MF_GEOS_IT ) +! - GEOS-IT Forcing: + call registerinitmetforc(trim(LIS_geositId)//char(0),init_geosit) + call registerretrievemetforc(trim(LIS_geositId)//char(0),get_geosit) + call registertimeinterpmetforc(trim(LIS_geositId)//char(0), & + timeinterp_geosit) + call registerresetmetforc(trim(LIS_geositId)//char(0),reset_geosit) + call registerfinalmetforc(trim(LIS_geositId)//char(0),finalize_geosit) +#endif + #if ( defined MF_ERA5) ! - ERA5 Reanalysis Forcing: call registerinitmetforc(trim(LIS_era5Id)//char(0),init_ERA5) diff --git a/lis/plugins/LIS_pluginIndices.F90 b/lis/plugins/LIS_pluginIndices.F90 index 8f9d57b15..352625ac3 100644 --- a/lis/plugins/LIS_pluginIndices.F90 +++ b/lis/plugins/LIS_pluginIndices.F90 @@ -135,6 +135,7 @@ module LIS_pluginIndices character*50, public, parameter :: LIS_gldasId = "GLDAS" character*50, public, parameter :: LIS_gfsId = "GFS" character*50, public, parameter :: LIS_merra2Id = "MERRA2" + character*50, public, parameter :: LIS_geositId = "GEOS-IT" character*50, public, parameter :: LIS_cmapId = "CMAP" character*50, public, parameter :: LIS_chirps2Id = "CHIRPS2" From 6fba4aedc0adbc3c6ad6a39edc2e893292a654c4 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Fri, 21 Apr 2023 15:54:16 -0400 Subject: [PATCH 129/328] Add do loop to avoid array bounds error. --- lis/metforcing/geos_it/readcrd_geosit.F90 | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/lis/metforcing/geos_it/readcrd_geosit.F90 b/lis/metforcing/geos_it/readcrd_geosit.F90 index 12c2d7a73..6aba34e62 100644 --- a/lis/metforcing/geos_it/readcrd_geosit.F90 +++ b/lis/metforcing/geos_it/readcrd_geosit.F90 @@ -32,7 +32,7 @@ subroutine readcrd_geosit() !EOP implicit none - integer :: n,t,rc + integer :: n,t,rc,m call ESMF_ConfigFindLabel(LIS_config, & "GEOS-IT forcing directory:",rc=rc) @@ -51,16 +51,18 @@ subroutine readcrd_geosit() 'GEOS-IT use lowest model level forcing: not defined') enddo - if (geosit_struc(n)%uselml.eq.0) then - call ESMF_ConfigFindLabel(LIS_config, & + do m = 1, LIS_rc%nnest + if (geosit_struc(m)%uselml.eq.0) then + call ESMF_ConfigFindLabel(LIS_config, & "GEOS-IT use 2m wind fields:",rc=rc) - do n = 1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config, & + do n = 1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & geosit_struc(n)%use2mwind,rc=rc) - call LIS_verify(rc, & + call LIS_verify(rc, & 'GEOS-IT use 2m wind fields: not defined') - enddo - endif + enddo + endif + enddo do n = 1,LIS_rc%nnest write(LIS_logunit,*) '[INFO] Using GEOS-IT forcing' From 80d4beee0019228431d2cefe79f1ddb7825445f2 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 24 Apr 2023 18:21:27 -0400 Subject: [PATCH 130/328] Update the LISF AppImage workflow for the master branch This adds PETSc to the compile_lisf script. PETSc support is disabled because this library has not yet been installed into the lisf_libraries image. --- .github/scripts/appimage/compile_lisf | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/scripts/appimage/compile_lisf b/.github/scripts/appimage/compile_lisf index 4614a6032..fa0999f4a 100755 --- a/.github/scripts/appimage/compile_lisf +++ b/.github/scripts/appimage/compile_lisf @@ -54,9 +54,10 @@ printf '%s\n' "0" "2" "2" "2" "4" "1" "1" "1" "1" "1" "1" "1" "1" "1" | ./config # Use LIS-CMEM? (1-yes, 0-no, default=0): 0 # Use LIS-LAPACK? (1-yes, 0-no, default=0): 0 # Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): 0 +# Use PETSc? (1-yes, 0-no, default=0): 0 cd ../lis -printf '%s\n' "1" "2" "2" "2" "0" "1" "4" "1" "1" "1" "1" "1" "1" "0" "0" "0" "0" "0" | ./configure +printf '%s\n' "1" "2" "2" "2" "0" "1" "4" "1" "1" "1" "1" "1" "1" "0" "0" "0" "0" "0" "0" | ./configure ./compile -j 2 # From df9ba9a07f83518e89ddafe069985abcc7b505e6 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 2 May 2023 13:09:24 -0400 Subject: [PATCH 131/328] Bug fix --- ldt/core/LDT_DApreprocMod.F90 | 23 +++++++++++++++-------- ldt/core/LDT_DrangeMod.F90 | 4 ++-- 2 files changed, 17 insertions(+), 10 deletions(-) diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index e03f1cd74..b2a2b8c82 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -213,14 +213,21 @@ subroutine LDT_DApreprocInit() do r=1,LDT_rc%lnr(n) do c=1,LDT_rc%lnc(n) if(LDT_domain(n)%gindex(c,r).ne.-1) then - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = & - nint((stratification_data(c,r,j) - LDT_rc%strat_cdfs_min)/& - delta)+1 - if (LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) .gt. LDT_rc%strat_cdfs_nbins) then - write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& - 'Value adjusted to the Max Startification bins' - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins + if(stratification_data(c,r,j) .gt. 0) then + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = & + nint((stratification_data(c,r,j) - LDT_rc%strat_cdfs_min)/& + delta)+1 + if (LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) .gt. LDT_rc%strat_cdfs_nbins) then + write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& + 'Value adjusted to the Max Startification bins' + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins + endif + else + write(LDT_logunit,*) '[INFO] Total precip is zero or undefined',& + stratification_data(c,r,j) ,& + 'Value adjusted to the Min Startification bins' + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = 1 endif endif enddo diff --git a/ldt/core/LDT_DrangeMod.F90 b/ldt/core/LDT_DrangeMod.F90 index fa85ae598..a5b9bec76 100644 --- a/ldt/core/LDT_DrangeMod.F90 +++ b/ldt/core/LDT_DrangeMod.F90 @@ -385,11 +385,11 @@ subroutine computeSingleDrange(n,obs, metrics) metrics%count_drange_total(t,j,k) if(metrics%maxval(t,j,k).gt.& strat_maxval(sindex,j,k)) then - strat_maxval(sindex,j,k) = metrics%maxval(t,j,k) + strat_maxval(sindex,j,k) = metrics%maxval(t,j,k) endif if(metrics%minval(t,j,k).lt.& strat_minval(sindex,j,k)) then - strat_minval(sindex,j,k) = metrics%minval(t,j,k) + strat_minval(sindex,j,k) = metrics%minval(t,j,k) endif enddo enddo From 179d22f9f39db69fd2a771d620edef497727f03d Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 2 May 2023 18:06:34 -0400 Subject: [PATCH 132/328] Fixed the issue that happened during the resolving the conflict. --- ldt/core/LDT_DAmetricsMod.F90 | 80 ----------------------------------- 1 file changed, 80 deletions(-) diff --git a/ldt/core/LDT_DAmetricsMod.F90 b/ldt/core/LDT_DAmetricsMod.F90 index 2e1054ccc..ce02ea2d9 100644 --- a/ldt/core/LDT_DAmetricsMod.F90 +++ b/ldt/core/LDT_DAmetricsMod.F90 @@ -691,86 +691,6 @@ subroutine initMetricsEntry(nsize, obs, metrics) endif !-----------------------------------Y.Kwon endif - if(LDT_rc%daily_interp_switch.eq.0) then !Y.Kwon - allocate(metrics%mask(nsize,LDT_rc%cdf_ntimes, obs%vlevels)) - allocate(metrics%maxval(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%minval(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - metrics%mask = LDT_rc%udef - metrics%maxval = -1000000.0 - metrics%minval = 1000000.0 - allocate(metrics%count_drange_total(nsize, LDT_rc%cdf_ntimes,& - obs%vlevels)) - metrics%count_drange_total = 0 - - allocate(metrics%cdf_bincounts(nsize,& - LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) - allocate(metrics%delta(nsize,LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%xrange(nsize,& - LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) - allocate(metrics%cdf(nsize,& - LDT_rc%cdf_ntimes, obs%vlevels,LDT_rc%cdf_nbins)) - - metrics%cdf_bincounts = 0 - metrics%delta = 0 - metrics%xrange = 0 - metrics%cdf = 0 - - allocate(metrics%sx_mu(nsize, LDT_rc%cdf_ntimes, obs%vlevels)) - allocate(metrics%mu(nsize, LDT_rc%cdf_ntimes, obs%vlevels)) - allocate(metrics%count_mu(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - - metrics%sx_mu = 0 - metrics%mu = 0 - metrics%count_mu = 0 - - allocate(metrics%sx_sigma(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%sxx_sigma(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%sigma(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%count_sigma(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - - metrics%sx_sigma = 0 - metrics%sxx_sigma = 0 - metrics%sigma = 0 - metrics%count_sigma = 0 - - !-----------------------------------Y.Kwon - elseif(LDT_rc%daily_interp_switch.eq.1) then - allocate(metrics%sx_mu_6am(nsize,24,obs%vlevels)) - allocate(metrics%sx_mu_6pm(nsize,24,obs%vlevels)) - allocate(metrics%mu_6am(nsize, LDT_rc%cdf_ntimes, obs%vlevels)) - allocate(metrics%mu_6pm(nsize, LDT_rc%cdf_ntimes, obs%vlevels)) - allocate(metrics%count_mu_6am(nsize,24,obs%vlevels)) - allocate(metrics%count_mu_6pm(nsize,24,obs%vlevels)) - allocate(metrics%mask_6am(nsize,24, obs%vlevels)) - allocate(metrics%mask_6pm(nsize,24, obs%vlevels)) - - metrics%sx_mu_6am = 0 - metrics%sx_mu_6pm = 0 - metrics%mu_6am = 0 - metrics%mu_6pm = 0 - metrics%count_mu_6am = 0 - metrics%count_mu_6pm = 0 - metrics%mask_6am = LDT_rc%udef - metrics%mask_6pm = LDT_rc%udef - - allocate(metrics%sx_sigma_6am(nsize, 24,obs%vlevels)) - allocate(metrics%sx_sigma_6pm(nsize, 24,obs%vlevels)) - allocate(metrics%sxx_sigma_6am(nsize, 24,obs%vlevels)) - allocate(metrics%sxx_sigma_6pm(nsize, 24,obs%vlevels)) - allocate(metrics%sigma_6am(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%sigma_6pm(nsize, LDT_rc%cdf_ntimes,obs%vlevels)) - allocate(metrics%count_sigma_6am(nsize, 24,obs%vlevels)) - allocate(metrics%count_sigma_6pm(nsize, 24,obs%vlevels)) - - metrics%sx_sigma_6am = 0 - metrics%sx_sigma_6pm = 0 - metrics%sxx_sigma_6am = 0 - metrics%sxx_sigma_6pm = 0 - metrics%sigma_6am = 0 - metrics%sigma_6pm = 0 - metrics%count_sigma_6am = 0 - metrics%count_sigma_6pm = 0 - endif endif end subroutine initMetricsEntry From 8904d99a768cdb8d4a5cf8741339bd548ff4d057 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Tue, 9 May 2023 18:44:09 -0400 Subject: [PATCH 133/328] Updated the documentation. --- ldt/configs/ldt.config.adoc | 48 +++++++++++++++++++++++++++++++++++ ldt/core/LDT_DApreprocMod.F90 | 2 +- lis/configs/lis.config.adoc | 8 +++--- 3 files changed, 54 insertions(+), 4 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 00f8fb92c..7a45254c3 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -3703,6 +3703,54 @@ landcover.1gd4r + CDF grouping attributes file: cdf_grouping.txt .... +`Stratify CDFs by external data:` specifies whether to stratify CDFs for each pixel by an externally specified categorical map; for example, by precipitation climatology. +This option generates a stratified CDF for each grid cell. That means if the domain contains 10000 grid cells, the CDF file also has 10000 CDFs. But CDFs in grid cells with a similar precipitation climatology are the same. +Acceptable values are: + +[cols="<,<",] +|=== +|Value |Description + +|0 |do not stratify by external data +|1 |stratify by external data +|=== + +.Example _ldt.config_ entry +.... +Stratify CDFs by external data: 1 +.... + +`Number of bins to use for stratification:` specifies the number of stratification bins to use for computing the CDF. + +.Example _ldt.config_ entry +.... +Number of bins to use for stratification: 15 +.... + +`Stratification data source:` specifies the name of the stratification data source + +.Example _ldt.config_ entry +.... +Stratification data source: "LIS LSM total precipitation" +.... + +`External stratification file:` Specifies the name of a NetCDF file that contains the monthly precipitation climatology. The user needs to run an LSM and generate daily total precipitation output for a long period. Then the user needs to run LVT to generate monthly precipitation climatology. + + +.Example _ldt.config_ entry +.... +External stratification file: "LVT_MEAN_FINAL.202201010000.d01.nc" +.... + + +`Write stratified geolocation independent CDFs:` specifies whether to write the stratified CDF or not. +This option eliminates the similar CDFs and collapses the stratified CDFs into a number of stratified bins. For example, if the domain contains 10000 grid cells and you chose to stratify the CDFs to 15 precipitation bins. This option collapses the 10000 CDFs to 15 CDFs. This CDF is a geolocation independent CDFs. + +.Example _ldt.config_ entry +.... +Write stratified geolocation independent CDFs: 1 +.... + `Temporal averaging interval:` specifies temporal averaging interval to be used while computing the CDF. .Example _ldt.config_ entry diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index 917e88ee8..5a47da57c 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -238,7 +238,7 @@ subroutine LDT_DApreprocInit() endif else write(LDT_logunit,*) '[INFO] Total precip is zero or undefined',& - stratification_data(c,r,j) ,& + stratification_data(c,r,j) ,c,r,j,& 'Value adjusted to the Min Startification bins' LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = 1 endif diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 7be9c016f..a8515881f 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -3023,10 +3023,12 @@ whether the observation error standard deviation is to be scaled using model and observation standard deviation. `SMAP(NASA) model CDF file:` specifies the name of the model CDF file -(observations will be scaled into this climatology). +(observations will be scaled into this climatology). +Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. `SMAP(NASA) observation CDF file:` specifies the name of the observation CDF file. +Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. `SMAP(NASA) soil moisture number of bins in the CDF:` specifies the number of bins in the CDF. @@ -3112,7 +3114,7 @@ whether to use CDF transfer method `Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory -`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF +`#Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF 'Reference domain precipitation climatology data source:' specifies the reference domain precipitation climatology generated by LVT @@ -3124,7 +3126,7 @@ whether to use CDF transfer method Use CDF transfer for soil moisture data assimilation: Reference domain model CDF file: Reference domain obs CDF file: -Number of bins in the soil moisture CDF: +#Number of bins in the soil moisture CDF: Reference domain precipitation climatology data source: Target domain precipitation climatology data source: .... From f58d5686eb92adaa8fd3ba038e46b2bad434df51 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Wed, 10 May 2023 17:57:41 -0400 Subject: [PATCH 134/328] resolvedthe issues raised by the gnu compiler --- ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 | 8 ++++---- ldt/core/LDT_DApreprocMod.F90 | 4 ++-- lis/core/LIS_dataAssimMod.F90 | 4 ++-- .../cdfTransfer_NASASMAPsm_Mod.F90 | 12 ++++++------ .../read_cdfTransfer_NASASMAPsm.F90 | 4 ++-- 5 files changed, 16 insertions(+), 16 deletions(-) diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 index 3edff6fa5..4f6a3653f 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -120,7 +120,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) deallocate(precip_climo) -#IF 0 +#if 0 call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & 'nf90_inq_dimid failed for ngrid') call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & @@ -175,7 +175,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) ! 'nf90_get_var failed for '//trim(varname)//'_CDF') ! Note: CDF is generated by LDT --> therefore data is in the LDT domain -#IF 0 +#if 0 if(ngrid.gt.0) then do kk=1,nbins call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & @@ -184,7 +184,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) cdf(:,j,kk)) enddo endif -#ENDIF +#endif enddo xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell @@ -199,7 +199,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) 'failed to close file '//trim(filename)) write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) !endif -#ENDIF +#endif ! end USE_NETCDF4 #endif diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index 5a47da57c..adfdb2420 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -248,7 +248,7 @@ subroutine LDT_DApreprocInit() enddo -#IF 0 +#if 0 !if(LDT_rc%strat_cdfs.gt.0) then allocate(LDT_rc%stratification_data(LDT_rc%ngrid(n))) allocate(stratification_data(LDT_rc%ngrid(n),2)) @@ -281,7 +281,7 @@ subroutine LDT_DApreprocInit() ! read(ftn,*) ! read(ftn,*) LDT_rc%strat_cdfs_nbins ! call LDT_releaseUnitNumber(ftn) -#ENDIF +#endif endif endif diff --git a/lis/core/LIS_dataAssimMod.F90 b/lis/core/LIS_dataAssimMod.F90 index f7be64b6c..af2693e2c 100644 --- a/lis/core/LIS_dataAssimMod.F90 +++ b/lis/core/LIS_dataAssimMod.F90 @@ -1915,7 +1915,7 @@ subroutine read_Precip_climo(n,k, filename, precip) ! enddo ! deallocate(precip_climo) -#IF 0 +#if 0 if(ngrid.gt.0) then do kk=1,nbins call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & @@ -1924,7 +1924,7 @@ subroutine read_Precip_climo(n,k, filename, precip) cdf(:,j,kk)) enddo endif -#ENDIF +#endif ! end USE_NETCDF4 #endif diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 index 5cf542a40..a486edf3f 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 @@ -198,7 +198,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call LIS_verify(status, 'SMAP(NASA) soil moisture use scaled standard deviation model: is missing') enddo -#IF 0 +#if 0 call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) model CDF file:",& rc=status) do n=1,LIS_rc%nnest @@ -212,13 +212,13 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%obscdffile,rc=status) call LIS_verify(status, 'SMAP(NASA) observation CDF file: not defined') enddo -#ENDIF +#endif call ESMF_ConfigFindLabel(LIS_config, "SMAP(NASA) soil moisture number of bins in the CDF:", rc=status) do n=1, LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) call LIS_verify(status, "SMAP(NASA) soil moisture number of bins in the CDF: not defined") enddo -#IF 0 +#if 0 do n=1, LIS_rc%nnest cdfT_SMAPsm_struc(n)%cdf_read_mon = .false. @@ -227,7 +227,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call ESMF_ConfigGetAttribute(LIS_config, cdfT_SMAPsm_struc(n)%cdf_read_opt, rc=status) call LIS_verify(status, "SMAP(NASA) CDF read option: not defined") enddo -#ENDIF +#endif call ESMF_ConfigFindLabel(LIS_config,"Use CDF transfer for soil moisture data assimilation:",& rc=status) @@ -256,13 +256,13 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) rc=status) call LIS_verify(status, 'Reference domain obs CDF file: is missing') enddo -#IF 0 +#if 0 call ESMF_ConfigFindLabel(LIS_config, "Number of bins in the soil moisture CDF:", rc=status) do n=1, LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) call LIS_verify(status, "Number of bins in the soil moisture CDF not defined") enddo -#ENDIF +#endif call ESMF_ConfigFindLabel(LIS_config,"Reference domain precipitation climatology data source:",& rc=status) diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 index 264933025..99be20224 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 @@ -588,7 +588,7 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) write(LIS_logunit,*) '[ERR] for CDF transfer method' call LIS_endrun() endif -#IF 0 +#if 0 if (LIS_rc%dascaloption(k) .eq. "CDF matching") then if (cdfT_SMAPsm_struc(n)%useSsdevScal .eq. 1) then call ESMF_StateGet(OBS_Pert_State, "Observation01", pertfield, & @@ -621,7 +621,7 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) deallocate (ssdev) endif endif -#ENDIF +#endif else call ESMF_AttributeSet(OBS_State, "Data Update Status", & .false., rc=status) From 91f8cff1d7edd66cb3d5c8e95faefc22051a2258 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 15 May 2023 14:05:56 -0400 Subject: [PATCH 135/328] New lis.config option - # of dims in latlon field This is an addition to Sujay's PR 1179 that changes the LIS lat/lon field output from 2d to 1d. The number of latlon dimensions is now an option in the lis.config file. This was done because this enables support for 1D and 2D output. Additinally, this maintains 2D support for projections that cannot be written with 1D. The logic works as follows: no entry in config, invalid entry in config, entry of 1D in config: 1D output requested check if projection supports 1D if yes: write with 1D if no: write with 2D entry of 2D in config: 2D output requested write with 2D --- lis/configs/lis.config.adoc | 18 +++ lis/core/LIS_PRIV_rcMod.F90 | 4 + lis/core/LIS_domainMod.F90 | 46 ++++++ lis/core/LIS_historyMod.F90 | 270 +++++++++++++++++++++++------------- lis/core/LIS_readConfig.F90 | 19 +++ 5 files changed, 261 insertions(+), 96 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 999186e5c..cdb0bfa37 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -10275,6 +10275,24 @@ Model output attributes file: './MODEL_OUTPUT_LIST.TBL' .... +`Number of dimensions in the lat/lon output fields:` specifies the number of dimensions +to use when writing the latitude and longitude fields of the LIS output. +Acceptable values are: + +|==== +|Value | Description + +|"1D" | 1 dimensional latitude and longitude output +| | (Note: only specific projections can be written in 1D. e.g. latlon, mercator +|"2D" | 2 dimensional latitude and longitude output +|==== + +.Example _lis.config_ entry +.... +Number of dimensions in the lat/lon output fields: "1D" +.... + + [[ssec_timeinterval,Defining a time interval]] === Defining a time interval diff --git a/lis/core/LIS_PRIV_rcMod.F90 b/lis/core/LIS_PRIV_rcMod.F90 index 26bd806bd..f8ad747b7 100644 --- a/lis/core/LIS_PRIV_rcMod.F90 +++ b/lis/core/LIS_PRIV_rcMod.F90 @@ -67,6 +67,8 @@ module LIS_PRIV_rcMod ! Total number of land tiles in the catchment-based parameter files per nest. ! \item[lis\_map\_proj] ! Choice of map projection used in LIS. +! \item[nlatlon\_dimensions] +! Choice of the dimension for output lat/lon variables ('1D' or '2D') ! \item[lsm] ! Choice of the land surface model in LIS. ! \item[param\_proj] @@ -613,6 +615,7 @@ module LIS_PRIV_rcMod ! 14 Oct 2003; Sujay Kumar; Removed LSM specific variables. ! 19 Jan 2007; Chuck Alonge; Added Flag to output parameters ! 17 Jan 2011: David Mocko, added max/min greenness & slope type +! 02 May 2023: Sujay Kumar; Add lat/lon dimension variable ! !EOP use LIS_constantsMod, only : LIS_CONST_PATH_LEN @@ -675,6 +678,7 @@ module LIS_PRIV_rcMod integer, allocatable :: obs_haloy(:) character*50 :: lis_map_proj + character*50 :: nlatlon_dimensions character*50, allocatable :: lis_obs_map_proj(:) character*50 :: lsm character*50 :: lakemodel diff --git a/lis/core/LIS_domainMod.F90 b/lis/core/LIS_domainMod.F90 index f5a445970..4cfd8eca1 100644 --- a/lis/core/LIS_domainMod.F90 +++ b/lis/core/LIS_domainMod.F90 @@ -2649,6 +2649,15 @@ subroutine readDomainInput() elseif(map_proj.eq."LAMBERT CONFORMAL") then LIS_rc%lis_map_proj = "lambert" + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The lambert map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if + ios = nf90_get_att(ftn, NF90_GLOBAL, 'TRUELAT1',LIS_domain(n)%truelat1) call LIS_verify(ios, 'Error in nf90_get_att: TRUELAT1') @@ -2707,6 +2716,15 @@ subroutine readDomainInput() elseif(map_proj.eq."POLAR STEREOGRAPHIC") then + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The polar stereographic map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if + ios = nf90_get_att(ftn, NF90_GLOBAL, 'TRUELAT1',LIS_domain(n)%truelat1) call LIS_verify(ios, 'Error in nf90_get_att: TRUELAT1') @@ -2736,6 +2754,15 @@ subroutine readDomainInput() elseif(map_proj.eq."GAUSSIAN") then + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The gaussian map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if + ios = nf90_get_att(ftn, NF90_GLOBAL, 'NUMBER OF LAT CIRCLES',& LIS_domain(n)%nlatcircles) call LIS_verify(ios, 'Error in nf90_get_att: NUMBER_OF_LAT_CIRCLES') @@ -2758,6 +2785,15 @@ subroutine readDomainInput() LIS_rc%gridDesc(n,20) = 64 elseif(map_proj.eq."HRAP") then + + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The HRAP map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if LIS_rc%gridDesc(n,1) = 8 LIS_rc%gridDesc(n,2) = LIS_rc%lnc(n) @@ -2778,6 +2814,16 @@ subroutine readDomainInput() 0.0,LIS_rc%lnc(n),LIS_rc%lnr(n),LIS_domain(n)%lisproj) elseif(map_proj.eq."UTM") then + + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The UTM map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if + LIS_rc%gridDesc(n,1) = 7 LIS_rc%gridDesc(n,2) = LIS_rc%lnc(n) diff --git a/lis/core/LIS_historyMod.F90 b/lis/core/LIS_historyMod.F90 index c3de1f724..84c65bf84 100644 --- a/lis/core/LIS_historyMod.F90 +++ b/lis/core/LIS_historyMod.F90 @@ -3270,25 +3270,38 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) #endif endif else ! 1 vertical level - if(nmodel_status.eq.1) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(2), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') - elseif(nmodel_status.eq.2) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(1), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') + ! The latlon fields for the mercator and latlon projection may be labeled as 1D + if(LIS_rc%nlatlon_dimensions == '1D') then + !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1:2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + endif + ! The latlon fields for other projections are labeled as 2D else call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& - dimids = dimID(1:2), varID=dataEntry%varId_def),& + dimids = dimID(1:2), varID=dataEntry%varID_def),& 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') endif + + #if(defined USE_NETCDF4) call LIS_verify(nf90_def_var_fill(ftn,& dataEntry%varId_def, & @@ -3425,25 +3438,39 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) !EMK END else ! 1 vertical level - if(nmodel_status.eq.1) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(2), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') - elseif(nmodel_status.eq.2) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(1), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') - else - call LIS_verify(nf90_def_var(ftn,trim(dataEntry%short_name)//'_tavg',& - nf90_float,& - dimids = dimID(1:3), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(dataEntry%short_name)//& - 'failed in defineNETCDFheadervar') - endif + ! The latlon fields for the mercator and latlon projection may be labeled as 1D + if(LIS_rc%nlatlon_dimensions == '1D') then + !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(dataEntry%short_name)//'_tavg',& + nf90_float,& + dimids = dimID(1:3), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(dataEntry%short_name)//& + 'failed in defineNETCDFheadervar') + endif + ! The latlon fields for other projections are labeled as 2D + else + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1:2), varID=dataEntry%varID_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + endif + + + #if(defined USE_NETCDF4) call LIS_verify(nf90_def_var_fill(ftn,& @@ -3592,22 +3619,33 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') else - if(nmodel_status.eq.1) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(2), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') - elseif(nmodel_status.eq.2) then - call LIS_verify(nf90_def_var(ftn,trim(short_name),& - nf90_float,& - dimids = dimID(1), varID=dataEntry%varId_def),& - 'nf90_def_var for '//trim(short_name)//& - 'failed in defineNETCDFheadervar') - else + ! The latlon fields for the mercator and latlon projection may be labeled as 1D + if(LIS_rc%nlatlon_dimensions == '1D') then + !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then + if(nmodel_status.eq.1) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + elseif(nmodel_status.eq.2) then + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + else + call LIS_verify(nf90_def_var(ftn,trim(short_name),& + nf90_float,& + dimids = dimID(1:2), varID=dataEntry%varId_def),& + 'nf90_def_var for '//trim(short_name)//& + 'failed in defineNETCDFheadervar') + endif + ! The latlon fields for other projections are labeled as 2D + else call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& - dimids = dimID(1:2), varID=dataEntry%varId_def),& + dimids = dimID(1:2), varID=dataEntry%varID_def),& 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') endif @@ -6566,6 +6604,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& integer, intent(in) :: form integer, intent(in) :: nmodel_status integer, intent(in), optional :: dim1 + integer :: gindex ! ! !DESCRIPTION: ! Write a real variable to a netcdf output file with some diagnostic @@ -6700,42 +6739,62 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo enddo - if(nmodel_status.eq.1) then ! lat - allocate(gtmplat(LIS_rc%gnr(n))) - gtmplat = LIS_rc%udef + + ! The latlon fields for the latlon and mercator projection can be 1D + if(LIS_rc%nlatlon_dimensions == '1D') then + !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then + if(nmodel_status.eq.1) then ! lat + allocate(gtmplat(LIS_rc%gnr(n))) + gtmplat = LIS_rc%udef - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - gtmplat(r) = gtmp(c,r) + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gindex = c+(r-1)*LIS_rc%gnc(n) + gtmplat(r) = LIS_domain(n)%glat(gindex) + enddo enddo - enddo - - iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& - (/LIS_rc%gnr(n)/)) - deallocate(gtmplat) - elseif(nmodel_status.eq.2) then !lon - allocate(gtmplon(LIS_rc%gnc(n))) - gtmplon = LIS_rc%udef + iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& + (/LIS_rc%gnr(n)/)) + deallocate(gtmplat) - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - gtmplon(c) = gtmp(c,r) - enddo - enddo + elseif(nmodel_status.eq.2) then !lon + allocate(gtmplon(LIS_rc%gnc(n))) + gtmplon = LIS_rc%udef + + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gindex = c+(r-1)*LIS_rc%gnc(n) + gtmplon(c) = LIS_domain(n)%glon(gindex) + enddo + enddo - iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& - (/LIS_rc%gnc(n)/)) - deallocate(gtmplon) - else - if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& + (/LIS_rc%gnc(n)/)) + deallocate(gtmplon) + + else + if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) + else + iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + endif + endif + + ! The latlon fields for other projections are 2D + else + if(PRESENT(dim1)) then iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) - else + (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) + else iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& - (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) endif endif + + if(ftn_stats.ne.-1) then if ( LIS_rc%sout ) then call stats(gtmp,LIS_rc%udef,LIS_rc%gnc(n)*LIS_rc%gnr(n),& @@ -6812,42 +6871,61 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo - if(nmodel_status.eq.1) then ! lat - allocate(gtmplat(LIS_rc%gnr(n))) - gtmplat = LIS_rc%udef + ! The latlon fields for the latlon and mercator projection can be 1D + if(LIS_rc%nlatlon_dimensions == '1D') then + !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then + if(nmodel_status.eq.1) then ! lat + allocate(gtmplat(LIS_rc%gnr(n))) + gtmplat = LIS_rc%udef - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - gtmplat(r) = gtmp(c,r) + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gindex = c+(r-1)*LIS_rc%gnc(n) + gtmplat(r) = LIS_domain(n)%glat(gindex) + enddo enddo - enddo - iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& - (/LIS_rc%gnr(n)/)) - deallocate(gtmplat) + iret = nf90_put_var(ftn,varid,gtmplat,(/1/),& + (/LIS_rc%gnr(n)/)) + deallocate(gtmplat) - elseif(nmodel_status.eq.2) then !lon - allocate(gtmplon(LIS_rc%gnc(n))) - gtmplon = LIS_rc%udef + elseif(nmodel_status.eq.2) then !lon + allocate(gtmplon(LIS_rc%gnc(n))) + gtmplon = LIS_rc%udef - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - gtmplon(c) = gtmp(c,r) + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + gindex = c+(r-1)*LIS_rc%gnc(n) + gtmplon(c) = LIS_domain(n)%glon(gindex) + enddo enddo - enddo - iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& - (/LIS_rc%gnc(n)/)) - deallocate(gtmplon) - else - if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmplon,(/1/),& + (/LIS_rc%gnc(n)/)) + deallocate(gtmplon) + + else + if(PRESENT(dim1)) then + iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) + else + iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& + (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) + endif + endif + + ! The latlon fields for other projections are 2D + else + if(PRESENT(dim1)) then iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& (/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)) - else + else iret = nf90_put_var(ftn,varid,gtmp,(/1,1/),& (/LIS_rc%gnc(n),LIS_rc%gnr(n)/)) endif endif + + if(ftn_stats.ne.-1) then if ( LIS_rc%sout ) then call stats(gtmp,LIS_rc%udef,LIS_rc%gnc(n)*LIS_rc%gnr(n),& diff --git a/lis/core/LIS_readConfig.F90 b/lis/core/LIS_readConfig.F90 index 419485c90..532ec0e84 100644 --- a/lis/core/LIS_readConfig.F90 +++ b/lis/core/LIS_readConfig.F90 @@ -29,6 +29,7 @@ ! and added parameter output option (wparm) ! 29 Dec 2007: Marv Freimund; Used trim on filenames ! 17 Jan 2011: David Mocko, added max/min greenness & slope type +! 15 May 2023 Sujay Kumar, added support for 1D lat/lon output for latlon and merc projections ! ! !INTERFACE: subroutine LIS_readConfig() @@ -134,9 +135,27 @@ subroutine LIS_readConfig() call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%runmode,& label="Running mode:",rc=rc) call LIS_verify(rc,'Running mode: option not specified in the config file') + ! call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%lis_map_proj,& ! label="Map projection of the LIS domain:",rc=rc) ! call LIS_verify(rc,'Map projection of the LIS domain: option not specified in the config file') + + ! CM Grabs new lis.config entry for number of dimensinos of the lat/on fields + call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%nlatlon_dimensions,& + label="Number of dimensions in the lat/lon output fields:",rc=rc) + call LIS_warning(rc, 'Number of dimensions in the lat/lon output fields: option not specified in the config file. Assigning value to "1D"') + + ! CM If the user did not specify the number of dimension for the lat/lon fields, use 1D. In LIS_domainMod, this will switch to 2D if the map projection can not be written with 1D. + if ( rc /= 0 ) then + LIS_rc%nlatlon_dimensions = "1D" + endif + + ! CM If the user specified an invalid dimension option, assign to "1D" + if ( LIS_rc%nlatlon_dimensions /= "1D" .AND. LIS_rc%nlatlon_dimensions /= "2D" ) then + call LIS_warning(1,'Invalid lis.config entry, "Number of dimensions in the lat/lon output fields:" Assigning value to "1D"') + LIS_rc%nlatlon_dimensions = "1D" + endif + call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%nnest,& label="Number of nests:",rc=rc) call LIS_verify(rc,'Number of nests: option not specified in the config file') From 2fb2be7681a66e0b2e46d042e074e5363b1ba39e Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 15 May 2023 14:33:17 -0400 Subject: [PATCH 136/328] Clean up lis.config.adoc and other comments --- lis/configs/lis.config.adoc | 4 ++-- lis/core/LIS_historyMod.F90 | 26 ++++++++++---------------- lis/core/LIS_readConfig.F90 | 2 +- 3 files changed, 13 insertions(+), 19 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index cdb0bfa37..895bf5881 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -10282,8 +10282,8 @@ Acceptable values are: |==== |Value | Description -|"1D" | 1 dimensional latitude and longitude output -| | (Note: only specific projections can be written in 1D. e.g. latlon, mercator +|"1D" | 1 dimensional latitude and longitude output + (Note: only specific projections can be written in 1D. e.g. latlon, mercator |"2D" | 2 dimensional latitude and longitude output |==== diff --git a/lis/core/LIS_historyMod.F90 b/lis/core/LIS_historyMod.F90 index 84c65bf84..b42c486c3 100644 --- a/lis/core/LIS_historyMod.F90 +++ b/lis/core/LIS_historyMod.F90 @@ -3270,9 +3270,8 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) #endif endif else ! 1 vertical level - ! The latlon fields for the mercator and latlon projection may be labeled as 1D + ! lat/lon fields will write in 1D if(LIS_rc%nlatlon_dimensions == '1D') then - !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then if(nmodel_status.eq.1) then call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -3292,7 +3291,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') endif - ! The latlon fields for other projections are labeled as 2D + ! lat/lon fields will write in 2D else call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -3438,9 +3437,8 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) !EMK END else ! 1 vertical level - ! The latlon fields for the mercator and latlon projection may be labeled as 1D + ! lat/lon field output will write in 1D if(LIS_rc%nlatlon_dimensions == '1D') then - !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then if(nmodel_status.eq.1) then call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -3460,7 +3458,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) 'nf90_def_var for '//trim(dataEntry%short_name)//& 'failed in defineNETCDFheadervar') endif - ! The latlon fields for other projections are labeled as 2D + ! latlon field output will write in 2D else call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -3619,9 +3617,8 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') else - ! The latlon fields for the mercator and latlon projection may be labeled as 1D + ! lat/lon field output will write in 1D if(LIS_rc%nlatlon_dimensions == '1D') then - !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then if(nmodel_status.eq.1) then call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -3641,7 +3638,7 @@ subroutine defineNETCDFheaderVar(n,ftn,dimID, dataEntry, non_model_fields) 'nf90_def_var for '//trim(short_name)//& 'failed in defineNETCDFheadervar') endif - ! The latlon fields for other projections are labeled as 2D + ! lat/lon field output will write in 2D else call LIS_verify(nf90_def_var(ftn,trim(short_name),& nf90_float,& @@ -6740,9 +6737,8 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo - ! The latlon fields for the latlon and mercator projection can be 1D + ! The latlon fields are written to 1D if(LIS_rc%nlatlon_dimensions == '1D') then - !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then if(nmodel_status.eq.1) then ! lat allocate(gtmplat(LIS_rc%gnr(n))) gtmplat = LIS_rc%udef @@ -6783,7 +6779,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& endif endif - ! The latlon fields for other projections are 2D + ! The latlon fields are written to 2D else if(PRESENT(dim1)) then iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& @@ -6871,9 +6867,8 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& enddo enddo - ! The latlon fields for the latlon and mercator projection can be 1D + ! The lat/lon fields are written to 1D if(LIS_rc%nlatlon_dimensions == '1D') then - !if(LIS_rc%lis_map_proj.eq."latlon" .OR. LIS_rc%lis_map_proj.eq."mecator" ) then if(nmodel_status.eq.1) then ! lat allocate(gtmplat(LIS_rc%gnr(n))) gtmplat = LIS_rc%udef @@ -6914,7 +6909,7 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& endif endif - ! The latlon fields for other projections are 2D + ! The latlon fields are written to 2D else if(PRESENT(dim1)) then iret = nf90_put_var(ftn,varid,gtmp,(/1,1,dim1/),& @@ -6925,7 +6920,6 @@ subroutine writevar_netcdf_withstats_real(ftn,ftn_stats, n, var,varid, mvar,& endif endif - if(ftn_stats.ne.-1) then if ( LIS_rc%sout ) then call stats(gtmp,LIS_rc%udef,LIS_rc%gnc(n)*LIS_rc%gnr(n),& diff --git a/lis/core/LIS_readConfig.F90 b/lis/core/LIS_readConfig.F90 index 532ec0e84..7c72403a7 100644 --- a/lis/core/LIS_readConfig.F90 +++ b/lis/core/LIS_readConfig.F90 @@ -140,7 +140,7 @@ subroutine LIS_readConfig() ! label="Map projection of the LIS domain:",rc=rc) ! call LIS_verify(rc,'Map projection of the LIS domain: option not specified in the config file') - ! CM Grabs new lis.config entry for number of dimensinos of the lat/on fields + ! CM Grabs new lis.config entry for number of dimensinos of the lat/lon fields call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%nlatlon_dimensions,& label="Number of dimensions in the lat/lon output fields:",rc=rc) call LIS_warning(rc, 'Number of dimensions in the lat/lon output fields: option not specified in the config file. Assigning value to "1D"') From b994d940798c31ca9f31753f422221d0c2b0066d Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 15 May 2023 16:01:47 -0400 Subject: [PATCH 137/328] Typo fix --- lis/configs/lis.config.adoc | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 895bf5881..ce0c62868 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -10283,7 +10283,7 @@ Acceptable values are: |Value | Description |"1D" | 1 dimensional latitude and longitude output - (Note: only specific projections can be written in 1D. e.g. latlon, mercator + (Note: only specific projections can be written in 1D. e.g. latlon, mercator) |"2D" | 2 dimensional latitude and longitude output |==== @@ -10292,7 +10292,6 @@ Acceptable values are: Number of dimensions in the lat/lon output fields: "1D" .... - [[ssec_timeinterval,Defining a time interval]] === Defining a time interval From f0ffaf65696bbbdffb08aefcd2f16298250a7153 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 17 May 2023 14:30:29 -0400 Subject: [PATCH 138/328] Fix typos in documentation --- lis/configs/lis.config.adoc | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index a8515881f..1d0ac8f2f 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -3108,27 +3108,27 @@ SMAP(NRT) CDF read option: ==== Transfering stratified CDFs from one domain to another `Use CDF transfer for soil moisture data assimilation:` specifies -whether to use CDF transfer method +whether to use CDF transfer method. -`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory +`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory. -`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory +`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory. -`#Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF +`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF. -'Reference domain precipitation climatology data source:' specifies the reference domain precipitation climatology generated by LVT +`Reference domain precipitation climatology data source:` specifies the reference domain precipitation climatology generated by LVT. -'Target domain precipitation climatology data source:' specifies the target domain precipitation climatology generated by LVT +`Target domain precipitation climatology data source:` specifies the target domain precipitation climatology generated by LVT. .Example _lis.config_ entry .... Use CDF transfer for soil moisture data assimilation: -Reference domain model CDF file: -Reference domain obs CDF file: -#Number of bins in the soil moisture CDF: -Reference domain precipitation climatology data source: -Target domain precipitation climatology data source: +Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc +Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc +Number of bins in the soil moisture CDF: 100 +Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc +Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc .... [[sssec_smapnasavodda,SMAP (NASA) vegetation optical depth assimilation]] From a955971fc38533174576c23ad1cdaaa2ebe3ff18 Mon Sep 17 00:00:00 2001 From: "Justin A. Pflug" Date: Fri, 9 Jun 2023 17:46:23 -0400 Subject: [PATCH 139/328] new code updates added --- .../da_snow/noahmp401_snow_update.F90 | 81 ++++++++++++++++--- 1 file changed, 68 insertions(+), 13 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 index 93e105177..8f9173232 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 @@ -16,6 +16,7 @@ ! 14 Dec 2018: Yeosang Yoon; Modified code for NoahMP 4.0.1 and SNODEP ! 15 May 2019: Yeosang Yoon; Modified for NoahMP 4.0.1 and LDTSI ! 13 Dec 2019: Eric Kemp; Replaced LDTSI with SNOW +! 05 Jun 2023: Justin Pflug; fixes for SnowModel-defined snow updates ! ! !INTERFACE @@ -59,6 +60,7 @@ subroutine noahmp401_snow_update(n, t, dsneqv, dsnowh) integer :: snl_idx,i,j,iz integer :: iloc, jloc ! needed, but not use real :: smp,sneqv,snowh + real :: snoden real :: sneqv1,snowh1 real :: ponding1,ponding2 integer :: newnode @@ -137,6 +139,22 @@ subroutine noahmp401_snow_update(n, t, dsneqv, dsnowh) stc(1:nsoil) = & noahmp401_struc(n)%noahmp401(t)%tslb(1:nsoil) + ! NMP snow density calculation + if(snowh.gt.0) then + snoden = sneqv/(snowh*1000) + else + snoden = 0.55 + endif + + ! allow snow update even in cases where changes opp. directions + ! alter snow depth change to be in direction of SWE change + if((dsneqv.gt.0.and.dsnowh.le.0).or.& + (dsneqv.lt.0.and.dsnowh.ge.0)) then + dsnowh = (dsneqv/snoden)/1000 + ! set snow depth change to zero in instance where no SWE change + elseif(dsneqv.eq.0.and.dsnowh.ne.0) then + dsnowh = 0. + endif ! from snowfall routine ! creating a new layer @@ -147,12 +165,12 @@ subroutine noahmp401_snow_update(n, t, dsneqv, dsnowh) newnode = 0 - if(isnow == 0 .and. snowh >= 0.025.and.& - (dsneqv.gt.0.and.dsnowh.gt.0)) then !mb: change limit - isnow = -1 - newnode = 1 + if(isnow.eq.0.and.dsneqv.gt.0.and.dsnowh.gt.0) then + if(snowh.ge.0.025) then + isnow = -1 + newnode = 1 + endif dzsnso(0)= snowh - snowh = 0. stc(0) = min(273.16, noahmp401_struc(n)%noahmp401(t)%sfctmp) snice(0) = sneqv snliq(0) = 0. @@ -168,23 +186,60 @@ subroutine noahmp401_snow_update(n, t, dsneqv, dsnowh) if(dsneqv.lt.0.and.dsnowh.lt.0) then snowh1 = snowh + dsnowh sneqv1 = sneqv + dsneqv +! if dsnowh adjusted since dsneqv and dsnowh in opp. directions +! can cause one or other snowh1 or sneqv1 to be negative + if(sneqv1.gt.0.and.snowh1.le.0) then + snowh = ((sneqv1/snoden)/1000)-dsnowh + snowh1 = snowh + dsnowh +! if SWE disappears, also make sure snow depth disappears + elseif(sneqv.le.0) then + sneqv = -dsneqv + sneqv1 = sneqv + dsneqv + snowh = -dsnowh + snowh1 = snowh + dsnowh + endif +! make sure snow layers currently exist in decrease case + if(dzsnso(0).eq.0) then + if(snowh.ge.0.025) then + isnow = -1 + else + isnow = 0 + endif + dzsnso(0)= snowh + stc(0) = min(273.16, noahmp401_struc(n)%noahmp401(t)%sfctmp) + snice(0) = sneqv + snliq(0) = 0. + endif if(snowh1.ge.0.and.sneqv1.ge.0) then snowh = snowh + dsnowh sneqv = sneqv + dsneqv -! update dzsnso -! how do you determine the thickness of a layer? +! snow can no longer fill layer 1 if(snowh.le.dzsnso(0)) then isnow = 0 dzsnso(-nsnow+1:(isnow-1)) = 0 dzsnso(isnow) = snowh + snice(-nsnow+1:(isnow-1)) = 0 + snice(isnow) = sneqv + snliq(-nsnow+1:isnow) = 0 +! snow can no longer fill layer 1 and 2 elseif(snowh.le.(dzsnso(0)+dzsnso(-1))) then - isnow = -1 - dzsnso(-nsnow+1:(isnow-1)) = 0 - dzsnso(isnow) = snowh -dzsnso(isnow+1) - elseif(snowh.le.(dzsnso(0)+dzsnso(-1)+dzsnso(-2))) then isnow = -2 - dzsnso(-nsnow+1:(isnow-2)) = 0 - dzsnso(isnow) = snowh -dzsnso(isnow+2) + dzsnso(-nsnow+1:isnow) = 0 + dzsnso(isnow+1) = snowh -dzsnso(0) + ! scale swe in layers by ratio of depth to pack + do snl_idx=-nsnow+1,0 + snice(snl_idx) = sneqv*(dzsnso(snl_idx)/snowh) + enddo + snliq(-nsnow+1:isnow) = 0 +! all other cases + elseif(snowh.le.(dzsnso(0)+dzsnso(-1)+dzsnso(-2))) then + isnow = -3 + dzsnso(isnow+1) = snowh -dzsnso(-1) -dzsnso(0) + ! scale swe in layers by ratio of depth to pack + do snl_idx=-nsnow+1,0 + snice(snl_idx) = sneqv*(dzsnso(snl_idx)/snowh) + enddo + snliq(-nsnow+1:isnow) = 0 endif endif endif From 5aae70baeeb0452b38bb780e940cc60bd989e6df Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 12 Jun 2023 13:08:58 -0400 Subject: [PATCH 140/328] First round of updates to the testcase walkthrough Includes typo fixes, updates to version and revision dates, adds suggestion to compile with default settings, fixes errors brought up by Hung and other more detailed desciptions when needed. Other commit may be made on top of this to add additional changes after retest --- .../public_testcase_walkthrough.adoc | 8 ++++---- docs/public_testcase_walkthrough/setup.adoc | 4 +++- docs/public_testcase_walkthrough/step_1.adoc | 8 ++++---- docs/public_testcase_walkthrough/step_3.adoc | 2 +- 4 files changed, 12 insertions(+), 10 deletions(-) diff --git a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc index df3727b17..2342840a4 100644 --- a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc +++ b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc @@ -1,7 +1,7 @@ = LIS Public Testcase Walkthrough :revnumber: 1.0 -:revdate: September 23, 2022 -:revremark: Updated for LISF Public 7.4 release +:revdate: June 1, 2023 +:revremark: Updated for LISF Public 7.5 release :imagesdir: ./images :title-page: :title-page-background-image: image:lisf_logo.png[fit=none,pdfwidth=50%,position=top] @@ -12,7 +12,7 @@ :figure-caption!: // disable figure captions // github commit known to be compatible with this walkthrough -:compatible-lisf-branch: support/lisf-public-7.3 +:compatible-lisf-branch: support/lisf-public-7.5 // urls :url-lis-website: https://lis.gsfc.nasa.gov @@ -20,7 +20,7 @@ :url-lis-testcases-data: https://portal.nccs.nasa.gov/lisdata_pub/Tutorials/Web_Version/ :url-lisf-docs: https://github.com/NASA-LIS/LISF/tree/master/docs :url-lisf-github: https://github.com/NASA-LIS/LISF -:ssh-lisf-github: git@github.com:NASA-LIS/LISF.git +:ssh-lisf-github: github:NASA-LIS/LISF.git // begin document diff --git a/docs/public_testcase_walkthrough/setup.adoc b/docs/public_testcase_walkthrough/setup.adoc index 9942ee45a..b8abd7318 100644 --- a/docs/public_testcase_walkthrough/setup.adoc +++ b/docs/public_testcase_walkthrough/setup.adoc @@ -37,12 +37,14 @@ IMPORTANT: The `{compatible-lisf-branch}` branch is known to be compatible with For information about configuration settings and detailed compilation instructions, see the {url-lisf-docs}[LISF Users' Guides,window=_blank]. In general, the compilation process for each component is as follows: +NOTE: The TARGET_OUTPUT files or "solutions" to this testcase were created using default compile configuration settings. It is recommended that default compile comfiguration settings are used. Other settings may be used, but this may result in difference between your output and the provided TARGET_OUTPUT. + [#compile-example] [source,shell,subs="attributes"] ---- % cd ldt % ./configure -> # Select compile configuration settings (see Docs)... +> # Select compile configuration settings (Default settings recommended. See docs for more)... % ./compile > # Compilation output... % mv LDT ../../ # move executable up into $WORKING_DIR diff --git a/docs/public_testcase_walkthrough/step_1.adoc b/docs/public_testcase_walkthrough/step_1.adoc index 81852abf6..972038518 100644 --- a/docs/public_testcase_walkthrough/step_1.adoc +++ b/docs/public_testcase_walkthrough/step_1.adoc @@ -81,7 +81,7 @@ Landcover spatial transform: tile [NOTE] -- -LISF configuration files use relative paths to describe file locations. Keep this in mind if you encounter any file not found errors. +LISF configuration files use relative paths to describe file locations. Keep this in mind if you encounter any "file not found" errors. -- === Noah Land Surface Model Parameters @@ -122,8 +122,8 @@ The following files are typically generated by an LDT parameter processing run: [%autowidth] |=== |`lis_input.nldas.noah36.d01.nc` |The NetCDF-formatted model parameter file which LIS reads at runtime. `d01` refers to the indexed domain, typically used as "nests" for NASA-Unified WRF simulations. -|`ldtlog.0000` |The runtime configuration file read by LDT in this stepThe output diagnostic file that provides runtime messages, including warnings and error messages. This file is useful for verifying successful run completion and troubleshooting unsuccessful runs. -|`MaskParamFill.log` |The "target" NetCDF file generated by LDT in this step. This diagnostic file informs of any disagreements between an LSM-based parameter and the landmask, and whether any parameter gridcells were "filled" to agree with the landmask. +|`ldtlog.0000` |The output diagnostic file that provides runtime messages, including warnings and error messages. This file is useful for verifying successful run completion and troubleshooting unsuccessful runs. +|`MaskParamFill.log` |This diagnostic file informs of any disagreements between an LSM-based parameter and the landmask, and whether any parameter gridcells were "filled" to agree with the landmask. |=== NOTE: The output filenames for `lis_input.nldas.noah36.d01.nc` and `ldtlog.0000` can be defined in the `ldt.config` file, but the filename of `MaskParamFill.log` cannot be modified. @@ -249,7 +249,7 @@ Where the flags `d`, `f`, and `s` enable the following options: * `f`: force comparison to continue after differences found * `s`: report identical files to terminal (by default `nccmp` runs silently if files are identical) -NOTE: The `nccmp` command will be used in future steps. Going forward, some files may not be identical, but any differences reported _should_ be small. +NOTE: The `nccmp` command will be used in future steps. Going forward, some files may not be identical, but any differences reported _should_ be small. Also note: in this step, the target lis input file was generated using `Soil texture spatial transform: mode` == Wrap-up diff --git a/docs/public_testcase_walkthrough/step_3.adoc b/docs/public_testcase_walkthrough/step_3.adoc index 4c72c490c..2306d7684 100644 --- a/docs/public_testcase_walkthrough/step_3.adoc +++ b/docs/public_testcase_walkthrough/step_3.adoc @@ -85,6 +85,6 @@ include::running_ldt.adoc[] During this run, LDT produced one output file named `LIS_EnRST_NOAH36_201801010000.d01.nc` and placed it into the `$WORKING_DIR/DA_ensrst` directory. -Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/D_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. +Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/DA_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. // TODO: ADD EXAMPLES HERE From b950bf780c3e3d3129b7e94c48a0eadddd93203d Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 14 Jun 2023 16:55:25 -0400 Subject: [PATCH 141/328] Move new lis.config entry to the Runtime options Moved the lis.config entry, "Number of dimensions in the lat/lon output fields:", under "runtime options" becuase it fits better in this section where other output configurations are being defined. --- lis/configs/lis.config.adoc | 31 +++++++++++++------------------ 1 file changed, 13 insertions(+), 18 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index ce0c62868..62e510d40 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -592,6 +592,19 @@ Acceptable values are: Output naming style: "3 level hierarchy" .... +`Number of dimensions in the lat/lon output fields:` specifies the number of dimensions to use when writing the latitude and longitude fields of the LIS output. This is an optional entry. If this entry is not used, LIS will attempt to write the lat/lon fields in 1D. If the projection being used is not compatible with 1D, LIS will write in 2D. +Acceptable values are: +|==== +|Value | Description +|"1D" | 1 dimensional latitude and longitude output + (Note: Only the latlon projection supports 1D output) +|"2D" | 2 dimensional latitude and longitude output +|==== +.Example _lis.config_ entry +.... +Number of dimensions in the lat/lon output fields: "1D" +.... + `Enable output statistics:` specifies whether to write the ASCII statistics file for the output data. Acceptable values are: @@ -10274,24 +10287,6 @@ sample MODEL_OUTPUT_LIST.TBL file for the complete specification. Model output attributes file: './MODEL_OUTPUT_LIST.TBL' .... - -`Number of dimensions in the lat/lon output fields:` specifies the number of dimensions -to use when writing the latitude and longitude fields of the LIS output. -Acceptable values are: - -|==== -|Value | Description - -|"1D" | 1 dimensional latitude and longitude output - (Note: only specific projections can be written in 1D. e.g. latlon, mercator) -|"2D" | 2 dimensional latitude and longitude output -|==== - -.Example _lis.config_ entry -.... -Number of dimensions in the lat/lon output fields: "1D" -.... - [[ssec_timeinterval,Defining a time interval]] === Defining a time interval From ae95fdb0d6c9cb6e7052c5fb8d1612ae79cf3adc Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Wed, 14 Jun 2023 16:59:36 -0400 Subject: [PATCH 142/328] 1D latlon fields option ONLY for latlon proj. Prior, I had thought the mercator projection could be written with 1D lat/lon fields. With this commit I make it so only the latlon proj can be written with 1D latlon fields. Mercator and all other projections will continue to be written in 2D. --- lis/core/LIS_domainMod.F90 | 9 +++++++++ lis/core/LIS_readConfig.F90 | 4 ++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/lis/core/LIS_domainMod.F90 b/lis/core/LIS_domainMod.F90 index 4cfd8eca1..db4a7e0a4 100644 --- a/lis/core/LIS_domainMod.F90 +++ b/lis/core/LIS_domainMod.F90 @@ -2689,6 +2689,15 @@ subroutine readDomainInput() elseif(map_proj.eq."MERCATOR") then + ! CM Ensure that the number of lat/lon dimensions is 2D for this projection + if(LIS_rc%nlatlon_dimensions == '1D') then + write(LIS_logunit,*) & + '[ERR] The MERCATOR map projection cannot be written with 1D lat/lon fields.' + write(LIS_logunit,*) & + '[WARN] The lat/lon fields will be written in 2D' + LIS_rc%nlatlon_dimensions = '2D' + end if + ios = nf90_get_att(ftn, NF90_GLOBAL, 'TRUELAT1',LIS_domain(n)%truelat1) call LIS_verify(ios, 'Error in nf90_get_att: TRUELAT1') diff --git a/lis/core/LIS_readConfig.F90 b/lis/core/LIS_readConfig.F90 index 7c72403a7..8ccc4bf28 100644 --- a/lis/core/LIS_readConfig.F90 +++ b/lis/core/LIS_readConfig.F90 @@ -140,12 +140,12 @@ subroutine LIS_readConfig() ! label="Map projection of the LIS domain:",rc=rc) ! call LIS_verify(rc,'Map projection of the LIS domain: option not specified in the config file') - ! CM Grabs new lis.config entry for number of dimensinos of the lat/lon fields + ! CM Grabs new optional lis.config entry for the number of dimensions of the lat/lon fields call ESMF_ConfigGetAttribute(LIS_config,LIS_rc%nlatlon_dimensions,& label="Number of dimensions in the lat/lon output fields:",rc=rc) call LIS_warning(rc, 'Number of dimensions in the lat/lon output fields: option not specified in the config file. Assigning value to "1D"') - ! CM If the user did not specify the number of dimension for the lat/lon fields, use 1D. In LIS_domainMod, this will switch to 2D if the map projection can not be written with 1D. + ! CM If the user did not specify the number of dimension for the lat/lon fields, use 1D. In LIS_domainMod, this will switch to 2D for all projections except latlon. if ( rc /= 0 ) then LIS_rc%nlatlon_dimensions = "1D" endif From 98eab035e93adfad494c8686f94a216a2b3435c6 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 26 Jun 2023 14:43:56 -0400 Subject: [PATCH 143/328] Second round of updates to testcase walkthrough + New file sizes, ensured wget scripts work, more typos fixes. --- .../public_testcase_walkthrough.adoc | 8 ++++---- docs/public_testcase_walkthrough/running_ldt.adoc | 6 ++++-- docs/public_testcase_walkthrough/setup.adoc | 4 ++-- docs/public_testcase_walkthrough/step_1.adoc | 6 +++--- docs/public_testcase_walkthrough/step_2.adoc | 14 +++++++------- docs/public_testcase_walkthrough/step_3.adoc | 8 ++++---- docs/public_testcase_walkthrough/step_4.adoc | 6 +++--- docs/public_testcase_walkthrough/step_5.adoc | 6 +++--- docs/public_testcase_walkthrough/step_6.adoc | 4 ++-- docs/public_testcase_walkthrough/step_7.adoc | 6 +++--- 10 files changed, 35 insertions(+), 33 deletions(-) diff --git a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc index 2342840a4..c409bed70 100644 --- a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc +++ b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc @@ -1,7 +1,7 @@ = LIS Public Testcase Walkthrough -:revnumber: 1.0 -:revdate: June 1, 2023 -:revremark: Updated for LISF Public 7.5 release +:revnumber: 1.1 +:revdate: June 26, 2023 +:revremark: Updated for LISF Public 7.4 release :imagesdir: ./images :title-page: :title-page-background-image: image:lisf_logo.png[fit=none,pdfwidth=50%,position=top] @@ -12,7 +12,7 @@ :figure-caption!: // disable figure captions // github commit known to be compatible with this walkthrough -:compatible-lisf-branch: support/lisf-public-7.5 +:compatible-lisf-branch: support/lisf-public-7.4 // urls :url-lis-website: https://lis.gsfc.nasa.gov diff --git a/docs/public_testcase_walkthrough/running_ldt.adoc b/docs/public_testcase_walkthrough/running_ldt.adoc index 223551a16..f0793bdd5 100644 --- a/docs/public_testcase_walkthrough/running_ldt.adoc +++ b/docs/public_testcase_walkthrough/running_ldt.adoc @@ -8,7 +8,9 @@ You're now ready to run LDT: % ./LDT {ldt-config-filename} ---- -The run should take a few minutes to complete. If the run aborts, troubleshoot the issue by reviewing any errors printed to the terminal and by viewing the contents of `ldtlog.0000`. If no errors print to the terminal, verify that the run completed successfully by checking for the following confirmation at the end of the `ldtlog.0000`: +The run should take a few minutes to complete. If the run aborts, troubleshoot the issue by reviewing any errors printed to the terminal and by viewing the contents of `ldtlog.0000`. If no errors print to the terminal, verify that the run completed successfully by checking for the following confirmation at the end of the `ldtlog.0000`. + +NOTE: If the terminal reports the error "./LDT: symbol lookup error:", this may be due extraneous modules loaded into your environement that do not allow lis to run properly. View your modules using the command `module list`. If extraneous modules are loaded, run `module purge` to clear your environment and then `module load [lisf module file]` to load an environment suitable to running LISF. See the "discover_quick_start" document in the {url-lisf-docs}[LISF Users' Guides,window=_blank] for more information. [source,shell] ---- @@ -17,4 +19,4 @@ The run should take a few minutes to complete. If the run aborts, troubleshoot t -------------------------------- Finished LDT run -------------------------------- ----- \ No newline at end of file +---- diff --git a/docs/public_testcase_walkthrough/setup.adoc b/docs/public_testcase_walkthrough/setup.adoc index b8abd7318..acbb7140b 100644 --- a/docs/public_testcase_walkthrough/setup.adoc +++ b/docs/public_testcase_walkthrough/setup.adoc @@ -37,14 +37,14 @@ IMPORTANT: The `{compatible-lisf-branch}` branch is known to be compatible with For information about configuration settings and detailed compilation instructions, see the {url-lisf-docs}[LISF Users' Guides,window=_blank]. In general, the compilation process for each component is as follows: -NOTE: The TARGET_OUTPUT files or "solutions" to this testcase were created using default compile configuration settings. It is recommended that default compile comfiguration settings are used. Other settings may be used, but this may result in difference between your output and the provided TARGET_OUTPUT. +NOTE: As you run these testcases, you will have the opportunity to compare your output to TARGET_OUTPUT files or "solutions". The TARGET_OUTPUT files were created by running ldt, lis, and lvt compiled with *default* compile configuration settings. For this walkthrough, it is recommended that you also use default compiler configuration settings. [#compile-example] [source,shell,subs="attributes"] ---- % cd ldt % ./configure -> # Select compile configuration settings (Default settings recommended. See docs for more)... +> # Select compile configuration settings (Default settings recommended.) % ./compile > # Compilation output... % mv LDT ../../ # move executable up into $WORKING_DIR diff --git a/docs/public_testcase_walkthrough/step_1.adoc b/docs/public_testcase_walkthrough/step_1.adoc index 972038518..aa56ce997 100644 --- a/docs/public_testcase_walkthrough/step_1.adoc +++ b/docs/public_testcase_walkthrough/step_1.adoc @@ -1,9 +1,9 @@ = Step 1: LSM Parameter Processing Run (LDT) :step-label: Step 1 -:download-filename: testcase1_ldt_parms_2020.tar.gz +:download-filename: testcase1_ldt_parms_2023.tar.gz :input-filesize-compressed: 350MB -:input-filesize-unpacked: 4.1GB +:input-filesize-unpacked: 4.2GB :ldt-run-dir: :ldt-config-filename: ldt.config.noah36_params @@ -130,7 +130,7 @@ NOTE: The output filenames for `lis_input.nldas.noah36.d01.nc` and `ldtlog.0000` === The LIS Parameter File -The contents of the LIS parameter input file produced by LDT can be examined visually using a command-line program such as http://meteora.ucsd.edu/~pierce/ncview_home_page.html[`ncview`,window=_blank] or a desktop application like NASA's https://www.giss.nasa.gov/tools/panoply/[Panoply,window=_blank]. For this walkthrough we will be using `ncview`. +The contents of the LIS parameter input file produced by LDT can be examined visually using a command-line program such as http://meteora.ucsd.edu/~pierce/ncview_home_page.html[`ncview`,window=_blank] or a desktop application like NASA's https://www.giss.nasa.gov/tools/panoply/[Panoply,window=_blank]. For this walkthrough we will be using `ncview`. If needed, add `ncview` to your environment by running, `module load ncview`. Open the LIS input file using `ncview`: diff --git a/docs/public_testcase_walkthrough/step_2.adoc b/docs/public_testcase_walkthrough/step_2.adoc index 82198409b..941506a75 100644 --- a/docs/public_testcase_walkthrough/step_2.adoc +++ b/docs/public_testcase_walkthrough/step_2.adoc @@ -1,9 +1,9 @@ = Step 2: LSM "Open-loop" (OL) Experiment (LIS) :step-label: Step 2 -:download-filename: testcase2_lis_ol_2020.tar.gz -:input-filesize-compressed: 67MB -:input-filesize-unpacked: 250MB +:download-filename: testcase2_lis_ol_2023.tar.gz +:input-filesize-compressed: 65MB +:input-filesize-unpacked: 343MB == Overview @@ -53,9 +53,9 @@ Jump to the <>. ==== Before running the download script: -. If needed, install `wget`. -. Create a link:https://urs.earthdata.nasa.gov/users/new[NASA Earthdata] account if you do not already have one. -. Follow steps 1-4 in link:https://disc.gsfc.nasa.gov/data-access#mac_linux_wget[these instructions] to save your NASA Earthdata login credentials locally. +. If needed, install `wget` +. Create a link:https://urs.earthdata.nasa.gov/users/new[NASA Earthdata] account if you do not already have one +. Follow steps 1-3 in link:https://disc.gsfc.nasa.gov/data-access#mac_linux_wget[these instructions] to save your NASA Earthdata login credentials locally ==== When you are ready to run the script, change directories into `INPUT/` and run the following command: @@ -98,7 +98,7 @@ In your `$WORKING_DIR`, execute the following command: LIS can also be run in parallel. The examples in this walkthrough, however, demonstrate how to run LIS on a single processor. See Chapter 6 in link:{url-lisf-docs}[the LIS Users' Guide] for instructions for running LIS in parallel. ==== -With a single processor the run should take approximately 20 minutes to complete. If the run fails, diagnose the issue by reviewing any errors that have printed to the terminal and by viewing the contents of `lislog` files (if any are present). If no errors appear and the run appears to have completed successfully, examine the end of any `lislog` files present to check for a confirmation message: +With a single processor the run should take approximately 20 minutes to complete. If the run fails, diagnose the issue by reviewing any errors that have printed to the terminal and by viewing the contents of `lislog` files (located in the `log` directory as defined by line 42 of `lis.config_noah36_ol`). If no errors appear and the run appears to have completed successfully, examine the end of any `lislog` files present to check for a confirmation message: [source,shell] ---- diff --git a/docs/public_testcase_walkthrough/step_3.adoc b/docs/public_testcase_walkthrough/step_3.adoc index 2306d7684..f0cf59838 100644 --- a/docs/public_testcase_walkthrough/step_3.adoc +++ b/docs/public_testcase_walkthrough/step_3.adoc @@ -1,9 +1,9 @@ = Step 3: Ensemble Restart File Generation (LDT) :step-label: Step 3 -:download-filename: testcase3_ldt_ensrst_2020.tar.gz -:input-filesize-compressed: 77KB -:input-filesize-unpacked: 180KB +:download-filename: testcase3_ldt_ensrst_2023.tar.gz +:input-filesize-compressed: 97KB +:input-filesize-unpacked: 100KB :ldt-run-dir: DA_ensrst :ldt-config-filename: ldt.config @@ -85,6 +85,6 @@ include::running_ldt.adoc[] During this run, LDT produced one output file named `LIS_EnRST_NOAH36_201801010000.d01.nc` and placed it into the `$WORKING_DIR/DA_ensrst` directory. -Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/DA_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. +Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/DA_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. If there are between your file and the target file, you can use `ncdiff` to create a new NetCDF file to visualize the differences. // TODO: ADD EXAMPLES HERE diff --git a/docs/public_testcase_walkthrough/step_4.adoc b/docs/public_testcase_walkthrough/step_4.adoc index 8eeda6484..80463dae4 100644 --- a/docs/public_testcase_walkthrough/step_4.adoc +++ b/docs/public_testcase_walkthrough/step_4.adoc @@ -1,9 +1,9 @@ = Step 4: Generate LSM OL Cumulative Density Function-based Files (LDT) :step-label: Step 4 -:download-filename: testcase4_ldt_lsmcdf_2020.tar.gz -:input-filesize-compressed: 362KB -:input-filesize-unpacked: 815KB +:download-filename: testcase4_ldt_lsmcdf_2023.tar.gz +:input-filesize-compressed: 384KB +:input-filesize-unpacked: 803KB :ldt-run-dir: DA_proc_LSM :ldt-config-filename: ldt.config.noah36_cdf diff --git a/docs/public_testcase_walkthrough/step_5.adoc b/docs/public_testcase_walkthrough/step_5.adoc index 2f711612b..73ed34e3d 100644 --- a/docs/public_testcase_walkthrough/step_5.adoc +++ b/docs/public_testcase_walkthrough/step_5.adoc @@ -1,9 +1,9 @@ = Step 5: Generate Observations CDF-based Files (LDT) :step-label: Step 5 -:download-filename: testcase5_ldt_obscdf_2020.tar.gz -:input-filesize-compressed: 4.5GB -:input-filesize-unpacked: 5.3GB +:download-filename: testcase5_ldt_obscdf_2023.tar.gz +:input-filesize-compressed: 4.6GB +:input-filesize-unpacked: 9.1GB :ldt-run-dir: DA_proc_SMAP :ldt-config-filename: ldt.config.smapobs_cdf diff --git a/docs/public_testcase_walkthrough/step_6.adoc b/docs/public_testcase_walkthrough/step_6.adoc index a04e366c6..8cc3d4818 100644 --- a/docs/public_testcase_walkthrough/step_6.adoc +++ b/docs/public_testcase_walkthrough/step_6.adoc @@ -1,9 +1,9 @@ = Step 6: LSM Data Assimilation (DA) Experiment (LIS) :step-label: Step 6 -:download-filename: testcase6_lis_da_2020.tar.gz +:download-filename: testcase6_lis_da_2023.tar.gz :input-filesize-compressed: 80MB -:input-filesize-unpacked: 220MB +:input-filesize-unpacked: 327MB == Overview diff --git a/docs/public_testcase_walkthrough/step_7.adoc b/docs/public_testcase_walkthrough/step_7.adoc index 8d64cec7d..53d4fc0a9 100644 --- a/docs/public_testcase_walkthrough/step_7.adoc +++ b/docs/public_testcase_walkthrough/step_7.adoc @@ -1,9 +1,9 @@ = Step 7: Comparison of OL and DA Experiments (LVT) :step-label: Step 7 -:download-filename: testcase7_lvt_expcomp_2020.tar.gz -:input-filesize-compressed: 150KB -:input-filesize-unpacked: 700KB +:download-filename: testcase7_lvt_expcomp_2023.tar.gz +:input-filesize-compressed: 481KB +:input-filesize-unpacked: 7.2MB == Overview From a2fe5e94fa104559a1eb91824e5cec8a690a28e4 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Thu, 6 Jul 2023 17:36:34 -0400 Subject: [PATCH 144/328] Update links for landcover files ral.ucar.edu updated their website. The old links for more information on the USGS_native and MODIS_native landcover data sources have deprecated. This commits adds the new link. --- ldt/configs/ldt.config.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 76feb33ec..6b9088d3e 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -763,9 +763,9 @@ endif::devonly[] |AVHRR |Univ. of Maryland 1992-93 AVHRR landcover map. Please see: https://doi.org/10.3334/ORNLDAAC/969 |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. -|MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php +|MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm#resources4 |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. -|USGS_Native |The 24-category USGS native landcover map. See: http://www.ral.ucar.edu/research/land/technology/noahmp_lsm.php +|USGS_Native |The 24-category USGS native landcover map. See: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm#resources4 |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html |CLSMF2.5 |CLSM Fortuna 2.5 landcover dataset. From 3d9eb2fba2e3e1b783e86d953b392f035b03d410 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Thu, 6 Jul 2023 17:44:36 -0400 Subject: [PATCH 145/328] Fix typo in url --- ldt/configs/ldt.config.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ldt/configs/ldt.config.adoc b/ldt/configs/ldt.config.adoc index 6b9088d3e..389ae1326 100644 --- a/ldt/configs/ldt.config.adoc +++ b/ldt/configs/ldt.config.adoc @@ -763,9 +763,9 @@ endif::devonly[] |AVHRR |Univ. of Maryland 1992-93 AVHRR landcover map. Please see: https://doi.org/10.3334/ORNLDAAC/969 |AVHRR_GFS |Similar to "`AVHRR`" option above but on a GFS grid. -|MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm#resources4 +|MODIS_Native |Terra-MODIS sensor-based IGBP land classification map, modified by NCEP. For more info, please see: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm |MODIS_LIS |Similar dataset as "`MODIS_Native`" above but processed by LISF-team. -|USGS_Native |The 24-category USGS native landcover map. See: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm#resources4 +|USGS_Native |The 24-category USGS native landcover map. See: https://ral.ucar.edu/model/noah-multiparameterization-land-surface-model-noah-mp-lsm |USGS_LIS |Similar dataset as "`USGS_Native`" but processed by LISF-team. |ALMIPII |AMMA/ALMIP Phase-2 landcover input option. For more info: http://www.cnrm.meteo.fr/amma-moana/amma_surf/almip2/input.html |CLSMF2.5 |CLSM Fortuna 2.5 landcover dataset. From b3d895ceee17b32aac74a8385a4bcef909272630 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Mon, 10 Jul 2023 18:28:47 -0400 Subject: [PATCH 146/328] More detail and final typo fixes --- docs/public_testcase_walkthrough/setup.adoc | 2 ++ docs/public_testcase_walkthrough/step_3.adoc | 2 +- docs/public_testcase_walkthrough/step_5.adoc | 2 +- docs/public_testcase_walkthrough/step_6.adoc | 13 +++++++------ 4 files changed, 11 insertions(+), 8 deletions(-) diff --git a/docs/public_testcase_walkthrough/setup.adoc b/docs/public_testcase_walkthrough/setup.adoc index acbb7140b..297108947 100644 --- a/docs/public_testcase_walkthrough/setup.adoc +++ b/docs/public_testcase_walkthrough/setup.adoc @@ -54,3 +54,5 @@ NOTE: As you run these testcases, you will have the opportunity to compare your Repeat the above process in the `lis/` and `lvt/` directories to generate the _LIS_ and _LVT_ executables. Change directories back into your `$WORKING_DIR` which should now contain three executable files: `LDT`, `LIS`, `LVT`. + +If you ever wish to generate new executable files, `cd` into `/LISF/l??/make` and run `gmake realclean`. This will clear all dependency files and allow you to cleanly define new compile configuration settings and recompile. diff --git a/docs/public_testcase_walkthrough/step_3.adoc b/docs/public_testcase_walkthrough/step_3.adoc index f0cf59838..88b729624 100644 --- a/docs/public_testcase_walkthrough/step_3.adoc +++ b/docs/public_testcase_walkthrough/step_3.adoc @@ -85,6 +85,6 @@ include::running_ldt.adoc[] During this run, LDT produced one output file named `LIS_EnRST_NOAH36_201801010000.d01.nc` and placed it into the `$WORKING_DIR/DA_ensrst` directory. -Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/DA_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. If there are between your file and the target file, you can use `ncdiff` to create a new NetCDF file to visualize the differences. +Use `ncview`, Panoply, Matlab or any other viewing package that supports NetCDF files. Compare what you see with the _target_ version of this output file, also located in `$WORKING_DIR/DA_ensrst`. Additionally, you can use `nccmp` to directly compare the contents of the file created by your LDT run and the target. If there are differences between your file and the target file, you can use `ncdiff` to create a new NetCDF file to visualize the differences. // TODO: ADD EXAMPLES HERE diff --git a/docs/public_testcase_walkthrough/step_5.adoc b/docs/public_testcase_walkthrough/step_5.adoc index 73ed34e3d..60bb72bdb 100644 --- a/docs/public_testcase_walkthrough/step_5.adoc +++ b/docs/public_testcase_walkthrough/step_5.adoc @@ -83,7 +83,7 @@ SMAP(NASA) soil moisture Composite Release ID (e.g., R16): R16 <8> <1> _DA preprocessing_ mode is used to generate the observation domain and scaling parameters. <2> Prefix of output files (e.g., `cdf_smapobs_domain.nc`). <3> Temporal resolution of resultant CDF. Specifies whether to generate lumped (i.e., considering all years and all seasons) CDFs or to stratify CDFs for each calendar month. -<4> Averaging interval used while computing CDF. In this case, one day. +<4> Averaging interval used while computing the CDF. In this case, one day. <5> Relative path to the directory containing SMAP observation data. <6> Specifies which SMAP data product is being used. <7> Specifies the radius in which LDT searches to detect open water. Then removes all pixels within the radius in the CDF calculations. diff --git a/docs/public_testcase_walkthrough/step_6.adoc b/docs/public_testcase_walkthrough/step_6.adoc index 8cc3d4818..89c56f481 100644 --- a/docs/public_testcase_walkthrough/step_6.adoc +++ b/docs/public_testcase_walkthrough/step_6.adoc @@ -61,7 +61,7 @@ This step relies on files downloaded or generated in the previous steps. In addi Review the contents of `lis.config_noah36_smapda` to view the configuration settings used for the DA run: -.Restart options +.Restart options: [source,shell] ---- ... @@ -72,11 +72,11 @@ Number of ensembles per tile: 12 <2> Noah.3.6 restart file: ./DA_ensrst/LIS_EnRST_NOAH36_201801010000.d01.nc <3> ... ---- -<1> Select "restart" mode to use a restart file (compare with coldstart mode). +<1> Select "restart" mode to use a restart file (as opposed to "coldstart" mode). <2> # of ensemble members to use (matches ensemble restart file). <3> Filepath of the 12 member ensemble restart file generated in Step 3. -.Data assimilation options +.Data assimilation options: [source,shell] ---- ... @@ -96,7 +96,7 @@ Data assimilation output innovations: 1 ... ---- -.Scaling strategy options +.Scaling strategy options: [source,shell] ---- ... @@ -111,7 +111,7 @@ Bias estimation restart file: ... ---- -.Perturbation options +.Perturbation options: [source,shell] ---- ... @@ -139,7 +139,7 @@ Observation perturbation attributes file: ./DA_INPUT/smap_pertattribs.txt <2> State perturbation options <3> Observation perturbation options -.Observation data options +.Observation data options: [source,shell] ---- SMAP(NASA) soil moisture data designation: SPL3SMP @@ -283,6 +283,7 @@ View the output of the run using `GrADS`, `ncview`, Matlab, or other software. C // TODO: ADD VISUALIZATION OF OUTPUT +.`SoilMoist_tavg` variable in `LIS_HIST_201701010600.d01.nc` image::step_6_output_example.png[pdfwidth=50%,align="center"] == Wrap Up From 68ce7f583d7fee7311d49635018c4d25955a9281 Mon Sep 17 00:00:00 2001 From: Colin McLaughlin Date: Tue, 11 Jul 2023 12:40:52 -0400 Subject: [PATCH 147/328] Adds example job script to the Public Testcases This describes how to download example batch scripts that I staged at /css/lisdata-pub/Web_Version/. This is just a note under step one because it could be distracting to fill the public testcase walkthrough with this. --- .../public_testcase_walkthrough.adoc | 1 + docs/public_testcase_walkthrough/step_1.adoc | 16 ++++++++++++++++ 2 files changed, 17 insertions(+) diff --git a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc index c409bed70..82b143fe5 100644 --- a/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc +++ b/docs/public_testcase_walkthrough/public_testcase_walkthrough.adoc @@ -20,6 +20,7 @@ :url-lis-testcases-data: https://portal.nccs.nasa.gov/lisdata_pub/Tutorials/Web_Version/ :url-lisf-docs: https://github.com/NASA-LIS/LISF/tree/master/docs :url-lisf-github: https://github.com/NASA-LIS/LISF +:url-nccs-discover-jobs-page: https://www.nccs.nasa.gov/nccs-users/instructional/using-slurm/submit-jobs :ssh-lisf-github: github:NASA-LIS/LISF.git // begin document diff --git a/docs/public_testcase_walkthrough/step_1.adoc b/docs/public_testcase_walkthrough/step_1.adoc index aa56ce997..891765ce2 100644 --- a/docs/public_testcase_walkthrough/step_1.adoc +++ b/docs/public_testcase_walkthrough/step_1.adoc @@ -2,6 +2,7 @@ :step-label: Step 1 :download-filename: testcase1_ldt_parms_2023.tar.gz +:download-batch-scripts-filename: testcase_batch_scripts.tar.gz :input-filesize-compressed: 350MB :input-filesize-unpacked: 4.2GB :ldt-run-dir: @@ -114,6 +115,21 @@ image::step_1_domain_radar.jpeg[align=center] include::running_ldt.adoc[] +[NOTE] +-- +ldt, lis, and lvt can also be run by submitting batch jobs using SLURM (**S**imple **L**inux **U**tility for **R**esource **M**anagement). If you are running this tutorial on Discover, you can download example batch scripts for all steps from the {url-lis-testcases-page}[LIS Testcase website] using the following command: + +[source,shell,subs="attributes"] +---- +% curl -O {url-lis-testcases-data}{download-batch-scripts-filename} +% tar -xzf {download-batch-scripts-filename} -C . +---- + +The batch scripts (`step*.job`) will unpack into the appropriate directories. To submit a job to discover using a batch script, use the command `sbatch [BATCH SCRIPT]` from the same directory as the job you wish to run. The command `squeue -u [YOUR USER ID]` will provide updates on your job. If the job crashes, troubleshoot using any `slurm.out` files. + +See the {url-nccs-discover-jobs-page}[NCCS Discover Jobs Users' Guide] for more information. +-- + == LDT Output Files The following files are typically generated by an LDT parameter processing run: From 0552513d02ffb64c983303f96101fb483b733bea Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Wed, 19 Jul 2023 18:16:12 -0400 Subject: [PATCH 148/328] Modified the code to read the unperturbed ensemble. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 42 +++++++------ ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 91 +++++++++++++++++----------- 2 files changed, 79 insertions(+), 54 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index d47b00395..1a6b73372 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -18,7 +18,10 @@ ! 06 Feb 2023: Eric Kemp, now process subset of SMAP fields. ! 14 Feb 2023: Eric Kemp, now uses USAFSI and USAF LIS output. ! 22 Feb 2023: Eric Kemp, ensemble size now in ldt.config file. -! +! 01 Jul 2023: Mahdi Navari,This edit generates a separate SMAP_filelist +! for each LDT job based on user input. +! Now we can run several LDT jobs in the same directory. +! #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -41,7 +44,7 @@ module LDT_smap_e_oplMod CLAYfile, Hfile, LCfile character*100 :: dailystats_ref, dailystats_lis character*10 :: date_curr - integer :: L1BresampWriteOpt, L1Btype + integer :: L1BresampWriteOpt, L1Btype, SMAPfilelistSuffixNumber integer :: Teffscale integer :: ntimes,ngrid real, allocatable :: mu_6am_ref(:), mu_6pm_ref(:) !(ngrid) @@ -108,6 +111,12 @@ subroutine LDT_smap_e_oplInit() call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%L1BresampWriteOpt, rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") + cfg_entry = "SMAP_E_OPL filelist suffix number:" + call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%SMAPfilelistSuffixNumber, rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + if(SMAPeOPL%L1BresampWriteOpt.eq.1) then cfg_entry = "SMAP_E_OPL L1B resampled output directory:" call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) @@ -254,6 +263,7 @@ subroutine LDT_smap_e_oplRun(n) character*2 :: hh_01, mm_01, dd_01 character*2 :: hh_02, mm_02, dd_02 character*2 :: hh_03, mm_03, dd_03 + character*2 :: tmp character*1 :: Orbit integer :: yr, mo, da, hr integer :: yr_pre, mo_pre, da_pre, hh_pre @@ -273,7 +283,7 @@ subroutine LDT_smap_e_oplRun(n) type(ESMF_TimeInterval) :: deltatime integer :: deltahr integer :: rc - + integer :: col, row external :: readUSAFSI external :: readLIS_Teff_usaf @@ -281,7 +291,7 @@ subroutine LDT_smap_e_oplRun(n) ! Resample SMAP L1B to L1C call search_SMAPL1B_files(SMAPeOPL%L1Bdir,SMAPeOPL%date_curr,& - SMAPeOPL%L1Btype) + SMAPeOPL%L1Btype, SMAPeOPL%SMAPfilelistSuffixNumber) yyyymmdd = SMAPeOPL%date_curr(1:8) yyyy = SMAPeOPL%date_curr(1:4) @@ -297,10 +307,11 @@ subroutine LDT_smap_e_oplRun(n) trim(SMAPeOPL%L1Bresampledir_02)) endif + write (tmp,'(I2.2)') SMAPeOPL%SMAPfilelistSuffixNumber + ftn = LDT_getNextUnitNumber() - open(unit=ftn, file='./SMAP_L1B_filelist.dat',& + open(unit=ftn, file='./SMAP_L1B_filelist_'//tmp//'.dat',& status='old', iostat=ierr) - fi = 0 do while (ierr .eq. 0) read (ftn, '(a)', iostat=ierr) fname @@ -367,7 +378,6 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeSet(curtime, yy=yr, mm=mo, dd=da, h=hr, m=0, s=0, & calendar=calendar, rc=rc) call LDT_verify(rc, '[ERR] in ESMF_TimeSet in LDT_smap_e_oplRun') - ! Go back 24 hours call ESMF_TimeIntervalSet(deltatime, d=1, rc=rc) call LDT_verify(rc, & @@ -441,7 +451,6 @@ subroutine LDT_smap_e_oplRun(n) yyyymmdd_01 = trim(yyyy_01)//trim(mm_01)//trim(dd_01) write(unit=hh_01, fmt='(i2.2)') hh_pre !hh_01 = hh - !call readLIS_Teff(n,yyyymmdd_01,hh_01,Orbit,teff_01) call readLIS_Teff_usaf(n, yyyymmdd_01, hh_01, Orbit, teff_01, rc) if (rc .ne. 0) then @@ -502,7 +511,6 @@ subroutine LDT_smap_e_oplRun(n) write(unit=dd_02, fmt='(i2.2)') da_02 write(unit=hh_02, fmt='(i2.2)') hr_02 yyyymmdd_02 = trim(yyyy_02)//trim(mm_02)//trim(dd_02) - !call readLIS_Teff(n,yyyymmdd_02,hh_02,Orbit,teff_02) call readLIS_Teff_usaf(n, yyyymmdd_02, hh_02, Orbit, teff_02, rc) if (rc .ne. 0) then @@ -518,7 +526,6 @@ subroutine LDT_smap_e_oplRun(n) write(unit=dd_03, fmt='(i2.2)') da_03 write(unit=hh_03, fmt='(i2.2)') hr_03 yyyymmdd_03 = trim(yyyy_03)//trim(mm_03)//trim(dd_03) - !call readLIS_Teff(n,yyyymmdd_03,hh_03,Orbit,teff_03) call readLIS_Teff_usaf(n, yyyymmdd_03, hh_03, Orbit, teff_03, rc) if (rc .ne. 0) then @@ -528,7 +535,6 @@ subroutine LDT_smap_e_oplRun(n) ! Scale LIS teff to GEOS teff climatology ! get DOY call get_doy(mo_pre,da_pre,doy_pre) - if(SMAPeOPL%Teffscale.eq.1) then ! get getattributes call getattributes(SMAPeOPL%dailystats_ref,& @@ -547,7 +553,6 @@ subroutine LDT_smap_e_oplRun(n) allocate(SMAPeOPL%grid_row(SMAPeOPL%ngrid)) call read_DailyTeffStats(doy_pre) - ! scale write (LDT_logunit,*) '[INFO] Scaling LIS effective soil temperature' call scale_teff(n, Orbit, teff_01, teff_02, teff_03) @@ -564,7 +569,6 @@ subroutine LDT_smap_e_oplRun(n) deallocate(SMAPeOPL%grid_col) deallocate(SMAPeOPL%grid_row) endif - read_L1Bdata = .false. ! Get snow information from LIS outputs @@ -595,30 +599,34 @@ subroutine LDT_smap_e_oplRun(n) end subroutine LDT_smap_e_oplRun - subroutine search_SMAPL1B_files(ndir,date_curr,L1Btype) + subroutine search_SMAPL1B_files(ndir,date_curr,L1Btype,suffix) implicit none ! !ARGUMENTS: character (len=*) :: ndir character (len=*) :: date_curr - integer :: L1Btype + integer :: L1Btype,suffix ! !Local variables character*8 :: yyyymmdd character*2 :: hh + character*2 :: tmp character*200 :: list_files yyyymmdd = date_curr(1:8) hh = date_curr(9:10) + write (tmp,'(I2.2)') suffix if(L1Btype.eq.1) then !NRT list_files = 'ls '//trim(ndir)//'/SMAP_L1B_TB_NRT_*'//& trim(yyyymmdd)//'T'//trim(hh) & - //"*.h5 > SMAP_L1B_filelist.dat" + //'*.h5 > SMAP_L1B_filelist_'//trim(tmp)//'.dat' +! //"*.h5 > SMAP_L1B_filelist.dat" elseif(L1Btype.eq.2) then !Historical list_files = 'ls '//trim(ndir)//'/SMAP_L1B_TB_*'//& trim(yyyymmdd)//'T'//trim(hh) & - //"*.h5 > SMAP_L1B_filelist.dat" + //'*.h5 > SMAP_L1B_filelist_'//trim(tmp)//'.dat' +! //"*.h5 > SMAP_L1B_filelist.dat" endif call system(trim(list_files)) diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index 797afc6b9..cf4c8a8b7 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -18,7 +18,11 @@ ! ! !REVISION HISTORY: ! 14 FEB 2023: Eric Kemp, Initial Specification -! +! 1 July 2023: Mahdi Navari, Modified the code to read the unperturbed +! ensemble. This is a temporary fix to overcome the bias in +! soil temperature from a bug in SMAP soil moisture DA +! PR#1385 +! ! !INTERFACE: subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) ! !USES: @@ -252,11 +256,18 @@ subroutine read_LIStsoil_data_usaf(n, ntiles, str_tind, ntiles_pergrid, nens, & ! Calculate ensemble mean in 2d grid space, for each soil layer do k = 1, SoilTemp_profiles - call calc_gridded_ensmean_1layer(n, ntiles, str_tind, ntiles_pergrid, & + !call calc_gridded_ensmean_1layer(n, ntiles, str_tind, ntiles_pergrid, & + ! nens, & + ! SoilTemp_inst_tiles(:,k), & + ! SoilTemp_inst_ensmean_1layer) + + call calc_gridded_lastens_1layer(n, ntiles, str_tind, ntiles_pergrid, & nens, & SoilTemp_inst_tiles(:,k), & - SoilTemp_inst_ensmean_1layer) - do r = 1, LDT_rc%lnr(n) + SoilTemp_inst_ensmean_1layer) ! Note to minimize the code chnage: SoilTemp_inst_ensmean_1layer is actually + ! SoilTemp_inst_lastens_1layer (ens #12) + + do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) if (SoilTemp_inst_ensmean_1layer(c,r) > 0) then tsoil(c,r,k) = SoilTemp_inst_ensmean_1layer(c,r) @@ -322,39 +333,45 @@ subroutine calc_gridded_ensmean_1layer(n, ntiles, str_tind, ntiles_pergrid, & end if end subroutine calc_gridded_ensmean_1layer -! ! Subroutine for extracting last ensemble member for a single soil layer, -! ! from tiled data. -! subroutine calc_gridded_lastens_1layer(n, gvar_tile, gvar) - -! ! Imports -! use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc - -! ! Defaults -! implicit none - -! ! Arguments -! integer, intent(in) :: n -! real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) -! real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) - -! ! Locals -! integer :: m, r, c, gid, stid, tid - -! if (LDT_masterproc) then -! gvar = 0 -! do r = 1, LDT_rc%gnr(n) -! do c = 1, LDT_rc%gnc(n) -! gid = c + ((r-1) * LDT_rc%gnc(n)) -! stid = LDT_domain(n)%str_tind(gid) -! if (LDT_domain(n)%ntiles_pergrid(gid) > 0) then -! m = LDT_rc%nensem(n) -! tid = stid + m - 1 -! gvar(c,r) = gvar_tile(tid) -! end if -! end do -! end do -! end if -! end subroutine calc_gridded_lastens_1layer +! Subroutine for extracting last ensemble member for a single soil layer, +! from tiled data. + subroutine calc_gridded_lastens_1layer(n, ntiles, str_tind, ntiles_pergrid, & + nens, gvar_tile, gvar) + + ! Imports + use LDT_coreMod, only: LDT_rc, LDT_domain, LDT_masterproc + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + integer, intent(in) :: ntiles + !real, intent(in) :: gvar_tile(LDT_rc%glbntiles_red(n)) + integer, intent(in) :: str_tind(LDT_rc%gnc(n) * LDT_rc%gnr(n)) + integer, intent(in) :: ntiles_pergrid(LDT_rc%gnc(n) * LDT_rc%gnr(n)) + real, intent(out) :: gvar(LDT_rc%gnc(n), LDT_rc%gnr(n)) + real, intent(in) :: gvar_tile(ntiles) + integer, intent(in) :: nens + + ! Locals + integer :: m, r, c, gid, stid, tid + + if (LDT_masterproc) then + gvar = 0 + do r = 1, LDT_rc%gnr(n) + do c = 1, LDT_rc%gnc(n) + gid = c + ((r-1) * LDT_rc%gnc(n)) + stid = str_tind(gid) + if (ntiles_pergrid(gid) > 0) then + m = nens + tid = stid + m - 1 + gvar(c,r) = gvar_tile(tid) + end if + end do + end do + end if + end subroutine calc_gridded_lastens_1layer !BOP ! !ROUTINE: create_LISsoilT_filename_usaf From 57bfc263f162c6e35c0b9fd208750c67dbf1ec76 Mon Sep 17 00:00:00 2001 From: "Sujay V. Kumar" Date: Sat, 22 Jul 2023 12:36:12 -0400 Subject: [PATCH 149/328] Fixed the LVT percentile issue Fixed the issue where LVT percentiles are undefined for valid input values. This was occurring due to the use of a minimum value of 0.0 for certain variables. In such cases, valid input values were being screened out. Resolves #1386 --- lvt/metrics/LVT_percentileMod.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lvt/metrics/LVT_percentileMod.F90 b/lvt/metrics/LVT_percentileMod.F90 index edc007117..70bd7da70 100644 --- a/lvt/metrics/LVT_percentileMod.F90 +++ b/lvt/metrics/LVT_percentileMod.F90 @@ -717,7 +717,7 @@ subroutine diagnoseSinglepercentileParams(model, obs, stats,metric) elseif(trim(model%short_name).eq."TWS") then min_value = -10000 else - min_value = 0.0 !soil moisture + min_value = -100.0 endif do t=1,LVT_rc%ngrid @@ -926,7 +926,7 @@ subroutine diagnoseSinglepercentile(model,obs,stats,metric) elseif(trim(model%short_name).eq."TWS") then min_value = -10000 else - min_value = 0.0 !soil moisture + min_value = -100.0 endif do t=1,LVT_rc%ngrid From dde02d25ef0fc167fd9b92164a5dcdb1d0a9d478 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 28 Jul 2023 10:49:56 -0400 Subject: [PATCH 150/328] Added new sfcobs format with longer station IDs. --- ldt/USAFSI/LDT_bratsethMod.F90 | 33 ++++++++++++--------- ldt/USAFSI/LDT_usafsiMod.F90 | 12 +++++++- ldt/USAFSI/USAFSI_analysisMod.F90 | 48 ++++++++++++++++++++++--------- ldt/USAFSI/USAFSI_run.F90 | 27 +++++++++++++---- 4 files changed, 86 insertions(+), 34 deletions(-) diff --git a/ldt/USAFSI/LDT_bratsethMod.F90 b/ldt/USAFSI/LDT_bratsethMod.F90 index 60046b249..d5901519f 100644 --- a/ldt/USAFSI/LDT_bratsethMod.F90 +++ b/ldt/USAFSI/LDT_bratsethMod.F90 @@ -19,6 +19,7 @@ ! errors. Plus, added two new QC tests based on ! Brasnett. Plus, other bug fixes. ! 02 Nov 2020 Eric Kemp Removed blacklist at request of 557WW. +! 28 Jul 2023 Eric Kemp Expanded station ID to 31 characters. ! ! DESCRIPTION: ! Source code for snow depth analysis using the Bratseth objective analysis @@ -78,7 +79,7 @@ module LDT_bratsethMod real :: back_err_v_corr_len ! Background error vert correlation length integer :: nobs ! Number of observations character*10, allocatable :: networks(:) ! Network name - character*10, allocatable :: platforms(:) ! Observation station ID + character*31, allocatable :: platforms(:) ! Observation station ID real, allocatable :: obs(:) ! Observed values real, allocatable :: lats(:) ! Latitude of observation (deg N) real, allocatable :: lons(:) ! Longitude of observation (deg E) @@ -229,8 +230,8 @@ end function LDT_bratseth_count_good_obs ! Append a single observation into a LDT_bratseth_t object. Value of ! interpolated background value is optional (useful for adding ! "superobservations") - subroutine LDT_bratseth_append_ob(this, network, platform, ob, lat, lon, & - elev, ob_err_var, back) + subroutine LDT_bratseth_append_ob(this, network, platform, ob, & + lat, lon, elev, ob_err_var, back) ! Imports use LDT_logmod, only : LDT_logunit @@ -241,7 +242,7 @@ subroutine LDT_bratseth_append_ob(this, network, platform, ob, lat, lon, & ! Arguments class(LDT_bratseth_t),intent(inout) :: this character(len=10), intent(in) :: network - character(len=10), intent(in) :: platform + character(len=31), intent(in) :: platform real, intent(in) :: ob real, intent(in) :: lat real, intent(in) :: lon @@ -838,7 +839,8 @@ subroutine LDT_bratseth_run_dup_qc(this) integer :: count_dups real :: mean, back, newlat, newlon, newelev real :: ob_err_var, ob_err_corr_len - character(len=10) :: network, platform + character(len=10) :: network + character(len=31) :: platform real :: diff integer :: i,j logical :: reject_all @@ -1239,8 +1241,8 @@ end subroutine LDT_bratseth_run_water_qc ! obs, and rejected if deviation is too high. Superobs are considered ! "close" if they are in the same LIS grid box. Based on Lespinas et al ! (2015). - subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, ncols, nrows, & - silent_rejects) + subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, & + ncols, nrows, silent_rejects) ! Imports use LDT_coreMod, only: LDT_domain, LDT_rc @@ -1253,7 +1255,7 @@ subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, ncols, nrows, & ! Arguments class(LDT_bratseth_t), intent(inout) :: this integer, intent(in) :: n - character(len=10), intent(in) :: new_name + character(len=31), intent(in) :: new_name integer, intent(in) :: ncols integer, intent(in) :: nrows logical, optional, intent(in) :: silent_rejects @@ -1262,7 +1264,8 @@ subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, ncols, nrows, & integer :: num_good_obs integer :: num_rejected_obs, num_merged_obs, num_superobs logical :: silent_rejects_local - character(len=10) :: network_new, platform_new + character(len=10) :: network_new + character(len=31) :: platform_new integer, allocatable :: actions(:) real, allocatable :: means(:,:) real, allocatable :: superobs(:,:), superbacks(:,:) @@ -1817,7 +1820,7 @@ subroutine LDT_bratseth_resort_bad_obs(this) integer :: iob,job logical :: found_replacement character*10 :: network - character*10 :: platform + character*31 :: platform real :: ob, lat, lon, elev, ob_err_var, back integer :: qc character*80 :: failed_qc_test @@ -2042,6 +2045,9 @@ end subroutine LDT_bratseth_run_missing_elev_qc ! See https://en.wikipedia.org/wiki/Comb_sort subroutine LDT_bratseth_sort_obs_by_id(this) + ! Imports + use LDT_logmod, only : LDT_logunit + ! Defaults implicit none @@ -2052,6 +2058,7 @@ subroutine LDT_bratseth_sort_obs_by_id(this) integer :: gap integer :: switch character*10 :: ctemp10 + character*31 :: ctemp31 character*80 :: ctemp80 real :: rtemp integer :: itemp @@ -2078,9 +2085,9 @@ subroutine LDT_bratseth_sort_obs_by_id(this) this%networks(i) = this%networks(j) this%networks(j) = ctemp10 - ctemp10 = this%platforms(i) + ctemp31 = this%platforms(i) this%platforms(i) = this%platforms(j) - this%platforms(j) = ctemp10 + this%platforms(j) = ctemp31 rtemp = this%obs(i) this%obs(i) = this%obs(j) @@ -2152,7 +2159,7 @@ subroutine LDT_bratseth_print_snowdepths(this,minprt) int(this%elevs(i)), this%obs(i), trim(this%reject_reasons(i)) end if end do ! i -7000 format (/,'[INFO] NETID = ',A5,' STATION ID = ',A9, & +7000 format (/,'[INFO] NETID = ',A5,' STATION ID = ',A31, & ' LAT = ',F6.2,' LON = ',F7.2, & ' ELEV(M) = ',I5,' DEPTH(M) = ', F7.5, & ' QC VERDICT = ',A) diff --git a/ldt/USAFSI/LDT_usafsiMod.F90 b/ldt/USAFSI/LDT_usafsiMod.F90 index 57451c4ea..66f67d849 100644 --- a/ldt/USAFSI/LDT_usafsiMod.F90 +++ b/ldt/USAFSI/LDT_usafsiMod.F90 @@ -27,6 +27,7 @@ module LDT_usafsiMod character*10 :: date10 character*255 :: fracdir character*255 :: modif + integer :: sfcobsfmt ! EMK 20230727 character*255 :: sfcobs character*255 :: ssmis character*255 :: gmi !kyh20201118 @@ -139,11 +140,20 @@ subroutine LDT_usafsiInit() call ESMF_ConfigGetAttribute(LDT_config, usafsi_settings%modif, rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") + ! New sfcobs format...EMK 20230728 + cfg_entry = "USAFSI surface obs data format:" + call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + call ESMF_ConfigGetAttribute(LDT_config, usafsi_settings%sfcobsfmt, & + rc=rc) + call LDT_verify(rc, trim(cfg_entry)//" not specified") + ! Get sfcobs cfg_entry = "USAFSI surface obs data directory:" call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") - call ESMF_ConfigGetAttribute(LDT_config, usafsi_settings%sfcobs, rc=rc) + call ESMF_ConfigGetAttribute(LDT_config, usafsi_settings%sfcobs, & + rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") !------------------------------------------------------------------------------kyh20201118 diff --git a/ldt/USAFSI/USAFSI_analysisMod.F90 b/ldt/USAFSI/USAFSI_analysisMod.F90 index 89fdcb6ca..e6ab7d92c 100644 --- a/ldt/USAFSI/USAFSI_analysisMod.F90 +++ b/ldt/USAFSI/USAFSI_analysisMod.F90 @@ -17,6 +17,8 @@ ! 02 Nov 2020 Eric Kemp Removed blacklist code at request of 557WW. ! 22 Jan 2021 Yeosang Yoon Add subroutine for new 0.1 deg snow climatology ! 13 Jan 2022 Eric Kemp Added support for GRIB1 FNMOC SST file. +! 28 Jul 2023 Eric Kemp Added support for new sfcobs file format (longer +! station names. ! ! DESCRIPTION: ! Source code for Air Force snow depth analysis. @@ -676,7 +678,7 @@ subroutine getgeo (month, static, nc, nr, elevations) end subroutine getgeo subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & - stalat, stalon, staelv, stadep) + stalat, stalon, staelv, stadep, sfcobsfmt) !******************************************************************************* !******************************************************************************* @@ -741,6 +743,7 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & !** 21 Mar 19 Ported to LDT...Eric Kemp, NASA GSFC/SSAI !** 09 May 19 Renamed LDTSI...Eric Kemp, NASA GSFC/SSAI !** 13 Dec 19 Renamed USAFSI...Eric Kemp, NASA GSFC/SSAI + !** 27 Jul 23 Added new sfcobs file format...Eric Kemp, SSAI !** !******************************************************************************* !******************************************************************************* @@ -760,12 +763,14 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & integer, intent(in) :: month ! CURRENT MONTH (1-12) character*255, intent(in) :: sfcobs ! PATH TO DBPULL SNOW OBS DIRECTORY character*5, intent(out) :: netid (:) ! NETWORK ID OF AN OBSERVATION - character*9, intent(out) :: staid (:) ! STATION ID OF AN OBSERVATION + character*31, intent(out) :: staid (:) ! STATION ID OF AN OBSERVATION + integer, intent(out) :: stacnt ! TOTAL NUMBER OF OBSERVATIONS USED integer, intent(out) :: stalat (:) ! LATITUDE OF A STATION OBSERVATION integer, intent(out) :: stalon (:) ! LONGITUDE OF A STATION OBSERVATION integer, intent(out) :: staelv (:) ! ELEVATION OF A STATION OBSERVATION (METERS) real, intent(out) :: stadep (:) ! SNOW DEPTH REPORTED AT A STATION (METERS) + integer, intent(in) :: sfcobsfmt ! Format of sfcobs file ! Local variables character*7 :: access_type ! FILE ACCESS TYPE @@ -779,9 +784,10 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & character*90 :: message (msglns) ! ERROR MESSAGE character*255 :: obsfile ! NAME OF OBSERVATION TEXT FILE character*5 :: obsnet ! RETURNED OBS STATION NETWORK - character*9 :: obssta ! RETURNED OBS STATION ID + character*31 :: obssta ! RETURNED OBS STATION ID character*5, allocatable :: oldnet (:) ! ARRAY OF NETWORKS FOR OLDSTA - character*9, allocatable :: oldsta (:) ! ARRAY OF PROCESSED STATIONS WITH SNOW DEPTHS + character*31, allocatable :: oldsta (:) ! ARRAY OF PROCESSED STATIONS WITH SNOW DEPTHS + character*12 :: routine_name ! NAME OF THIS SUBROUTINE integer :: ctrgrd ! TEMP HOLDER FOR GROUND OBS INFO integer :: ctrtmp ! TEMP HOLDER FOR TOO WARM TEMPERATURE OBS @@ -855,13 +861,18 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & message = ' ' ! OPEN INPUT FILE. - obsfile = trim(sfcobs) // 'sfcsno_' // chemi(hemi) // & - interval // date10 // '.txt' + if (sfcobsfmt == 1) then + obsfile = trim(sfcobs) // 'sfcsno_' // chemi(hemi) // & + interval // date10 // '.txt' + else if (sfcobsfmt == 2) then + obsfile = trim(sfcobs) // 'newsno_' // chemi(hemi) // & + interval // date10 // '.txt' + end if inquire (file=obsfile, exist=isfile) file_check : if (isfile) then access_type = 'OPENING' - open (lunsrc(hemi), file=obsfile, iostat=istat, err=5000, & + open (lunsrc(hemi), file=obsfile, iostat=istat, err=5000, & form='formatted') isopen = .true. @@ -873,10 +884,19 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & ! LOOP THROUGH ALL OBSERVATIONS RETRIEVED FROM THE DATABASE. read_loop : do while (istat .eq. 0) - read (lunsrc(hemi), 6400, iostat=istat, end=3000, err=5000) & - date10_hourly, obsnet, obssta, oblat, oblon, obelev, & - itemp, depth, ground - + if (sfcobsfmt == 1) then + read (lunsrc(hemi), 6400, iostat=istat, end=3000, & + err=5000) & + date10_hourly, obsnet, obssta, oblat, oblon, & + obelev, & + itemp, depth, ground + else if (sfcobsfmt == 2) then + read (lunsrc(hemi), 6401, iostat=istat, end=3000, & + err=5000) & + date10_hourly, obsnet, obssta, oblat, oblon, & + obelev, & + itemp, depth, ground + end if good_read : if (istat == 0) then if (date10_hourly .ne. date10_prev) then @@ -924,7 +944,6 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & NETID(STCTP1) = OBSNET staid(stctp1) = obssta - stadep(stctp1) = (float (depth) / 1000.0) ! convert from mm to meters if (depth >= 1 .and. stadep(stctp1) < 0.001) then @@ -1103,10 +1122,11 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & 6000 format (/, '[INFO] ', A, ': READING ', A) !6200 format (I) 6400 format (A10, 1X, A5, 1X, A10, 6(I10)) +6401 format (A10, 1X, A5, 1X, A31, 1X, 6(I10)) 6500 format (/, '[INFO] ', A6, ': SURFACE OBS READ FOR ', A2, ' DTG ', & A10, ' = ', I6) 6600 format (1X, '**', A6, ': DEPTH = ', I6, ' STADEP = ', I6) -6700 format (/, 1X, '[INFO] HIGH POLAR TEMP: NETW= ', A5, 1X, 'STN= ', A9, & +6700 format (/, 1X, '[INFO] HIGH POLAR TEMP: NETW= ', A5, 1X, 'STN= ', A31, & 1X, 'LAT= ', F8.2, 1X, 'LON= ', F8.2, & 1X, 'ELEV= ', I5, /, 6X, 'TEMP= ', F7.1, & 2X, 'ST OF GRND= ', I9, 2X, 'DEPTH(CM)= ', I6) @@ -2780,7 +2800,7 @@ subroutine run_snow_analysis_noglacier(runcycle, nc, nr, landmask, & integer :: snomask_reject_count integer :: bad_back_count, glacier_zone_count real :: ob_value - character*10 :: new_name + character*31 :: new_name integer :: gindex real :: rlat diff --git a/ldt/USAFSI/USAFSI_run.F90 b/ldt/USAFSI/USAFSI_run.F90 index aab170d1e..0a2672e2f 100644 --- a/ldt/USAFSI/USAFSI_run.F90 +++ b/ldt/USAFSI/USAFSI_run.F90 @@ -69,6 +69,7 @@ subroutine USAFSI_run(n) !** 28 Jan 21 Updated messages for PMW snow retrievals !** and cleaned some unused codes..................Yeosang Yoon/NASA GSFC/SAIC !** 13 Jan 22 Added support for FNMOC SST GRIB1 file.........Eric Kemp/NASA GSFC/SSAI + !** 28 Jun 23 Extended station names to 31 characters........Eric Kemp/SSAI !***************************************************************************************** !***************************************************************************************** @@ -107,8 +108,10 @@ subroutine USAFSI_run(n) character*5, allocatable :: netid (:) ! NETWORK ID OF AN OBSERVATION character*255 :: modif ! PATH TO MODIFIED DATA DIRECTORY character*255 :: sfcobs ! PATH TO DBPULL SNOW OBS DIRECTORY + integer :: sfcobsfmt ! Format of sfcobs file character*255 :: TB_product_path ! TB_based retrivals path !kyh20201118 - character*9, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION + !character*9, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION + character*31, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION character*255 :: static ! STATIC FILE DIRECTORY PATH character*255 :: stmpdir ! SFC TEMP DIRECTORY PATH character*255 :: sstdir ! EMK 20220113 @@ -129,7 +132,8 @@ subroutine USAFSI_run(n) real, allocatable :: stadep (:) ! OBSERVATION SNOW DEPTH (METERS) character*12 :: routine_name type(LDT_bratseth_t) :: bratseth - character*10 :: network10, platform10 + character*10 :: network10 + character*31 :: platform31 real :: rob, rlat, rlon, relev integer :: nc,nr real, allocatable :: landmask(:,:) @@ -176,6 +180,8 @@ subroutine USAFSI_run(n) fracdir = trim(usafsi_settings%fracdir) modif = trim(usafsi_settings%modif) sfcobs = trim(usafsi_settings%sfcobs) + sfcobsfmt = usafsi_settings%sfcobsfmt ! EMK test + !---------------------------------------------------------kyh20201118 if (usafsi_settings%TB_option == 1) then !SSMIS TB_product_path = trim(usafsi_settings%ssmis) @@ -367,8 +373,16 @@ subroutine USAFSI_run(n) allocate (stalat (maxsobs)) allocate (stalon (maxsobs)) - call getobs (date10, month, sfcobs, netid, staid, stacnt, & - stalat, stalon, staelv, stadep) + if (sfcobsfmt == 1 .or. sfcobsfmt == 2) then + call getobs (date10, month, sfcobs, netid, staid, stacnt, & + stalat, stalon, staelv, stadep, sfcobsfmt) + else + write(LDT_logunit,*)'[ERR] Invalid sfcobs file format!' + write(LDT_logunit,*)'[ERR] Expected 1 (old) or 2 (new)' + write(LDT_logunit,*)'[ERR] Received ', sfcobsfmt + call LDT_endrun() + end if + write(LDT_logunit,*) & '[INFO] TOTAL OBSERVATIONS RETURNED FROM GETOBS: ', & stacnt @@ -376,12 +390,13 @@ subroutine USAFSI_run(n) ! EMK Copy observations to bratseth object do j = 1, stacnt network10 = trim(netid(j)) - platform10 = trim(staid(j)) + platform31 = trim(staid(j)) rob = stadep(j) rlat = real(stalat(j)) * 0.01 rlon = real(stalon(j)) * 0.01 relev = real(staelv(j)) - call bratseth%append_ob(network10, platform10, rob, rlat, rlon,& + call bratseth%append_ob(network10, platform31, rob, & + rlat, rlon,& relev, & usafsi_settings%ob_err_var, back=-1.) end do From 50010998ac07e3e2fde7ed9b9141d974a8e41b51 Mon Sep 17 00:00:00 2001 From: Jessica Erlingis Date: Mon, 7 Aug 2023 11:41:53 -0400 Subject: [PATCH 151/328] Modify IMERG reader to ingest v07A Final products --- lis/metforcing/imerg/read_imerg.F90 | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index e9290fb07..16bfe69fb 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -92,7 +92,7 @@ subroutine read_imerg (n, kk, name_imerg, findex, order, ferror_imerg ) if (file_exists) then if(LIS_masterproc) write(LIS_logunit,*) & "[INFO] Reading HDF5 IMERG precipitation data from ", trim(fname) - call read_imerghdf(fname, xd, yd, realprecip, ireaderr) + call read_imerghdf(n, fname, xd, yd, realprecip, ireaderr) if (ireaderr .ne. 0) then if(LIS_masterproc) write(LIS_logunit,*) & "[WARN] Error reading IMERG file ",trim(fname) @@ -133,25 +133,27 @@ end subroutine read_imerg ! J.Case (3/9/2015) -- below will be the HDF5 reader subroutine. -subroutine read_imerghdf(filename, xsize, ysize, precipout, istatus) +subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) ! !USES: #if (defined USE_HDF5) use hdf5 #endif use LIS_coreMod, only : LIS_rc, LIS_domain, LIS_masterproc use LIS_logMod, only : LIS_logunit, LIS_getNextUnitNumber + use imerg_forcingMod, only : imerg_struc implicit none ! ARGUMENTS character(len=*) :: filename integer, intent(in) :: xsize, ysize - - character(len=40) :: dsetname='/Grid/precipitationCal' + character(len=40) :: dsetname real :: precipin(ysize,xsize) real :: precipout(xsize,ysize) logical :: bIsError integer :: istatus,i + character(len=4) :: vlname + integer :: vnum, n #if (defined USE_HDF5) integer(HSIZE_T), dimension(2) :: dims integer(HID_T) :: fileid,dsetid @@ -160,6 +162,17 @@ subroutine read_imerghdf(filename, xsize, ysize, precipout, istatus) dims(2) = ysize bIsError=.false. + + ! Variable names changed in IMERG V07 + + vlname = trim(imerg_struc(n)%imergver) + read( vlname(3:3), *) vnum + + if(vnum.ge.7) then + dsetname='/Grid/precipitation' + else + dsetname='/Grid/precipitationCal' + endif !open fortran interface call h5open_f(istatus) if(istatus.ne.0) then From f20bc115eb83bf537580be598bfbcd53103e0606 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 16 Aug 2023 17:00:02 -0400 Subject: [PATCH 152/328] Modified reader to improve code quality. 1. Conversion of version number to integer now uses formatted read. 2. Improved error handling to ensure necessary HDF5 "close" calls are invoked. This is to insure the HDF5 dataset is closed, the HDF5 file is closed, and the HDF5 Fortran interface is closed before return. 3. Added additional local error code variable to handle subsequent HDF5 close calls after an error occurs, to ensure non-zero error is returned from the reader subroutine. Also, the local error code variable is used after a successful copy to the output array, since errors in closing the dataset, file, and interface should have no impact on the data returned. 4. Removed unnecessary logical variable, which was set .true. or .false. but not returned or used for anything. --- lis/metforcing/imerg/read_imerg.F90 | 131 ++++++++++++++++------------ 1 file changed, 73 insertions(+), 58 deletions(-) diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index 16bfe69fb..7a8aaa97e 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -15,6 +15,9 @@ ! !REVISION HISTORY: ! 17 Jul 2001: Jon Gottschalck; Initial code ! 09 Mar 2015: Jon Case; Added IMERG precipitation reader +! 07 Aug 2023: Jessica Erlingas; Added support for IMERG V07 +! 16 Aug 2023: Eric Kemp; Improved graceful HDF5 library cleanup if +! error is detected. ! ! !INTERFACE: subroutine read_imerg (n, kk, name_imerg, findex, order, ferror_imerg ) @@ -150,82 +153,94 @@ subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) character(len=40) :: dsetname real :: precipin(ysize,xsize) real :: precipout(xsize,ysize) - logical :: bIsError integer :: istatus,i character(len=4) :: vlname integer :: vnum, n #if (defined USE_HDF5) integer(HSIZE_T), dimension(2) :: dims - integer(HID_T) :: fileid,dsetid + integer(HID_T) :: fileid, dsetid + integer :: ierr dims(1) = xsize dims(2) = ysize - bIsError=.false. - ! Variable names changed in IMERG V07 - vlname = trim(imerg_struc(n)%imergver) - read( vlname(3:3), *) vnum - - if(vnum.ge.7) then + read( vlname(3:3), '(I)') vnum + if (vnum .ge. 7) then dsetname='/Grid/precipitation' else dsetname='/Grid/precipitationCal' endif -!open fortran interface + + istatus = 0 ! istatus is returned from this subroutine + ierr = 0 ! ierr is strictly a local variable + + ! Open Fortran interface call h5open_f(istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error opening HDF5 fortran interface' - return - endif -!open hdf5 file - call h5fopen_f(filename,H5F_ACC_RDONLY_F,fileid,istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error opening IMERG file',trim(filename) - return - endif -!open dataset - call h5dopen_f(fileid,dsetname,dsetid,istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error opening IMERG dataset',trim(dsetname) - return - endif -!read dataset - call h5dread_f(dsetid,H5T_NATIVE_REAL,precipin,dims,istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error reading IMERG dataset',trim(dsetname) - return - endif -!Put the real(1:,1:) on the precipout(0:,0:) -!precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) + if (istatus .ne. 0) then + ! No need to proceed, something is wrong with HDF5. + write (LIS_logunit,*) '[WARN] Error opening HDF5 Fortran interface' + return + end if + + ! Open HDF5 file. + call h5fopen_f(filename, H5F_ACC_RDONLY_F, fileid, istatus) + if (istatus .ne. 0) then + ! We couldn't open the file. Close the Fortran interface and return. + ! Don't overwrite the istatus value. + write (LIS_logunit,*) '[WARN] Error opening IMERG file', & + trim(filename) + call h5close_f(ierr) + return + end if + + ! Open dataset + call h5dopen_f(fileid, dsetname, dsetid, istatus) + if (istatus .ne. 0) then + ! We can't open the dataset. Close the file and Fortran interface. + ! Don't overwrite the istatus value. + write (LIS_logunit,*) '[WARN] Error opening IMERG dataset', & + trim(dsetname) + call h5fclose_f(fileid, ierr) + call h5close_f(ierr) + return + end if + + ! Read dataset + call h5dread_f(dsetid, H5T_NATIVE_REAL, precipin, dims, istatus) + if (istatus .ne. 0) then + ! We can't read the dataset. Close the dataset, the file, and + ! the Fortran interface. Don't overwrite the istatus values. + write (LIS_logunit,*) '[WARN] Error reading IMERG dataset', & + trim(dsetname) + call h5dclose_f(dsetid, ierr) + call h5fclose_f(fileid, ierr) + call h5close_f(ierr) + return + end if + + ! Put the real(1:,1:) on the precipout(0:,0:) + ! precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) precipout(1:xsize,1:ysize)=transpose(precipin) -!close dataset - call h5dclose_f(dsetid,istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error closing IMERG dataset',trim(dsetname) - return - endif -!close file - call h5fclose_f(fileid,istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error closing IMERG file',trim(filename) - return - endif -!close fortran interface - call h5close_f(istatus) - if(istatus.ne.0) then - bIsError=.true. - if (LIS_masterproc) write (LIS_logunit,*) 'Error closing HDF5 fortran interface' - return - endif + ! Close the dataset, file, and Fortran interface. We already have + ! the IMERG data in the array, so we don't need to overwrite the + ! istatus value. But we'll still log problems. + call h5dclose_f(dsetid, ierr) + if (ierr .ne. 0) then + write (LIS_logunit,*) '[WARN] Error closing IMERG dataset', & + trim(dsetname) + end if + call h5fclose_f(fileid, ierr) + if (ierr .ne. 0) then + write (LIS_logunit,*) '[WARN] Error closing IMERG file', & + trim(filename) + end if + call h5close_f(ierr) + if (ierr .ne. 0) then + write (LIS_logunit,*) '[WARN] Error closing HDF5 Fortran interface' + end if #endif From b12d2739d0a96cfcd3c58dbee823233a33c5dda2 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 17 Aug 2023 11:18:17 -0400 Subject: [PATCH 153/328] Make all processes log messages regarding reading IMERG --- lis/metforcing/imerg/read_imerg.F90 | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index 7a8aaa97e..d45a16e64 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -22,7 +22,7 @@ ! !INTERFACE: subroutine read_imerg (n, kk, name_imerg, findex, order, ferror_imerg ) ! !USES: - use LIS_coreMod,only : LIS_rc, LIS_domain, LIS_masterproc + use LIS_coreMod,only : LIS_rc, LIS_domain use LIS_logMod, only : LIS_logunit, LIS_getNextUnitNumber, & LIS_releaseUnitNumber use LIS_metforcingMod,only : LIS_forc @@ -93,16 +93,16 @@ subroutine read_imerg (n, kk, name_imerg, findex, order, ferror_imerg ) ferror_imerg = 1 inquire(file=fname, EXIST=file_exists) if (file_exists) then - if(LIS_masterproc) write(LIS_logunit,*) & + write(LIS_logunit,*) & "[INFO] Reading HDF5 IMERG precipitation data from ", trim(fname) call read_imerghdf(n, fname, xd, yd, realprecip, ireaderr) if (ireaderr .ne. 0) then - if(LIS_masterproc) write(LIS_logunit,*) & + write(LIS_logunit,*) & "[WARN] Error reading IMERG file ",trim(fname) ferror_imerg = 0 endif else - if(LIS_masterproc) write(LIS_logunit,*) & + write(LIS_logunit,*) & "[WARN] Missing IMERG precipitation data:: ",trim(fname) ferror_imerg = 0 endif @@ -126,8 +126,7 @@ subroutine read_imerg (n, kk, name_imerg, findex, order, ferror_imerg ) endif enddo enddo - if (LIS_masterproc) & - write(LIS_logunit,*) "Obtained IMERG precipitation data from ", trim(fname) + write(LIS_logunit,*) "Obtained IMERG precipitation data from ", trim(fname) endif deallocate (precip_regrid) @@ -141,7 +140,7 @@ subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) #if (defined USE_HDF5) use hdf5 #endif - use LIS_coreMod, only : LIS_rc, LIS_domain, LIS_masterproc + use LIS_coreMod, only : LIS_rc, LIS_domain use LIS_logMod, only : LIS_logunit, LIS_getNextUnitNumber use imerg_forcingMod, only : imerg_struc @@ -211,7 +210,7 @@ subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) call h5dread_f(dsetid, H5T_NATIVE_REAL, precipin, dims, istatus) if (istatus .ne. 0) then ! We can't read the dataset. Close the dataset, the file, and - ! the Fortran interface. Don't overwrite the istatus values. + ! the Fortran interface. Don't overwrite the istatus value. write (LIS_logunit,*) '[WARN] Error reading IMERG dataset', & trim(dsetname) call h5dclose_f(dsetid, ierr) From 54d716cad76322691e22808fc33beb0ee8e58e3b Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 17 Aug 2023 14:39:37 -0400 Subject: [PATCH 154/328] Update IMERG documentation --- lis/configs/lis.config.adoc | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index a05404c88..82382f346 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -5973,8 +5973,18 @@ default to the "`final`" product of GPM IMERG. `IMERG version:` specifies the version of the GPM IMERG precipitation forcing files. If no version is specified, -the reader will default to the latest version of GPM IMERG. -(Currently V06B). +the reader will default to "`V06B`". + +The supported versions of GPM IMERG are: + +|==== +|Version | Product + +|V06B | early, late, final +|V06C | early, late, final +|V06D | early, late, final +|V07A | preliminary support for final +|==== .Example _lis.config_ entry .... From cfbd323b6352945bee2547ab50a64552b72d197f Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Fri, 18 Aug 2023 15:16:14 -0400 Subject: [PATCH 155/328] Bug fix: improved error handling --- ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 index 4f6a3653f..3a487468e 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -71,9 +71,16 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) #if(defined USE_NETCDF3 || defined USE_NETCDF4) inquire(file=trim(filename), exist=file_exists) - if(file_exists) then - write(LDT_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) + if (.not. file_exists) then + write(LDT_logunit,*) '[ERR] (',filename, & + ') does not exist. Please provide a monthly precipitation climatology in CDF format ' + call LDT_endrun() + end if + + !if(file_exists) then + + write(LDT_logunit,*) '[INFO] Reading Precipitation climatology from CDF file ',trim(filename) !if(ngrid.gt.0) then call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& ncid=nid),'failed to open file '//trim(filename)) @@ -114,7 +121,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) ios = nf90_close(nid) call LDT_verify(ios,'Error in nf90_close in readldtparam_real_2d') write(LDT_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) - endif + !endif precip = precip_climo deallocate(precip_climo) From 5dbe6f5025926e3d06268bd50cfc0650d1307d08 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 21 Aug 2023 15:26:50 -0400 Subject: [PATCH 156/328] Fix GNU Fortran compiler error --- lis/metforcing/imerg/read_imerg.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index d45a16e64..aa052468c 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -165,7 +165,7 @@ subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) ! Variable names changed in IMERG V07 vlname = trim(imerg_struc(n)%imergver) - read( vlname(3:3), '(I)') vnum + read( vlname(3:3), '(I4)') vnum if (vnum .ge. 7) then dsetname='/Grid/precipitation' else From c703aefc9ce69335ae42fdfca3f284e2d1f565e7 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 22 Aug 2023 09:00:11 -0400 Subject: [PATCH 157/328] Tweaked conversion to read two digits. --- lis/metforcing/imerg/read_imerg.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index aa052468c..039d4c185 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -165,7 +165,7 @@ subroutine read_imerghdf(n, filename, xsize, ysize, precipout, istatus) ! Variable names changed in IMERG V07 vlname = trim(imerg_struc(n)%imergver) - read( vlname(3:3), '(I4)') vnum + read( vlname(2:3), '(I2)') vnum if (vnum .ge. 7) then dsetname='/Grid/precipitation' else From aa848011c527a8891000f861412c9706749fbe68 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 29 Aug 2023 17:04:27 -0400 Subject: [PATCH 158/328] Changed "new" sfcsno file format to global file. Station IDs now 32 chars. --- ldt/USAFSI/LDT_bratsethMod.F90 | 21 +++---- ldt/USAFSI/USAFSI_analysisMod.F90 | 96 +++++++++++++++++++++++-------- ldt/USAFSI/USAFSI_run.F90 | 9 +-- 3 files changed, 87 insertions(+), 39 deletions(-) diff --git a/ldt/USAFSI/LDT_bratsethMod.F90 b/ldt/USAFSI/LDT_bratsethMod.F90 index d5901519f..dc2ccba0b 100644 --- a/ldt/USAFSI/LDT_bratsethMod.F90 +++ b/ldt/USAFSI/LDT_bratsethMod.F90 @@ -20,6 +20,7 @@ ! Brasnett. Plus, other bug fixes. ! 02 Nov 2020 Eric Kemp Removed blacklist at request of 557WW. ! 28 Jul 2023 Eric Kemp Expanded station ID to 31 characters. +! 24 Aug 2023 Eric Kemp Expanded station ID to 32 characters. ! ! DESCRIPTION: ! Source code for snow depth analysis using the Bratseth objective analysis @@ -79,7 +80,7 @@ module LDT_bratsethMod real :: back_err_v_corr_len ! Background error vert correlation length integer :: nobs ! Number of observations character*10, allocatable :: networks(:) ! Network name - character*31, allocatable :: platforms(:) ! Observation station ID + character*32, allocatable :: platforms(:) ! Observation station ID real, allocatable :: obs(:) ! Observed values real, allocatable :: lats(:) ! Latitude of observation (deg N) real, allocatable :: lons(:) ! Longitude of observation (deg E) @@ -242,7 +243,7 @@ subroutine LDT_bratseth_append_ob(this, network, platform, ob, & ! Arguments class(LDT_bratseth_t),intent(inout) :: this character(len=10), intent(in) :: network - character(len=31), intent(in) :: platform + character(len=32), intent(in) :: platform real, intent(in) :: ob real, intent(in) :: lat real, intent(in) :: lon @@ -840,7 +841,7 @@ subroutine LDT_bratseth_run_dup_qc(this) real :: mean, back, newlat, newlon, newelev real :: ob_err_var, ob_err_corr_len character(len=10) :: network - character(len=31) :: platform + character(len=32) :: platform real :: diff integer :: i,j logical :: reject_all @@ -1255,7 +1256,7 @@ subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, & ! Arguments class(LDT_bratseth_t), intent(inout) :: this integer, intent(in) :: n - character(len=31), intent(in) :: new_name + character(len=32), intent(in) :: new_name integer, intent(in) :: ncols integer, intent(in) :: nrows logical, optional, intent(in) :: silent_rejects @@ -1265,7 +1266,7 @@ subroutine LDT_bratseth_run_superstat_qc(this, n, new_name, & integer :: num_rejected_obs, num_merged_obs, num_superobs logical :: silent_rejects_local character(len=10) :: network_new - character(len=31) :: platform_new + character(len=32) :: platform_new integer, allocatable :: actions(:) real, allocatable :: means(:,:) real, allocatable :: superobs(:,:), superbacks(:,:) @@ -1820,7 +1821,7 @@ subroutine LDT_bratseth_resort_bad_obs(this) integer :: iob,job logical :: found_replacement character*10 :: network - character*31 :: platform + character*32 :: platform real :: ob, lat, lon, elev, ob_err_var, back integer :: qc character*80 :: failed_qc_test @@ -2058,7 +2059,7 @@ subroutine LDT_bratseth_sort_obs_by_id(this) integer :: gap integer :: switch character*10 :: ctemp10 - character*31 :: ctemp31 + character*32 :: ctemp32 character*80 :: ctemp80 real :: rtemp integer :: itemp @@ -2085,9 +2086,9 @@ subroutine LDT_bratseth_sort_obs_by_id(this) this%networks(i) = this%networks(j) this%networks(j) = ctemp10 - ctemp31 = this%platforms(i) + ctemp32 = this%platforms(i) this%platforms(i) = this%platforms(j) - this%platforms(j) = ctemp31 + this%platforms(j) = ctemp32 rtemp = this%obs(i) this%obs(i) = this%obs(j) @@ -2159,7 +2160,7 @@ subroutine LDT_bratseth_print_snowdepths(this,minprt) int(this%elevs(i)), this%obs(i), trim(this%reject_reasons(i)) end if end do ! i -7000 format (/,'[INFO] NETID = ',A5,' STATION ID = ',A31, & +7000 format (/,'[INFO] NETID = ',A5,' STATION ID = ',A32, & ' LAT = ',F6.2,' LON = ',F7.2, & ' ELEV(M) = ',I5,' DEPTH(M) = ', F7.5, & ' QC VERDICT = ',A) diff --git a/ldt/USAFSI/USAFSI_analysisMod.F90 b/ldt/USAFSI/USAFSI_analysisMod.F90 index e6ab7d92c..d1d01ab14 100644 --- a/ldt/USAFSI/USAFSI_analysisMod.F90 +++ b/ldt/USAFSI/USAFSI_analysisMod.F90 @@ -744,6 +744,7 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & !** 09 May 19 Renamed LDTSI...Eric Kemp, NASA GSFC/SSAI !** 13 Dec 19 Renamed USAFSI...Eric Kemp, NASA GSFC/SSAI !** 27 Jul 23 Added new sfcobs file format...Eric Kemp, SSAI + !** 24 Aug 23 New global sfcsno file format...Eric Kemp, SSAI !** !******************************************************************************* !******************************************************************************* @@ -763,7 +764,7 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & integer, intent(in) :: month ! CURRENT MONTH (1-12) character*255, intent(in) :: sfcobs ! PATH TO DBPULL SNOW OBS DIRECTORY character*5, intent(out) :: netid (:) ! NETWORK ID OF AN OBSERVATION - character*31, intent(out) :: staid (:) ! STATION ID OF AN OBSERVATION + character*32, intent(out) :: staid (:) ! STATION ID OF AN OBSERVATION integer, intent(out) :: stacnt ! TOTAL NUMBER OF OBSERVATIONS USED integer, intent(out) :: stalat (:) ! LATITUDE OF A STATION OBSERVATION @@ -784,9 +785,9 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & character*90 :: message (msglns) ! ERROR MESSAGE character*255 :: obsfile ! NAME OF OBSERVATION TEXT FILE character*5 :: obsnet ! RETURNED OBS STATION NETWORK - character*31 :: obssta ! RETURNED OBS STATION ID + character*32 :: obssta ! RETURNED OBS STATION ID character*5, allocatable :: oldnet (:) ! ARRAY OF NETWORKS FOR OLDSTA - character*31, allocatable :: oldsta (:) ! ARRAY OF PROCESSED STATIONS WITH SNOW DEPTHS + character*32, allocatable :: oldsta (:) ! ARRAY OF PROCESSED STATIONS WITH SNOW DEPTHS character*12 :: routine_name ! NAME OF THIS SUBROUTINE integer :: ctrgrd ! TEMP HOLDER FOR GROUND OBS INFO @@ -864,9 +865,9 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & if (sfcobsfmt == 1) then obsfile = trim(sfcobs) // 'sfcsno_' // chemi(hemi) // & interval // date10 // '.txt' - else if (sfcobsfmt == 2) then - obsfile = trim(sfcobs) // 'newsno_' // chemi(hemi) // & - interval // date10 // '.txt' + else if (sfcobsfmt == 2) then ! Global file + obsfile = trim(sfcobs) // 'sfcsno_' // & + '06hr_' // date10 // '.txt' end if inquire (file=obsfile, exist=isfile) file_check : if (isfile) then @@ -891,6 +892,7 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & obelev, & itemp, depth, ground else if (sfcobsfmt == 2) then + ! New format with longer station IDs read (lunsrc(hemi), 6401, iostat=istat, end=3000, & err=5000) & date10_hourly, obsnet, obssta, oblat, oblon, & @@ -901,9 +903,15 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & if (date10_hourly .ne. date10_prev) then if (totalobs > 1) then - write(ldt_logunit,6500) & - trim(routine_name), chemicap(hemi), & - date10_prev, obsrtn + if (sfcobsfmt == 1) then + write(ldt_logunit,6500) & + trim(routine_name), chemicap(hemi), & + date10_prev, obsrtn + else + write(ldt_logunit,6501) & + trim(routine_name), & + date10_prev, obsrtn + end if obsrtn = 0 end if end if @@ -1076,38 +1084,64 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & if (totalobs > 0) then stacnt_h = stacnt - stacnt_h - write (ldt_logunit,6500) trim(routine_name), chemicap(hemi), & - date10_prev, obsrtn - - write (ldt_logunit,6800) trim(routine_name), chemicap(hemi), & - totalobs, & - stacnt_h, obwsno, ctrgrd, ctrtmp, ctrtrs - + if (sfcobsfmt == 1) then + write (ldt_logunit,6500) trim(routine_name), & + chemicap(hemi), & + date10_prev, obsrtn + write (ldt_logunit,6800) trim(routine_name), & + chemicap(hemi), & + totalobs, & + stacnt_h, obwsno, ctrgrd, ctrtmp, ctrtrs + else if (sfcobsfmt == 2) then + write (ldt_logunit,6501) trim(routine_name), & + date10_prev, obsrtn + write (ldt_logunit,6801) trim(routine_name), & + totalobs, & + stacnt_h, obwsno, ctrgrd, ctrtmp, ctrtrs + end if else - message(1) = & - '[WARN] NO SURFACE OBSERVATIONS READ FOR ' // date10 // & - ' ' // chemicap(hemi) + if (sfcobsfmt == 1) then + message(1) = & + '[WARN] NO SURFACE OBSERVATIONS READ FOR ' // & + date10 // & + ' ' // chemicap(hemi) + else if (sfcobsfmt == 2) then + message(1) = & + '[WARN] NO SURFACE OBSERVATIONS READ FOR ' // & + date10 + end if call error_message (program_name, routine_name, message) end if else file_check - message(1) = & - '[WARN] NO SURFACE OBSERVATIONS FILE FOR ' // date10 // & - ' ' // chemicap(hemi) + if (sfcobsfmt == 1) then + message(1) = & + '[WARN] NO SURFACE OBSERVATIONS FILE FOR ' // & + date10 // & + ' ' // chemicap(hemi) + else if (sfcobsfmt == 2) then + message(1) = & + '[WARN] NO SURFACE OBSERVATIONS FILE FOR ' & + // date10 + end if + message(2) = '[WARN] Looked for ' // trim(obsfile) call error_message (program_name, routine_name, message) end if file_check + ! New file format is global, so we don't need to loop again + if (sfcobsfmt == 2) exit + end do hemi_loop ! DEALLOCATE ARRAYS deallocate (oldsta) return - + ! ERROR-HANDLING SECTION. 5000 continue @@ -1122,9 +1156,12 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & 6000 format (/, '[INFO] ', A, ': READING ', A) !6200 format (I) 6400 format (A10, 1X, A5, 1X, A10, 6(I10)) -6401 format (A10, 1X, A5, 1X, A31, 1X, 6(I10)) +!6401 format (A10, 1X, A5, 1X, A31, 1X, 6(I10)) +6401 format (A10, 1X, A5, 1X, A32, 6(I10)) 6500 format (/, '[INFO] ', A6, ': SURFACE OBS READ FOR ', A2, ' DTG ', & A10, ' = ', I6) +6501 format (/, '[INFO] ', A6, ': SURFACE OBS READ FOR DTG ', & + A10, ' = ', I6) 6600 format (1X, '**', A6, ': DEPTH = ', I6, ' STADEP = ', I6) 6700 format (/, 1X, '[INFO] HIGH POLAR TEMP: NETW= ', A5, 1X, 'STN= ', A31, & 1X, 'LAT= ', F8.2, 1X, 'LON= ', F8.2, & @@ -1139,6 +1176,15 @@ subroutine getobs (date10, month, sfcobs, netid, staid, stacnt, & /, 5X, '[INFO] OBS NOT USED FOR SEASON AND ELEVATION = ', I4, & /, 5X, '[INFO] OBS NOT USED FOR EXCEEDED TEMP THRESH = ', I6, & /, 1X, 55('-')) +6801 format (/, 1X, 55('-'), & + /, 3X, '[INFO] SUBROUTINE: ', A6, & + /, 5X, '[INFO] TOTAL SURFACE OBS READ = ', I6, & + /, 5X, '[INFO] TOTAL NON-DUPLICATE OBS PROCESSED = ', I6, & + /, 5X, '[INFO] STATIONS WITH A FOUR-THREE GROUP = ', I4, & + /, 5X, '[INFO] OBS NOT USED FOR STATE OF GROUND = ', I4, & + /, 5X, '[INFO] OBS NOT USED FOR SEASON AND ELEVATION = ', I4, & + /, 5X, '[INFO] OBS NOT USED FOR EXCEEDED TEMP THRESH = ', I6, & + /, 1X, 55('-')) end subroutine getobs @@ -2800,7 +2846,7 @@ subroutine run_snow_analysis_noglacier(runcycle, nc, nr, landmask, & integer :: snomask_reject_count integer :: bad_back_count, glacier_zone_count real :: ob_value - character*31 :: new_name + character*32 :: new_name integer :: gindex real :: rlat diff --git a/ldt/USAFSI/USAFSI_run.F90 b/ldt/USAFSI/USAFSI_run.F90 index 0a2672e2f..cd2733d07 100644 --- a/ldt/USAFSI/USAFSI_run.F90 +++ b/ldt/USAFSI/USAFSI_run.F90 @@ -70,6 +70,7 @@ subroutine USAFSI_run(n) !** and cleaned some unused codes..................Yeosang Yoon/NASA GSFC/SAIC !** 13 Jan 22 Added support for FNMOC SST GRIB1 file.........Eric Kemp/NASA GSFC/SSAI !** 28 Jun 23 Extended station names to 31 characters........Eric Kemp/SSAI + !** 24 Aug 23 Changed station names to 32 characters.........Eric Kemp/SSAI !***************************************************************************************** !***************************************************************************************** @@ -111,7 +112,7 @@ subroutine USAFSI_run(n) integer :: sfcobsfmt ! Format of sfcobs file character*255 :: TB_product_path ! TB_based retrivals path !kyh20201118 !character*9, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION - character*31, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION + character*32, allocatable :: staid (:) ! STATION ID OF AN OBSERVATION character*255 :: static ! STATIC FILE DIRECTORY PATH character*255 :: stmpdir ! SFC TEMP DIRECTORY PATH character*255 :: sstdir ! EMK 20220113 @@ -133,7 +134,7 @@ subroutine USAFSI_run(n) character*12 :: routine_name type(LDT_bratseth_t) :: bratseth character*10 :: network10 - character*31 :: platform31 + character*32 :: platform32 real :: rob, rlat, rlon, relev integer :: nc,nr real, allocatable :: landmask(:,:) @@ -390,12 +391,12 @@ subroutine USAFSI_run(n) ! EMK Copy observations to bratseth object do j = 1, stacnt network10 = trim(netid(j)) - platform31 = trim(staid(j)) + platform32 = trim(staid(j)) rob = stadep(j) rlat = real(stalat(j)) * 0.01 rlon = real(stalon(j)) * 0.01 relev = real(staelv(j)) - call bratseth%append_ob(network10, platform31, rob, & + call bratseth%append_ob(network10, platform32, rob, & rlat, rlon,& relev, & usafsi_settings%ob_err_var, back=-1.) From e27c778413c639927712d2d8d4d33ec1f94078e7 Mon Sep 17 00:00:00 2001 From: David Mocko Date: Thu, 7 Sep 2023 09:14:52 -0400 Subject: [PATCH 159/328] Fix ISRIC soil texture water point index value in LDT This pull request fixes the water point index values when using the ISRIC soil texture maps in LDT. LDT re-maps the ISRIC soil texture map onto the STATSGO soil classification index. However, the water points were incorrectly assigned a value of 13, when it should be 14 in the STATSGO soil texture classification. Resolves: #1406 --- ldt/core/LDT_paramOptCheckMod.F90 | 4 ++-- ldt/core/LDT_soilsMod.F90 | 8 ++++---- ldt/params/soils/read_ISRIC_texture.F90 | 2 +- ldt/params/soils/set_ISRIC_texture_attribs.F90 | 2 +- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/ldt/core/LDT_paramOptCheckMod.F90 b/ldt/core/LDT_paramOptCheckMod.F90 index 41e17df70..8b705f607 100644 --- a/ldt/core/LDT_paramOptCheckMod.F90 +++ b/ldt/core/LDT_paramOptCheckMod.F90 @@ -483,8 +483,8 @@ subroutine LDT_soilsOptChecks( n, param_name, soil_class, spatial_transform ) endif case( "ISRIC") - if (nt.ne.13) then - write(LDT_logunit,*) "Param_Check: ISRIC has 13 types (includes water) for tiling." + if (nt.ne.16) then + write(LDT_logunit,*) "Param_Check: ISRIC has 16 types (includes water) for tiling." write(LDT_logunit,*) " The current value is: ",nt write(LDT_logunit,*) " Stopping ..." call LDT_endrun diff --git a/ldt/core/LDT_soilsMod.F90 b/ldt/core/LDT_soilsMod.F90 index cff4a36b2..7eb889b1f 100644 --- a/ldt/core/LDT_soilsMod.F90 +++ b/ldt/core/LDT_soilsMod.F90 @@ -782,7 +782,7 @@ subroutine soils_init_LIS() elseif(INDEX(LDT_LSMparam_struc(n)%texture%source,"ZOBLER") >0) then soiltext%watervalue = 1.0 elseif(INDEX(LDT_LSMparam_struc(n)%texture%source,"ISRIC") >0) then - soiltext%watervalue = 13. + soiltext%watervalue = 14. else soiltext%watervalue = LDT_rc%udef endif @@ -1484,7 +1484,7 @@ subroutine soils_init_LISHydro(flag) elseif(INDEX(LDT_LSMparam_struc(n)%texture%source,"ZOBLER") >0) then soiltext%watervalue = 1.0 elseif(INDEX(LDT_LSMparam_struc(n)%texture%source,"ISRIC") >0) then - soiltext%watervalue = 13. + soiltext%watervalue = 14. else soiltext%watervalue = LDT_rc%udef endif @@ -1814,7 +1814,7 @@ subroutine soils_writeHeader_LIS(n,ftn,dimID) 14)) elseif( LDT_rc%soil_classification(1) == "ISRIC" ) then call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_SOILTYPES", & - 13)) + 19)) else call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_SOILTYPES", & 19)) @@ -1972,7 +1972,7 @@ subroutine soils_writeHeader_LISHydro(n,ftn,dimID,flag) 14)) elseif( LDT_rc%soil_classification(1) == "ISRIC" ) then call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_SOILTYPES", & - 13)) + 19)) else call LDT_verify(nf90_put_att(ftn,NF90_GLOBAL,"NUMBER_SOILTYPES", & 19)) diff --git a/ldt/params/soils/read_ISRIC_texture.F90 b/ldt/params/soils/read_ISRIC_texture.F90 index 1b6bf4d0d..21e17b627 100644 --- a/ldt/params/soils/read_ISRIC_texture.F90 +++ b/ldt/params/soils/read_ISRIC_texture.F90 @@ -94,7 +94,7 @@ subroutine read_ISRIC_texture( n, num_bins, fgrd, texture_layers ) ! ___________________________________________________________________ - water_class = 13 ! Water class for ISRIC soil texture class + water_class = 14 ! Water class for ISRIC soil texture class temp = LDT_rc%udef gridcnt = 0. diff --git a/ldt/params/soils/set_ISRIC_texture_attribs.F90 b/ldt/params/soils/set_ISRIC_texture_attribs.F90 index a50614c00..470996bc6 100644 --- a/ldt/params/soils/set_ISRIC_texture_attribs.F90 +++ b/ldt/params/soils/set_ISRIC_texture_attribs.F90 @@ -34,7 +34,7 @@ subroutine set_ISRIC_texture_attribs() ! \end{description} !EOP ! - LDT_LSMparam_struc(:)%texture%num_bins = 13 + LDT_LSMparam_struc(:)%texture%num_bins = 16 LDT_LSMparam_struc(:)%texture%vlevels = 1 LDT_soils_struc(:)%texture_nlyrs%num_bins = 1 From 1d817ba0015668e452294b8c1e8637d504885afc Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 7 Sep 2023 12:55:54 -0400 Subject: [PATCH 160/328] Remove unused LAPACK and MKL_LAPACK macros --- lis/arch/Config.pl | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index e11f911f6..8bc281462 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -1241,20 +1241,6 @@ printf misc_file "%s\n","#undef RTMS "; } -if($use_lapack == 1) { - printf misc_file "%s\n","#define LAPACK "; -} -else{ - printf misc_file "%s\n","#undef LAPACK "; -} - -if($use_mkllapack == 1) { - printf misc_file "%s\n","#define MKL_LAPACK "; -} -else{ - printf misc_file "%s\n","#undef MKL_LAPACK "; -} - if($use_petsc == 1) { printf misc_file "%s\n","#define PETSc "; } From 778db5bcbca36a82a342ab50c13730d8653685aa Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 7 Sep 2023 12:56:35 -0400 Subject: [PATCH 161/328] Rework the handling of the LAPACK libraries by Config.pl This allows compiling LIS with the PETSc library using the GNU compilers. These two prompts Use LIS-LAPACK? (1-yes, 0-no, default=0): Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): were combined into one because you cannot enable both at the same time. --- lis/arch/Config.pl | 50 +++++++++++++++------------------------------- 1 file changed, 16 insertions(+), 34 deletions(-) diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index 8bc281462..f4fc2dfcd 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -802,7 +802,7 @@ } } -print "Use LIS-LAPACK? (1-yes, 0-no, default=0): "; +print "Use LIS-LAPACK? (0-no, 1-mkl, 2-lapack/blas, 3-lapack/refblas, default=0): "; $use_lapack=; $use_lapack=~s/ *#.*$//; chomp($use_lapack); @@ -810,7 +810,7 @@ $use_lapck=0; } -if($use_lapack == 1) { +if($use_lapack != 0) { if(defined($ENV{LIS_LAPACK})){ $sys_lapack_path = $ENV{LIS_LAPACK}; $lib = "/"; @@ -826,29 +826,6 @@ } } -print "Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): "; -$use_mkllapack=; -chomp($use_mkllapack); -if($use_mkllapack eq ""){ - $use_mkllapck=0; -} - -if($use_mkllapack == 1) { - if(defined($ENV{LIS_MKL_LAPACK})){ - $sys_lapack_path = $ENV{LIS_MKL_LAPACK}; - $lib = "/"; - $lib_lapack=$sys_lapack_path.$lib; - } - else { - print "--------------ERROR---------------------\n"; - print "Please specify the MKL-LAPACK path using\n"; - print "the LIS_MKL_LAPACK variable.\n"; - print "Configuration exiting ....\n"; - print "--------------ERROR---------------------\n"; - exit 1; - } -} - print "Use PETSc? (1-yes, 0-no, default=0): "; $use_petsc=; chomp($use_petsc); @@ -1057,20 +1034,25 @@ $lib_paths= $lib_paths." -L\$(LIB_MINPACK)"; } +if($use_petsc == 1){ + $fflags = $fflags." -I\$(INC_PETSC)"; + $ldflags = $ldflags." -L\$(LIB_PETSC) -lpetsc -lm"; +} + if($use_lapack == 1){ + $ldflags = $ldflags." -L\$(LIB_LAPACK) -lmkl_rt"; + $lib_flags= $lib_flags." -lmkl_rt"; + $lib_paths= $lib_paths." -L\$(LIB_LAPACK)"; +} +elsif($use_lapack == 2){ $ldflags = $ldflags." -L\$(LIB_LAPACK) -llapack -lblas"; $lib_flags= $lib_flags." -llapack -lblas"; $lib_paths= $lib_paths." -L\$(LIB_LAPACK)"; } - -if($use_mkllapack == 1){ - #Changed to be able to use mkl Wendy Sharples - $ldflags = $ldflags." -L\$(LIB_LAPACK) -lmkl_rt"; -} - -if($use_petsc == 1){ - $fflags = $fflags." -I\$(INC_PETSC)"; - $ldflags = $ldflags." -L\$(LIB_PETSC) -lpetsc -lm"; +elsif($use_lapack == 3){ + $ldflags = $ldflags." -L\$(LIB_LAPACK) -llapack -lrefblas"; + $lib_flags= $lib_flags." -llapack -lrefblas"; + $lib_paths= $lib_paths." -L\$(LIB_LAPACK)"; } if($use_esmf_trace == 1){ From f2b7dffb07f1125cc8d21c4c5e34757370732f67 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 7 Sep 2023 12:57:52 -0400 Subject: [PATCH 162/328] Update "Building the Executable" section in the LIS Users' Guide Add instructions for the "Use LIS-LAPACK?" prompt. --- docs/LIS_users_guide/build.adoc | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/docs/LIS_users_guide/build.adoc b/docs/LIS_users_guide/build.adoc index 14c9273d7..9251602b1 100644 --- a/docs/LIS_users_guide/build.adoc +++ b/docs/LIS_users_guide/build.adoc @@ -96,6 +96,7 @@ This script will prompt the user with a series of questions regarding support to | `LIS_CRTM_PROF` | path to LIS-CRTM Profile library | optional | `LIS_CMEM` | path to LIS-CMEM library | optional | `LIS_LAPACK` | path to LAPACK library | optional +| `LIS_PETSC` | path to PETSc library | optional | `LIS_JPEG` | path to JPEG library | optional (use system libjpeg by default) |==== @@ -137,8 +138,7 @@ Use HDFEOS? (1-yes, 0-no, default=1): Use MINPACK? (1-yes, 0-no, default=0): Use LIS-CRTM? (1-yes, 0-no, default=0): Use LIS-CMEM? (1-yes, 0-no, default=0): -Use LIS-LAPACK? (1-yes, 0-no, default=0): -Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): +Use LIS-LAPACK? (0-no, 1-mkl, 2-lapack/blas, 3-lapack/refblas, default=0): Use PETSc? (1-yes, 0-no, default=0): ----------------------------------------------------- configure.lis file generated successfully @@ -175,6 +175,20 @@ if you wish to enable LIS-CRTM2EM support, then you must also enable LIS-CMEM su * for `Use LIS-CMEM? (1-yes, 0-no, default=0):`, if you wish to enable LIS-CMEM support, then you must also enable LIS-CRTM. So for `Use LIS-CRTM? (1-yes, 0-no, default=0):`, you must also select 1. +* for `Use LIS-LAPACK? (0-no, 1-mkl, 2-lapack/blas, 3-lapack/refblas, default=0):`, +select the type of LAPACK library that you have installed. This is used with `Use PETSc? (1-yes, 0-no, default=0):`. If you select 0 for `Use PETSc?`, then select 0 for `Use LIS-LAPACK?`. If you select 1 for `Use PETSc?`, then select `Use LIS-LAPACK?` according to the following table: ++ +|==== +| Selection | Description + +| 0 | No LAPACK needed / Use system LAPACK +| 1 | LAPACK in Intel MKL +| 2 | liblapack / libblas +| 3 | liblapack / librefblas +|==== ++ +For example, on a Cray system using the Cray compilers, select 0 because the linker will find Cray's LAPACK libraries. + Note that due to an issue involving multiple definitions within the NetCDF 3 and HDF 4 libraries, you cannot compile LIS with support for both NetCDF 3 and HDF 4 together. Note that if you compiled NetCDF 4 without compression, then when specifying `NETCDF version (3 or 4, default=4):`, select 3. Then you must manually append `-lnetcdff` to the `LDFLAGS` variable in the _make/configure.lis_ file. From f1271f69adb3838bf320e957b5b8060caa89c321 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 8 Sep 2023 16:52:09 -0400 Subject: [PATCH 163/328] First attempt at adding IMERG Monthly support. This only supports V07A Final Run. Code compiles, but has not been run yet. --- .../IMERG_monthly/IMERG_monthly_dataMod.F90 | 170 +++++++++ .../IMERG_monthly/readIMERGmonthlydata.F90 | 327 ++++++++++++++++++ lvt/make/Filepath | 2 +- lvt/plugins/LVT_datastream_pluginMod.F90 | 9 +- lvt/plugins/LVT_pluginIndices.F90 | 2 + 5 files changed, 508 insertions(+), 2 deletions(-) create mode 100644 lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 create mode 100644 lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 diff --git a/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 new file mode 100644 index 000000000..5321bdb3e --- /dev/null +++ b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 @@ -0,0 +1,170 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +! +! NOTE: Currently only V07A IMERG Final Run data are supported +module IMERG_monthly_dataMod + + ! Defaults + implicit none + private + + ! Public routines + public :: IMERG_monthly_datainit + + ! Public types + public :: imergmonthlydata + + type, public :: imergmonthlydatadec + character*100 :: odir + character*10 :: imergver, imergprd + real :: datares + real, allocatable :: rlat(:) + real, allocatable :: rlon(:) + + ! This is only used with upscale averaging + integer, allocatable :: n11(:) + + ! These are only used with budget interpolation + integer, allocatable :: n112(:,:) + integer, allocatable :: n122(:,:) + integer, allocatable :: n212(:,:) + integer, allocatable :: n222(:,:) + real, allocatable :: w112(:,:) + real, allocatable :: w122(:,:) + real, allocatable :: w212(:,:) + real, allocatable :: w222(:,:) + + integer :: nc + integer :: nr + end type imergmonthlydatadec + + type(imergmonthlydatadec), allocatable :: imergmonthlydata(:) + +contains + + subroutine IMERG_monthly_datainit(i) + + ! Imports + use ESMF + use LVT_coreMod, only: LVT_rc, LVT_config, LVT_isAtAFinerResolution + use LVT_logMod, only: LVT_logunit, LVT_verify, LVT_endrun + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: i + + ! Local variables + integer :: status + real :: gridDesci(50) + + ! External routines + external :: conserv_interp_input + external :: upscaleByAveraging_input + + if (.not. allocated(imergmonthlydata)) then + allocate(imergmonthlydata(LVT_rc%nDataStreams)) + endif + + ! Get top level IMERG data directory + call ESMF_ConfigGetAttribute(LVT_Config, imergmonthlydata(i)%odir, & + label='IMERG monthly data directory:', rc=status) + call LVT_verify(status, 'IMERG monthly data directory: not defined') + + ! Get IMERG product + call ESMF_ConfigFindLabel(LVT_config," IMERG monthly product:", & + rc=status) + call LVT_verify(status, 'IMERG monthly product: not defined') + call ESMF_ConfigGetAttribute(LVT_config, & + imergmonthlydata(i)%imergprd, rc=status) + if (imergmonthlydata(i)%imergprd .ne. 'final') then + write(LVT_logunit,*)'[ERR] Invalid IMERG monthly product specified' + write(LVT_logunit,*)"[ERR] Currently only 'final' is supported" + call LVT_endrun() + end if + + ! Get IMERG version + call ESMF_ConfigFindLabel(LVT_config, "IMERG monthly version:", & + rc=status) + call LVT_verify(status, 'IMERG monthly version: not defined') + call ESMF_ConfigGetAttribute(LVT_config, & + imergmonthlydata(i)%imergver, rc=status) + if (imergmonthlydata(i)%imergver .ne. 'V07A') then + write(LVT_logunit,*)'[ERR] Invalid IMERG monthly version specified' + write(LVT_logunit,*)"[ERR] Currently only 'V07A' is supported" + call LVT_endrun() + end if + + ! Allocate arrays on LVT grid + allocate(imergmonthlydata(i)%rlat(LVT_rc%lnc*LVT_rc%lnr)) + allocate(imergmonthlydata(i)%rlon(LVT_rc%lnc*LVT_rc%lnr)) + + ! Set IMERG grid and map projection information. + gridDesci(:) = 0 + gridDesci(1) = 0 ! Lat/lon + gridDesci(2) = 3600 ! Points along latitude circle + gridDesci(3) = 1800 ! Points along longitude circle + gridDesci(4) = -89.95 ! Latitude of first grid point + gridDesci(5) = -179.95 ! Longitude of first grid point + gridDesci(6) = 128 + gridDesci(7) = 89.95 ! Latitude of last grid point + gridDesci(8) = 179.95 ! Longitude of last grid point + gridDesci(9) = 0.1 ! Longitudinal direction increment + gridDesci(10) = 0.1 ! Latitude direction increment + gridDesci(20) = 64 + + ! Set up interpolation data + imergmonthlydata(i)%datares = 0.1 + imergmonthlydata(i)%nc = 3600 + imergmonthlydata(i)%nr = 1800 + + ! Use budget-bilinear interpolation if IMERG resolution (0.1 deg) + ! is coarser than the analysis grid. Use upscale averaging if + ! IMERG is finer than the analysis grid. + if (LVT_isAtAFinerResolution(imergmonthlydata(i)%datares)) then + + ! Used only with budget interpolation + allocate(imergmonthlydata(i)%n112(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%n122(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%n212(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%n222(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%w112(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%w122(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%w212(LVT_rc%lnc*LVT_rc%lnr,25)) + allocate(imergmonthlydata(i)%w222(LVT_rc%lnc*LVT_rc%lnr,25)) + imergmonthlydata(i)%n112 = 0 + imergmonthlydata(i)%n122 = 0 + imergmonthlydata(i)%n212 = 0 + imergmonthlydata(i)%n222 = 0 + imergmonthlydata(i)%w112 = 0 + imergmonthlydata(i)%w122 = 0 + imergmonthlydata(i)%w212 = 0 + imergmonthlydata(i)%w222 = 0 + call conserv_interp_input(gridDesci, LVT_rc%gridDesc, & + LVT_rc%lnc*LVT_rc%lnr, & + imergmonthlydata(i)%rlat, imergmonthlydata(i)%rlon, & + imergmonthlydata(i)%n112, imergmonthlydata(i)%n122, & + imergmonthlydata(i)%n212, imergmonthlydata(i)%n222, & + imergmonthlydata(i)%w112, imergmonthlydata(i)%w122, & + imergmonthlydata(i)%w212, imergmonthlydata(i)%w222) + else + + ! Used only with upscale averaging + allocate(imergmonthlydata(i)%n11(imergmonthlydata(i)%nc * & + imergmonthlydata(i)%nr)) + imergmonthlydata(i)%n11 = 0 + call upscaleByAveraging_input(gridDesci, LVT_rc%gridDesc,& + imergmonthlydata(i)%nc*imergmonthlydata(i)%nr, & + LVT_rc%lnc*LVT_rc%lnr, & + imergmonthlydata(i)%n11) + end if + end subroutine IMERG_monthly_datainit +end module IMERG_monthly_dataMod diff --git a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 new file mode 100644 index 000000000..1ee98dd7b --- /dev/null +++ b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 @@ -0,0 +1,327 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.4 +! +! Copyright (c) 2022 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- + +#include "LVT_misc.h" + +!NOTE: Currently only V07A IMERG Final Run monthly data are supported. +subroutine readIMERGmonthlydata(source) + + ! Imports + use ESMF + use IMERG_monthly_dataMod, only: imergmonthlydata + use LVT_coreMod, only: LVT_rc, LVT_isAtAFinerResolution + use LVT_histDataMod, only: LVT_logSingleDataStreamVar, & + LVT_MOC_totalprecip + use LVT_logMod, only: LVT_verify, LVT_logunit + use LVT_timeMgrMod, only: LVT_calendar + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: source + + ! Local variables + character*255 :: filename + logical :: file_exists + real :: prcp_in(imergmonthlydata(source)%nc, & + imergmonthlydata(source)%nr) + real :: prcp_in1(imergmonthlydata(source)%nc * & + imergmonthlydata(source)%nr) + logical*1 :: lb(imergmonthlydata(source)%nc * & + imergmonthlydata(source)%nr) + logical*1 :: lo(LVT_rc%lnc*LVT_rc%lnr) + real :: prcp(LVT_rc%lnc*LVT_rc%lnr) + real :: prcp_final(LVT_rc%lnc, LVT_rc%lnr) + integer :: t, c, r + integer :: iret, ireaderr + real :: currTime + logical :: alarmCheck + integer :: yr1, mo1, da1, hr1, mn1, ss1 + integer :: yr2, mo2, da2, hr2, mn2, ss2 + type(ESMF_Time) :: time1 + type(ESMF_Time) :: time2 + type(ESMF_TimeInterval) :: lis_ts + integer :: status + integer :: days_in_month + + ! External routines + external :: create_IMERG_monthly_filename + external :: read_imergmonthly_hdf + external :: conserv_interp + external :: upscaleByAveraging + + ! Initialize variables + prcp(:) = LVT_rc%udef + prcp_final(:,:) = LVT_rc%udef + currTime = float(LVT_rc%dhr(source))*3600 + & + 60*LVT_rc%dmn(source) + LVT_rc%dss(source) + + ! Read IMERG at beginning of the month + alarmCheck = .false. + if (LVT_rc%dda(source) == 1 .and. & + LVT_rc%dhr(source) == 0 .and. & + LVT_rc%dmn(source) == 0 .and. & + LVT_rc%dss(source) == 0) alarmCheck = .true. + + yr1 = LVT_rc%dyr(source) + mo1 = LVT_rc%dmo(source) + da1 = LVT_rc%dda(source) + hr1 = LVT_rc%dhr(source) + mn1 = LVT_rc%dmn(source) + ss1 = 0 + call ESMF_TimeSet(time1,yy=yr1, mm=mo1, dd=da1, & + h=hr1,m=mn1,s=ss1,calendar=LVT_calendar,rc=status) + call LVT_verify(status) + + ! Use previous month file. + call ESMF_TimeIntervalSet(lis_ts, mm=1, calendar=LVT_calendar, & + rc=status) + call LVT_verify(status) + time2 = time1 - lis_ts + call ESMF_TimeGet(time2, yy=yr2, mm=mo2, dd=da2, & + h=hr2, m=mn2, s=ss2, calendar=LVT_calendar, & + rc=status) + call LVT_verify(status) + + if (alarmCheck) then + call create_IMERG_monthly_filename(source, yr1, mo1, filename) + inquire(file=trim(filename), exist=file_exists) + + if (file_exists) then + write(LVT_logunit,*) '[INFO] Reading IMERG data ',trim(filename) + call read_imergmonthly_hdf(filename, & + imergmonthlydata(source)%nc, & + imergmonthlydata(source)%nr, prcp_in, ireaderr) + if (ireaderr .eq. 0) then + + ! Use budget-bilinear interpolation if IMERG data are at + ! coarser resolution than the analysis grid; otherwise, use + ! upscale averaging. + prcp_in1(:) = 0 + lb(:) = .false. + t = 1 + do r = 1, imergmonthlydata(source)%nr + do c = 1,imergmonthlydata(source)%nc + prcp_in1(t) = prcp_in(c,r) + if (prcp_in1(t) .ge. 0) then + lb(t) = .true. + end if + t = t + 1 + end do ! c + end do ! r + + if (LVT_isAtAFinerResolution( & + imergmonthlydata(source)%datares)) then + call conserv_interp(LVT_rc%gridDesc, lb, prcp_in1, & + lo, prcp, & + (imergmonthlydata(source)%nc * & + imergmonthlydata(source)%nr), & + (LVT_rc%lnc*LVT_rc%lnr), & + imergmonthlydata(source)%rlat, & + imergmonthlydata(source)%rlon, & + imergmonthlydata(source)%w112, & + imergmonthlydata(source)%w122, & + imergmonthlydata(source)%w212, & + imergmonthlydata(source)%w222, & + imergmonthlydata(source)%n112, & + imergmonthlydata(source)%n122, & + imergmonthlydata(source)%n212, & + imergmonthlydata(source)%n222, & + LVT_rc%udef, iret) + else + call upscaleByAveraging( & + (imergmonthlydata(source)%nc * & + imergmonthlydata(source)%nr), & + (LVT_rc%lnc*LVT_rc%lnr), LVT_rc%udef, & + imergmonthlydata(source)%n11, lb, & + prcp_in1, lo, prcp) + endif + write(LVT_logunit,*) '[INFO] Finished processing ', & + trim(filename) + else + write(LVT_logunit,*) '[ERR] Read error with IMERG file ', & + trim(filename) + prcp = LVT_rc%udef + endif + else + write(LVT_logunit,*) '[ERR] Missing IMERG file ', trim(filename) + prcp = LVT_rc%udef + end if ! file_exists + + do r = 1, LVT_rc%lnr + do c = 1, LVT_rc%lnc + prcp_final(c,r) = prcp(c+(r-1)*LVT_rc%lnc) + end do ! c + end do ! r + end if ! alarmCheck + + ! Convert mm/hr to kg/m2s. + do r = 1, LVT_rc%lnr + do c = 1, LVT_rc%lnc + if (prcp_final(c,r) .ge. 0) then + prcp_final(c,r) = prcp_final(c,r) / 3600. + else + prcp_final(c,r) = LVT_rc%udef + end if + end do ! c + end do ! r + call LVT_logSingleDataStreamVar(LVT_MOC_totalprecip, source, & + prcp_final, vlevel=1, units='kg/m2s') + + ! Now convert from kg/m2s to kg/m2. Need to calculate length of + ! month in seconds. + lis_ts = time1 - time2 + call ESMF_TimeIntervalGet(lis_ts, d=days_in_month, rc=status) + call LVT_verify(status) + write(LVT_logunit,*)'EMK: days_in_month = ', days_in_month + do r = 1, LVT_rc%lnr + do c = 1, LVT_rc%lnc + if (prcp_final(c,r) .ge. 0) then + prcp_final(c,r) = & + prcp_final(c,r) * days_in_month * 86400 ! kg/m2 + else + prcp_final(c,r) = LVT_rc%udef + endif + enddo ! c + enddo ! r + call LVT_logSingleDataStreamVar(LVT_MOC_totalprecip, source, & + prcp_final, vlevel=1, units='kg/m2') + +end subroutine readIMERGmonthlydata + +subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) + + ! Imports + use LVT_logMod, only: LVT_logunit + +#if (defined USE_HDF5) + use HDF5 +#endif + + ! Defaults + implicit none + + ! Arguments + character(len=*), intent(in) :: filename + integer, intent(in) :: col, row + integer, intent(out) :: ireaderr + real, intent(out) :: precipout(col,row) + + ! Local variables + integer :: xsize, ysize + character(len=40) :: dsetname='/Grid/precipitation' + real :: precipin(row,col) + integer :: istatus +#if (defined USE_HDF5) + integer(HSIZE_T), dimension(2) :: dims + integer(HID_T) :: fileid, dsetid +#endif + +#if (defined USE_HDF5) + xsize = col + ysize = row + dims(1) = xsize + dims(2) = ysize + + ireaderr = 0 + + ! Open Fortran interface + call h5open_f(istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error opening HDF5 fortran interface' + ireaderr = istatus + return + end if + + ! Open HDF5 file + call h5fopen_f(filename, H5F_ACC_RDONLY_F, fileid, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error opening IMERG file', trim(filename) + ireaderr = istatus + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Open dataset + call h5dopen_f(fileid, dsetname, dsetid, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error opening IMERG dataset', trim(dsetname) + ireaderr = istatus + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Read dataset + call h5dread_f(dsetid, H5T_NATIVE_REAL, precipin, dims, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error reading IMERG dataset', trim(dsetname) + ireaderr = istatus + call h5dclose_f(dsetid, istatus) ! Close dataset + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Put the real(1:,1:) on the precipout(0:,0:) + ! precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) + precipout(1:xsize,1:ysize) = transpose(precipin) + + ! Clean up. Since the data have already been copied, we will assume + ! any HDF5 errors from this point will have no impact on the data, and + ! therefore we will ignore the status codes. + call h5dclose_f(dsetid, istatus) ! Close HDF5 dataset + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + +#endif + +end subroutine read_imergmonthly_hdf + +subroutine create_IMERG_monthly_filename(source, yr, mo, filename) + + ! Imports + use IMERG_monthly_dataMod, only: imergmonthlydata + use LVT_logMod, only: LVT_logunit, LVT_endrun + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: source, yr, mo + character(len=*), intent(out) :: filename + + ! Local variables + character*4 :: cyr + character*2 :: cmo + character*100 :: fstem, fext + character*255 :: odir + character*4 :: imVer + + write(cyr, '(I4.4)') yr + write(cmo, '(I2.2)') mo + odir = trim(imergmonthlydata(source)%odir) + imVer = imergmonthlydata(source)%imergver + + ! FIXME: Add support for Early and Late Runs + if (imergmonthlydata(source)%imergprd == 'final') then + fstem = '/3B-MO.MS.MRG.3IMERG.' + fext = '.HDF5' + else + write(LVT_logunit,*) "[ERR] Invalid IMERG product option was chosen." + write(LVT_logunit,*) "[ERR] Please choose either 'final'." + call LVT_endrun() + endif + + filename = trim(odir) // "/" // cyr // cmo // trim(fstem) // & + cyr // cmo // "01-S000000-E235959." // cmo // trim(imVer) // fext + +end subroutine create_IMERG_monthly_filename diff --git a/lvt/make/Filepath b/lvt/make/Filepath index d0034d33b..a1e42cc42 100644 --- a/lvt/make/Filepath +++ b/lvt/make/Filepath @@ -1 +1 @@ -dirs := . ../main ../core ../metrics ../plugins ../interp ../lib/bil ../domains/UTM ../domains/lambert ../domains/latlon ../datastreams/template ../datastreams/LISout ../datastreams/LISDAobs ../datastreams/ISCCP_Tskin ../datastreams/CEOP ../datastreams/SCAN ../datastreams/SCANGMAO ../datastreams/NASMD ../datastreams/GHCN ../datastreams/SNOTEL ../datastreams/SURFRAD ../datastreams/WGPBMR ../datastreams/LSWG_Tb ../datastreams/FMI_SWE ../datastreams/FMI_SNWD ../datastreams/CMC_SNWD ../datastreams/SNODAS ../datastreams/NASA_AMSRE_sm ../datastreams/LPRM_AMSRE_sm ../datastreams/AMMA ../datastreams/Ameriflux ../datastreams/ARM ../datastreams/SMOSREX ../datastreams/AGRMET ../datastreams/GlobSnow ../datastreams/SNODEPmetobs ../datastreams/SNODEP ../datastreams/MOD10A1 ../datastreams/MODSCAG ../datastreams/MOD10A1V6 ../datastreams/ANSA_SNWD ../datastreams/ANSA_SWE ../datastreams/CPC_PRCP ../datastreams/USGS_streamflow_gridded ../datastreams/USGS_streamflow ../datastreams/Natural_streamflow ../datastreams/ISMN ../datastreams/FLUXNETmte ../datastreams/FLUXNET2015 ../datastreams/FLUXNET2015_NC ../datastreams/MOD16A2 ../datastreams/UWET ../datastreams/ARSsm ../datastreams/NLDAS2 ../datastreams/ALEXI ../datastreams/ALEXIesi ../datastreams/GRACE ../datastreams/simGRACE ../datastreams/USGS_GWwell ../datastreams/PBOH2O ../datastreams/SMOS_L2sm ../datastreams/SMOS_NESDIS ../datastreams/SMOS_L1TB ../datastreams/SMOS_CATDS_L3sm ../datastreams/GCOMW_AMSR2L3sm ../datastreams/GCOMW_AMSR2L3snd ../datastreams/SMOPS ../datastreams/MODIS_LST ../datastreams/GLERL_HydroData ../datastreams/JULESdata ../datastreams/JULES2Ddata ../datastreams/ESACCI_sm ../datastreams/GIMMS_AVHRR_NDVI ../datastreams/GIMMS_MODIS_NDVI ../datastreams/GLDAS1 ../datastreams/GLDAS2 ../datastreams/MERRA2 ../datastreams/MERRA2asm ../datastreams/MERRA-Land ../datastreams/SSEBop ../datastreams/GRDC ../datastreams/GOES_LST ../datastreams/ERAinterimLand ../datastreams/SMAPsm ../datastreams/SMAPvod ../datastreams/LPRMvod ../datastreams/SMAPvwc ../datastreams/SMAP_L3TB ../datastreams/SMAPTB ../datastreams/GOME2_SIF ../datastreams/LVTbenchmarkOUT ../datastreams/LIS6out ../datastreams/LISDAdiag ../datastreams/Daymet ../datastreams/CMORPH ../datastreams/CHIRPSv2 ../datastreams/3B42V7 ../datastreams/USCRNsm ../datastreams/GLEAM ../datastreams/USDM ../datastreams/LVTpercentile ../datastreams/IMD_PRCP ../datastreams/APHRO_PRCP ../datastreams/GLASSlai ../datastreams/MODISsportLAI ../datastreams/FLUXCOM ../datastreams/HAR ../datastreams/OCO2_SIF ../datastreams/ECMWFforc ../datastreams/GDASforc ../datastreams/ASO_SWE ../runmodes/DataComp ../runmodes/557post ../runmodes/LISpost ../runmodes/DAstats ../runmodes/optUE ../runmodes/Benchmarking ../runmodes/USAFSIpost ../training/LinearRegression/ ../datastreams/GLASSalbedo ../datastreams/IMERG ../datastreams/UA_SNOW ../datastreams/OzFlux ../datastreams/jasmin ../datastreams/MCD15A2H ../datastreams/ERA5 ../datastreams/FluxSat_GPP ../datastreams/THySM/ ../datastreams/GRUNrunoff ../datastreams/UASMAP/ ../datastreams/COAMPSout/ ../datastreams/SMAP_E_OPL/ +dirs := . ../main ../core ../metrics ../plugins ../interp ../lib/bil ../domains/UTM ../domains/lambert ../domains/latlon ../datastreams/template ../datastreams/LISout ../datastreams/LISDAobs ../datastreams/ISCCP_Tskin ../datastreams/CEOP ../datastreams/SCAN ../datastreams/SCANGMAO ../datastreams/NASMD ../datastreams/GHCN ../datastreams/SNOTEL ../datastreams/SURFRAD ../datastreams/WGPBMR ../datastreams/LSWG_Tb ../datastreams/FMI_SWE ../datastreams/FMI_SNWD ../datastreams/CMC_SNWD ../datastreams/SNODAS ../datastreams/NASA_AMSRE_sm ../datastreams/LPRM_AMSRE_sm ../datastreams/AMMA ../datastreams/Ameriflux ../datastreams/ARM ../datastreams/SMOSREX ../datastreams/AGRMET ../datastreams/GlobSnow ../datastreams/SNODEPmetobs ../datastreams/SNODEP ../datastreams/MOD10A1 ../datastreams/MODSCAG ../datastreams/MOD10A1V6 ../datastreams/ANSA_SNWD ../datastreams/ANSA_SWE ../datastreams/CPC_PRCP ../datastreams/USGS_streamflow_gridded ../datastreams/USGS_streamflow ../datastreams/Natural_streamflow ../datastreams/ISMN ../datastreams/FLUXNETmte ../datastreams/FLUXNET2015 ../datastreams/FLUXNET2015_NC ../datastreams/MOD16A2 ../datastreams/UWET ../datastreams/ARSsm ../datastreams/NLDAS2 ../datastreams/ALEXI ../datastreams/ALEXIesi ../datastreams/GRACE ../datastreams/simGRACE ../datastreams/USGS_GWwell ../datastreams/PBOH2O ../datastreams/SMOS_L2sm ../datastreams/SMOS_NESDIS ../datastreams/SMOS_L1TB ../datastreams/SMOS_CATDS_L3sm ../datastreams/GCOMW_AMSR2L3sm ../datastreams/GCOMW_AMSR2L3snd ../datastreams/SMOPS ../datastreams/MODIS_LST ../datastreams/GLERL_HydroData ../datastreams/JULESdata ../datastreams/JULES2Ddata ../datastreams/ESACCI_sm ../datastreams/GIMMS_AVHRR_NDVI ../datastreams/GIMMS_MODIS_NDVI ../datastreams/GLDAS1 ../datastreams/GLDAS2 ../datastreams/MERRA2 ../datastreams/MERRA2asm ../datastreams/MERRA-Land ../datastreams/SSEBop ../datastreams/GRDC ../datastreams/GOES_LST ../datastreams/ERAinterimLand ../datastreams/SMAPsm ../datastreams/SMAPvod ../datastreams/LPRMvod ../datastreams/SMAPvwc ../datastreams/SMAP_L3TB ../datastreams/SMAPTB ../datastreams/GOME2_SIF ../datastreams/LVTbenchmarkOUT ../datastreams/LIS6out ../datastreams/LISDAdiag ../datastreams/Daymet ../datastreams/CMORPH ../datastreams/CHIRPSv2 ../datastreams/3B42V7 ../datastreams/USCRNsm ../datastreams/GLEAM ../datastreams/USDM ../datastreams/LVTpercentile ../datastreams/IMD_PRCP ../datastreams/APHRO_PRCP ../datastreams/GLASSlai ../datastreams/MODISsportLAI ../datastreams/FLUXCOM ../datastreams/HAR ../datastreams/OCO2_SIF ../datastreams/ECMWFforc ../datastreams/GDASforc ../datastreams/ASO_SWE ../runmodes/DataComp ../runmodes/557post ../runmodes/LISpost ../runmodes/DAstats ../runmodes/optUE ../runmodes/Benchmarking ../runmodes/USAFSIpost ../training/LinearRegression/ ../datastreams/GLASSalbedo ../datastreams/IMERG ../datastreams/IMERG_monthly ../datastreams/UA_SNOW ../datastreams/OzFlux ../datastreams/jasmin ../datastreams/MCD15A2H ../datastreams/ERA5 ../datastreams/FluxSat_GPP ../datastreams/THySM/ ../datastreams/GRUNrunoff ../datastreams/UASMAP/ ../datastreams/COAMPSout/ ../datastreams/SMAP_E_OPL/ diff --git a/lvt/plugins/LVT_datastream_pluginMod.F90 b/lvt/plugins/LVT_datastream_pluginMod.F90 index 1016c4e7b..9259286b7 100644 --- a/lvt/plugins/LVT_datastream_pluginMod.F90 +++ b/lvt/plugins/LVT_datastream_pluginMod.F90 @@ -172,6 +172,7 @@ subroutine LVT_datastream_plugin use GDASforc_dataMod, only : GDASforc_datainit use ASOSWE_obsMod, only : ASOSWE_obsinit use IMERG_dataMod, only : IMERG_datainit + use IMERG_monthly_dataMod, only : IMERG_monthly_datainit use UASNOW_obsMod, only : UASNOW_obsinit use OzFlux_obsMod, only : OzFlux_obsinit use JASMINsm_obsMod, only : JASMINsm_obsInit @@ -284,6 +285,7 @@ subroutine LVT_datastream_plugin external readGDASforcdata external readASOSWEObs external readIMERGdata + external readIMERGmonthlydata external readUASNOWObs external readOzFluxObs external readJASMINsmobs @@ -700,7 +702,12 @@ subroutine LVT_datastream_plugin readASOSWEObs) call registerobssetup(trim(LVT_IMERGdataId)//char(0), IMERG_datainit) - call registerobsread(trim(LVT_IMERGdataId)//char(0) , readIMERGdata) + call registerobsread(trim(LVT_IMERGdataId)//char(0), readIMERGdata) + + call registerobssetup(trim(LVT_IMERGmonthlydataId)//char(0), & + IMERG_monthly_datainit) + call registerobsread(trim(LVT_IMERGdataId)//char(0), & + readIMERGmonthlydata) call registerobssetup(trim(LVT_UASNOWdataId)//char(0), UASNOW_obsinit) call registerobsread(trim(LVT_UASNOWdataId)//char(0) , readUASNOWObs) diff --git a/lvt/plugins/LVT_pluginIndices.F90 b/lvt/plugins/LVT_pluginIndices.F90 index e188f6197..e596e60eb 100644 --- a/lvt/plugins/LVT_pluginIndices.F90 +++ b/lvt/plugins/LVT_pluginIndices.F90 @@ -262,6 +262,8 @@ module LVT_pluginIndices character*50, public, parameter :: LVT_GDASdataId = "GDAS" character*50, public, parameter :: LVT_ASOSWEdataId = "ASO SWE" character*50, public, parameter :: LVT_IMERGdataId = "GPM IMERG" + character*50, public, parameter :: LVT_IMERGMonthlydataId = & + "GPM IMERG Monthly" character*50, public, parameter :: LVT_UASNOWdataId = "UA SNOW" character*50, public, parameter :: LVT_ozFluxdataId = "OzFlux" character*50, public, parameter :: LVT_JASMINsmobsId = "JASMIN soil moisture" From 741f6c9c50221212f3cdb9bb028d8619f847688f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Sep 2023 16:57:39 -0400 Subject: [PATCH 164/328] First cut at adding NRT bias-correction for GFS/GALWEM precip. Code compiles, but not tested yet. --- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 23 ++- lis/metforcing/usaf/USAF_bratsethMod.F90 | 209 +++++++++++++++++++--- lis/metforcing/usaf/readcrd_agrmet.F90 | 53 +++++- 3 files changed, 256 insertions(+), 29 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index 4a707ac24..ad1f1f809 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -719,6 +719,12 @@ module AGRMET_forcingMod ! EMK Add GFS-to-GALWEM bias correction integer :: back_bias_corr real, allocatable :: pcp_back_bias_ratio(:,:) + ! EMK Add NRT bias correction toward IMERG-Final Run + ! (back_bias_corr == 2) + character(255) :: gfs_nrt_bias_ratio_file + character(255) :: galwem_nrt_bias_ratio_file + real, allocatable :: gfs_nrt_bias_ratio(:,:) + real, allocatable :: galwem_nrt_bias_ratio(:,:) integer :: pcp_back_bias_ratio_month end type agrmet_type_dec @@ -747,7 +753,7 @@ module AGRMET_forcingMod subroutine init_AGRMET(findex) ! !USES: - use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_coreMod, only : LIS_rc use LIS_timeMgrMod, only : LIS_update_timestep use LIS_logMod, only : LIS_logunit, LIS_endrun use LIS_snowMod, only : LIS_snow_setup @@ -827,6 +833,21 @@ subroutine init_AGRMET(findex) integer :: istat1 integer :: ftn + external :: readcrd_agrmet + external :: AGRMET_readmask + external :: AGRMET_readterrain + external :: AGRMET_readpcpcntm + external :: AGRMET_read_sfcalccntm + external :: polarToLatLon + external :: bilinear_interp_input_withgrid + external :: neighbor_interp_input_withgrid + external :: AGRMET_read_pcpclimodata + external :: gfs_reset_interp_input + external :: galwem_reset_interp_input + external :: conserv_interp_input + external :: bilinear_interp_input + external :: upscaleByAveraging_input + allocate(agrmet_struc(LIS_rc%nnest)) call readcrd_agrmet() diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index b6dedf826..3995698ec 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -628,6 +628,8 @@ subroutine USAF_addSSMIObsData(this,imax,jmax,ra_tmp,nest) integer :: count_good_ssmi real, parameter :: FILL = -9999.0 + external :: polarToLatLon + net = "SSMI" platform = "SSMI" sigmaOSqr = agrmet_struc(nest)%bratseth_precip_ssmi_sigma_o_sqr @@ -774,6 +776,10 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) character(len=10) :: yyyymmddhh integer :: c, r + external :: AGRMET_julhr_date10 + external :: MPI_Barrier + external :: sleep + TRACE_ENTER("bratseth_getBackNWP") rc = 0 @@ -801,6 +807,8 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) ! EMK...Fetch bias ratio if requested if (agrmet_struc(nest)%back_bias_corr .eq. 1) then call USAF_pcpBackBiasRatio_s2s(nest, yyyymmddhh) + else if (agrmet_struc(nest)%back_bias_corr .eq. 2) then + call USAF_pcpBackBiasRatio_nrt(nest, yyyymmddhh) end if write(LIS_logunit,*) & @@ -824,6 +832,20 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) ! Use GALWEM Bratseth settings if we have the data if (rc .eq. 0) then pcp_src(k) = 'GALWEM' + + ! Apply bias correction to background field + if (agrmet_struc(nest)%back_bias_corr .eq. 2) then + write(LIS_logunit,*) & + '[INFO] Applying IMERG-based bias correction to GALWEM precip' + do r = 1, LIS_rc%gnr(nest) + do c = 1, LIS_rc%gnc(nest) + fg_data_glb(c,r) = & + fg_data_glb(c,r) * & + agrmet_struc(nest)%galwem_nrt_bias_ratio(c,r) + end do + end do + end if + end if endif @@ -851,9 +873,10 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) end if ! Apply bias correction to background field - if (agrmet_struc(nest)%back_bias_corr .eq. 1) then + if (agrmet_struc(nest)%back_bias_corr .eq. 1 .and. & + rc .eq. 0) then write(LIS_logunit,*) & - '[INFO] Applying GALWEM-based bias correction to GFS precip' + '[INFO] Applying GALWEM-based bias correction to GFS precip' do r = 1, LIS_rc%gnr(nest) do c = 1, LIS_rc%gnc(nest) fg_data_glb(c,r) = & @@ -861,6 +884,19 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) agrmet_struc(nest)%pcp_back_bias_ratio(c,r) end do end do + + else if (agrmet_struc(nest)%back_bias_corr .eq. 2 .and. & + rc .eq. 0) then + ! New IMERG option for NRT + write(LIS_logunit,*) & + '[INFO] Applying IMERG-based bias correction to GFS precip' + do r = 1, LIS_rc%gnr(nest) + do c = 1, LIS_rc%gnc(nest) + fg_data_glb(c,r) = & + fg_data_glb(c,r) * & + agrmet_struc(nest)%gfs_nrt_bias_ratio(c,r) + end do + end do end if ! Use GFS Bratseth settings if we have the data @@ -946,6 +982,8 @@ subroutine USAF_getSSMIObsData(nest,j6hr,use_twelve,precip3,precip6, & integer :: local_diff_grid integer :: ii,jj,kk,count_good_ssmi ! EMK TEST + external :: agrmet_ssmiprec_filename + TRACE_ENTER("bratseth_getSSMI") routine_name = 'USAF_getSSMIObsData' @@ -1135,6 +1173,9 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& logical, external :: is_geo_corrupted real, allocatable :: gest_temp(:,:,:) + external :: agrmet_geoprec_filename + external :: polarToLatLon + TRACE_ENTER("bratseth_getGeopPrcp") net = "GEOPRECIP" platform = "GEOPRECIP" @@ -1546,7 +1587,6 @@ subroutine USAF_analyzePrecip(precipAll,nest,back,hourindex,mrgp,precipOBA) use AGRMET_forcingMod, only: agrmet_struc use LIS_coreMod, only: LIS_rc, LIS_ews_halo_ind, LIS_ewe_halo_ind, & LIS_nss_halo_ind, LIS_nse_halo_ind, LIS_localPet - use LIS_logMod, only: LIS_logunit use USAF_OBAMod, only: OBA, createOBA,assignOBA ! Defaults @@ -1565,8 +1605,6 @@ subroutine USAF_analyzePrecip(precipAll,nest,back,hourindex,mrgp,precipOBA) real, allocatable :: invDataDensities(:) real, allocatable :: sumObsEstimates(:) integer :: npasses - integer :: r - character(len=10) :: new_name,type real :: convergeThresh real :: sigmaBSqr integer :: good_obs @@ -1688,6 +1726,9 @@ subroutine interpBack2ObsPts(this,nest,imax,jmax,back, & integer, external :: get_fieldpos real, parameter :: FILL = MISSING + external :: compute_grid_coord + external :: bilinear_interp + ! See if we have any observations available nobs = this%nobs if (nobs .eq. 0) return @@ -1831,6 +1872,8 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & integer :: imax,jmax logical :: verbose + external :: MPI_Barrier, MPI_ALLREDUCE + verbose = .true. if (present(silent)) then if (silent) verbose = .false. @@ -2055,6 +2098,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& real :: O, A integer :: good_obs + external :: MPI_Barrier, MPI_ALLREDUCE + verbose = .true. if (present(silent)) then if (silent) verbose = .false. @@ -2506,6 +2551,8 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& integer :: r_local, c_local integer :: gindex + external :: MPI_Barrier, MPI_ALLREDUCE + ! Sanity checks if (nobs .eq. 0) return @@ -2765,6 +2812,11 @@ subroutine fldbld_precip_nwp(nest,findex,julhr,src,fc_hr, & integer :: rc2 logical :: first_time + external :: getAVNfilename + external :: AGRMET_getGALWEMfilename + external :: AGRMET_fg2lis_precip + external :: interp_galwem_first_guess + rc = 0 found = .false. @@ -2974,7 +3026,6 @@ subroutine check_grib_file(gribfile,yr1,mo1,da1,hr1,found, & #if (defined USE_GRIBAPI) use grib_api #endif - use LIS_coreMod, only: LIS_masterproc use LIS_logMod, only : LIS_logunit, LIS_abort, LIS_alert, & LIS_verify, LIS_endrun use LIS_mpiMod @@ -3203,6 +3254,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) double precision :: t1, t2 logical :: silent_rejects_local + external :: MPI_Barrier, MPI_Allreduce + ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -3617,6 +3670,8 @@ subroutine USAF_dupQC(this) integer :: ierr logical :: location_issue + external :: MPI_Barrier + nobs = this%nobs if (nobs .eq. 0) then write(LIS_logunit,*)& @@ -4006,6 +4061,8 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) double precision :: t1, t2 logical :: silent_rejects_local + external :: MPI_Barrier + nobs = this%nobs if (nobs .eq. 0) then write(LIS_logunit,*)& @@ -4093,7 +4150,9 @@ end function is_gauge logical function is_stn(net) implicit none character(len=10), intent(in) :: net + character(len=10) :: net_local logical :: answer + net_local = net answer = .true. is_stn = answer end function is_stn @@ -4367,8 +4426,7 @@ end subroutine destroy_hash2d subroutine build_hash2d(this,nest,imax,jmax,hash2d) ! Imports - use LIS_coreMod, only: LIS_rc, LIS_domain, LIS_localPet - use LIS_logMod, only: LIS_logunit + use LIS_coreMod, only: LIS_rc use LIS_mpiMod ! Defaults @@ -4382,26 +4440,21 @@ subroutine build_hash2d(this,nest,imax,jmax,hash2d) type(hash_list), allocatable, intent(out) :: hash2d(:,:) ! Local variables - real :: dlat, dlon, ctrlat, ctrlon integer :: nobs integer, allocatable :: cols(:), rows(:) - integer :: pet, pet_incr - logical :: found - integer :: j,r,c,gindex - integer :: ierr nobs = this%nobs if (nobs .eq. 0) return ! Get the columns and rows of the observations in the LIS grid - call find_LIS_cols_rows(this,nest,cols,rows) + call find_LIS_cols_rows(this, nest, cols, rows) ! Loop through the collected col, row information and add to the ! hash2d table. - call init_hash2d(LIS_rc%gnc(nest),LIS_rc%gnr(nest),hash2d) + call init_hash2d(LIS_rc%gnc(nest), LIS_rc%gnr(nest), hash2d) imax = LIS_rc%gnc(nest) ! Output jmax = LIS_rc%gnr(nest) ! Output - call insert_hash2d_array(imax,jmax,hash2d,nobs,cols,rows) + call insert_hash2d_array(imax, jmax, hash2d, nobs, cols, rows) ! do j = 1,nobs ! c = cols(j) ! if (c .eq. 0) cycle @@ -4786,6 +4839,8 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) integer :: j,r,c,gindex integer :: ierr + external :: MPI_Barrier, MPI_ALLREDUCE + nobs = this%nobs if (nobs .eq. 0) return @@ -4910,12 +4965,10 @@ end subroutine find_LIS_cols_rows subroutine USAF_waterQC(this,nest,silent_rejects) ! Imports - use LIS_coreMod, only: LIS_rc use LIS_LMLCMod, only: LIS_LMLC use LIS_logMod, only: LIS_logunit use LIS_mpiMod - ! Defaults implicit none @@ -4934,6 +4987,8 @@ subroutine USAF_waterQC(this,nest,silent_rejects) integer :: reject_count logical :: silent_rejects_local + external :: MPI_Barrier + ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -5036,6 +5091,8 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) real :: threshold_local logical :: silent_rejects_local + external :: MPI_Barrier, MPI_ALLREDUCE + ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -5219,6 +5276,8 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) integer :: rglb,cglb integer :: gid + external :: MPI_Barrier, MPI_ALLREDUCE + ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -5440,9 +5499,9 @@ subroutine USAF_analyzeScreen(screenObs,nest,back,sigmaBSqr, & real, allocatable :: invDataDensities(:) real, allocatable :: sumObsEstimates(:) integer :: npasses - character(len=10) :: new_name,type + character(len=10) :: new_name, type real :: convergeThresh - integer :: i,j + integer :: j TRACE_ENTER("bratseth_analyzeScrn") ! Initialize analysis field with the background first guess. This will @@ -5614,6 +5673,8 @@ subroutine USAF_getCMORPHObsData(nest,j6hr,use_twelve, & integer :: ftn, ios integer :: i,j,k + external :: cmorfile_agrmet + TRACE_ENTER("bratseth_getCMORPH") net = "CMORPH" platform = "CMORPH" @@ -6397,14 +6458,15 @@ subroutine USAF_setBratsethScreenStats(src,n) end subroutine USAF_setBratsethScreenStats - ! Read bias ratio for background field + ! Read bias ratio for background field (S2S version, which uses + ! data in the LDT parameter file) subroutine USAF_pcpBackBiasRatio_s2s(n, yyyymmddhh) ! Imports use AGRMET_forcingMod, only: agrmet_struc - use LIS_coreMod, only: LIS_rc, LIS_localPet, & - LIS_ews_halo_ind, LIS_ewe_halo_ind, & - LIS_nss_halo_ind, LIS_nse_halo_ind + use LIS_coreMod, only: LIS_rc!, LIS_localPet, & + !LIS_ews_halo_ind, LIS_ewe_halo_ind, & + !LIS_nss_halo_ind, LIS_nse_halo_ind use LIS_logMod, only: LIS_logunit, LIS_endrun, LIS_verify #if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) use netcdf @@ -6468,4 +6530,101 @@ subroutine USAF_pcpBackBiasRatio_s2s(n, yyyymmddhh) #endif end subroutine USAF_pcpBackBiasRatio_s2s -end module USAF_bratsethMod + + ! Read bias ratio for background field (NRT version, which uses + ! data in standalone netCDF file) + subroutine USAF_pcpBackBiasRatio_nrt(n, yyyymmddhh) + + ! Imports + use AGRMET_forcingMod, only: agrmet_struc + use LIS_coreMod, only: LIS_rc!, LIS_localPet, & + !LIS_ews_halo_ind, LIS_ewe_halo_ind, & + !LIS_nss_halo_ind, LIS_nse_halo_ind + + use LIS_logMod, only: LIS_logunit, LIS_endrun, LIS_verify +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + use netcdf +#endif + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + character(len=10), intent(in) :: yyyymmddhh + + ! Locals + integer :: imonth + logical :: file_exists + integer :: ncid, ppt_ratio_Id + +#if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) + + read(yyyymmddhh(5:6),'(i2.2)') imonth + + ! Accumulations ending at 00Z first of month are part of the + ! *previous* month. So decrement imonth by one in that situation, + ! and reset to 12 (December) at the year change. + if (agrmet_struc(n)%pcp_back_bias_ratio_month .ne. 0) then + if (yyyymmddhh(9:10) .eq. '00' .and. & + yyyymmddhh(7:8) .eq. '01') then + imonth = imonth - 1 + if (imonth .eq. 0) then + imonth = 12 + end if + end if + end if + if (imonth .eq. agrmet_struc(n)%pcp_back_bias_ratio_month .and. & + agrmet_struc(n)%pcp_back_bias_ratio_month .ne. 0) return + + agrmet_struc(n)%pcp_back_bias_ratio_month = imonth + + ! First, update the GFS ratios + inquire(file=agrmet_struc(n)%gfs_nrt_bias_ratio_file, & + exist=file_exists) + if (.not. file_exists) then + write(LIS_logunit,*) '[ERR] Cannot find ', & + trim(agrmet_struc(n)%gfs_nrt_bias_ratio_file) + call LIS_endrun() + end if + call LIS_verify( & + nf90_open(path=agrmet_struc(n)%gfs_nrt_bias_ratio_file, & + mode=NF90_NOWRITE, ncid=ncid), & + 'Error in nf90_open in USAF_pcpBackBiasRatio_nrt') + call LIS_verify(nf90_inq_varid(ncid, "biasRatio", ppt_ratio_Id), & + 'biasRatio field not found in bias file') + call LIS_verify(nf90_get_var(ncid, ppt_ratio_Id, & + agrmet_struc(n)%gfs_nrt_bias_ratio, & + start=(/1,1,imonth/), & + count=(/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)), & + 'n90_get_var failed for biasRatio in LIS param file') + call LIS_verify(nf90_close(ncid),& + 'nf90_close failed in USAF_pcpBackBiasRatio_nrt') + + ! Repeat for GALWEM ratios + inquire(file=agrmet_struc(n)%galwem_nrt_bias_ratio_file, & + exist=file_exists) + if (.not. file_exists) then + write(LIS_logunit,*) '[ERR] Cannot find ', & + trim(agrmet_struc(n)%galwem_nrt_bias_ratio_file) + call LIS_endrun() + end if + call LIS_verify( & + nf90_open(path=agrmet_struc(n)%galwem_nrt_bias_ratio_file, & + mode=NF90_NOWRITE, ncid=ncid), & + 'Error in nf90_open in USAF_pcpBackBiasRatio_nrt') + call LIS_verify(nf90_inq_varid(ncid, "biasRatio", ppt_ratio_Id), & + 'biasRatio field not found in bias file') + call LIS_verify(nf90_get_var(ncid, ppt_ratio_Id, & + agrmet_struc(n)%galwem_nrt_bias_ratio, & + start=(/1,1,imonth/), & + count=(/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)),& + 'n90_get_var failed for biasRatio in LIS param file') + call LIS_verify(nf90_close(ncid),& + 'nf90_close failed in USAF_pcpBackBiasRatio_nrt') + +#endif + + end subroutine USAF_pcpBackBiasRatio_nrt + + end module USAF_bratsethMod diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 05452a3a4..819905484 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -62,6 +62,10 @@ subroutine readcrd_agrmet() integer, external :: LIS_create_subdirs integer :: tmp_imerg_plp_thresh integer :: ierr + logical :: use_nrt_bias_files ! EMK + + external :: MPI_Barrier + external :: sleep call ESMF_ConfigFindLabel(LIS_config,"AGRMET forcing directory:",rc=rc) do n=1,LIS_rc%nnest @@ -1091,16 +1095,59 @@ subroutine readcrd_agrmet() call LIS_verify(rc, & "[ERR] AGRMET PPT Background bias correction option: not specified in config file") if (agrmet_struc(n)%back_bias_corr .lt. 0 .or. & - agrmet_struc(n)%back_bias_corr .gt. 1) then + agrmet_struc(n)%back_bias_corr .gt. 2) then call LIS_verify(rc, & - "[ERR] AGRMET PPT Background bias correction option: bad value in config file, set 0 or 1") + "[ERR] AGRMET PPT Background bias correction option: bad value in config file, set 0, 1, or 2") end if if (agrmet_struc(n)%back_bias_corr .eq. 1) then allocate(agrmet_struc(n)%pcp_back_bias_ratio(LIS_rc%gnc(n),LIS_rc%gnr(n))) agrmet_struc(n)%pcp_back_bias_ratio = 1. agrmet_struc(n)%pcp_back_bias_ratio_month = 0 + else if (agrmet_struc(n)%back_bias_corr .eq. 2) then + + allocate(agrmet_struc(n)%gfs_nrt_bias_ratio( & + LIS_rc%gnc(n),LIS_rc%gnr(n))) + allocate(agrmet_struc(n)%galwem_nrt_bias_ratio( & + LIS_rc%gnc(n),LIS_rc%gnr(n))) + agrmet_struc(n)%gfs_nrt_bias_ratio = 1. + agrmet_struc(n)%galwem_nrt_bias_ratio = 1. + agrmet_struc(n)%pcp_back_bias_ratio_month = 0 end if - enddo ! n + end do + + ! EMK Add support for NRT bias files for GFS and GALWEM + use_nrt_bias_files = .false. + do n = 1, LIS_rc%nnest + if (agrmet_struc(n)%back_bias_corr .eq. 2) then + use_nrt_bias_files = .true. + exit + end if + end do + + if (use_nrt_bias_files) then + call ESMF_ConfigFindLabel(LIS_config, & + "AGRMET PPT GFS NRT bias file:", rc=rc) + call LIS_verify(rc, & + "[ERR] AGRMET PPT GFS NRT bias file: not specified in config file") + + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + agrmet_struc(n)%gfs_nrt_bias_ratio_file, rc=rc) + call LIS_verify(rc, & + "[ERR] AGRMET PPT GFS NRT bias file: not specified in config file") + end do + + call ESMF_ConfigFindLabel(LIS_config, & + "AGRMET PPT GALWEM NRT bias file:", rc=rc) + call LIS_verify(rc, & + "[ERR] AGRMET PPT GALWEM NRT bias file: not specified in config file") + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + agrmet_struc(n)%galwem_nrt_bias_ratio_file, rc=rc) + call LIS_verify(rc, & + "[ERR] AGRMET PPT GALWEM NRT bias file: not specified in config file") + end do + end if do n=1,LIS_rc%nnest agrmet_struc(n)%radProcessInterval = 1 From 0bc46527bedcf87d7e740b0b2868fc67749cec8c Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 18 Sep 2023 14:06:51 -0400 Subject: [PATCH 165/328] Rework handling of PETSc library in Config.pl This is for compiling LIS with PETSc enabled into AppImage. --- lis/arch/Config.pl | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index f4fc2dfcd..bfc145bf0 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -1001,6 +1001,12 @@ $lib_flags= $lib_flags." -lmfhdf -ldf ".$libjpeg." -lz"; $lib_paths= $lib_paths." -L\$(LIB_HDF4)" } + +if($use_petsc == 1){ + $fflags = $fflags." -I\$(INC_PETSC)"; + $ldflags = $ldflags." -L\$(LIB_PETSC) -lpetsc -lm -ldl"; +} + if($use_hdf5 == 1){ $fflags77 = $fflags77." -I\$(INC_HDF5)"; $fflags = $fflags." -I\$(INC_HDF5)"; @@ -1034,11 +1040,6 @@ $lib_paths= $lib_paths." -L\$(LIB_MINPACK)"; } -if($use_petsc == 1){ - $fflags = $fflags." -I\$(INC_PETSC)"; - $ldflags = $ldflags." -L\$(LIB_PETSC) -lpetsc -lm"; -} - if($use_lapack == 1){ $ldflags = $ldflags." -L\$(LIB_LAPACK) -lmkl_rt"; $lib_flags= $lib_flags." -lmkl_rt"; From 8d8a24e02d12b1481b382f08ccbb450973d28b95 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 18 Sep 2023 14:22:14 -0400 Subject: [PATCH 166/328] Add PETSc library support to GitHub Actions scripts This is for compiling LIS with the PETSc library into an AppImage. --- .github/scripts/appimage/compile_lisf | 5 ++--- .github/scripts/appimage/lisf.env | 11 ++++++++++- .github/scripts/appimage/prep_appdir | 2 +- 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/.github/scripts/appimage/compile_lisf b/.github/scripts/appimage/compile_lisf index fa0999f4a..e67a9d9fc 100755 --- a/.github/scripts/appimage/compile_lisf +++ b/.github/scripts/appimage/compile_lisf @@ -52,12 +52,11 @@ printf '%s\n' "0" "2" "2" "2" "4" "1" "1" "1" "1" "1" "1" "1" "1" "1" | ./config # Use MINPACK? (1-yes, 0-no, default=0): 0 # Use LIS-CRTM? (1-yes, 0-no, default=0): 0 # Use LIS-CMEM? (1-yes, 0-no, default=0): 0 -# Use LIS-LAPACK? (1-yes, 0-no, default=0): 0 -# Use LIS-MKL-LAPACK? (1-yes, 0-no, default=0): 0 +# Use LIS-LAPACK? (0-no, 1-mkl, 2-lapack/blas, 3-lapack/refblas, default=0): 0 # Use PETSc? (1-yes, 0-no, default=0): 0 cd ../lis -printf '%s\n' "1" "2" "2" "2" "0" "1" "4" "1" "1" "1" "1" "1" "1" "0" "0" "0" "0" "0" "0" | ./configure +printf '%s\n' "1" "2" "2" "2" "0" "1" "4" "1" "1" "1" "1" "1" "1" "0" "0" "0" "0" "0" | ./configure ./compile -j 2 # diff --git a/.github/scripts/appimage/lisf.env b/.github/scripts/appimage/lisf.env index 9b6368e32..dfcecec32 100644 --- a/.github/scripts/appimage/lisf.env +++ b/.github/scripts/appimage/lisf.env @@ -11,6 +11,8 @@ LISF_LIBS_GDAL=/home/workdir/lib/gdal/3.5.2_gnu-11.2.0 LISF_LIBS_FORTRANGIS=/home/workdir/lib/fortrangis/2.6-6_gnu-11.2.0 LISF_LIBS_LIBGEOTIFF=/home/workdir/lib/geotiff/1.7.0_gnu-11.2.0 LISF_LIBS_TIFF=/home/workdir/lib/tiff/4.0.9_gnu-11.2.0 +LISF_LIBS_LAPACK=/home/workdir/lib/blaslapack/3.11.0_gnu-11.2.0 +LISF_LIBS_PETSC=/home/workdir/lib/petsc/3.16.1_gnu-11.2.0 LISF_LIBS_PATH="$LISF_LIBS_MPICH/lib" LISF_LIBS_PATH+=":$LISF_LIBS_ECCODES/lib" @@ -23,6 +25,8 @@ LISF_LIBS_PATH+=":$LISF_LIBS_GDAL/lib" LISF_LIBS_PATH+=":$LISF_LIBS_LIBGEOTIFF/lib" LISF_LIBS_PATH+=":$LISF_LIBS_OPENJPEG/lib" LISF_LIBS_PATH+=":$LISF_LIBS_TIFF/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_LAPACK/lib" +LISF_LIBS_PATH+=":$LISF_LIBS_PETSC/lib" export LISF_LIBS_PATH def_lis_jpeg="" @@ -38,7 +42,8 @@ def_lis_minpack="" def_lis_crtm="" def_lis_crtm_prof="" def_lis_cmem="" -def_lis_lapack="" +def_lis_lapack=$LISF_LIBS_LAPACK/lib +def_lis_petsc=$LISF_LIBS_PETSC def_lvt_gdal=$LISF_LIBS_GDAL def_lvt_fortrangis=$LISF_LIBS_FORTRANGIS def_ldt_libgeotiff=$LISF_LIBS_LIBGEOTIFF @@ -61,6 +66,7 @@ export LIS_MINPACK=$def_lis_minpack export LIS_CRTM=$def_lis_crtm export LIS_CRTM_PROF=$def_lis_crtm_prof export LIS_CMEM=$def_lis_cmem +export LIS_PETSC=$def_lis_petsc export LIS_LAPACK=$def_lis_lapack export LDT_ARCH=linux_gfortran @@ -112,6 +118,7 @@ unset def_lis_crtm unset def_lis_crtm_prof unset def_lis_cmem unset def_lis_lapack +unset def_lis_petsc unset def_lvt_gdal unset def_lvt_fortrangis unset def_ldt_libgeotiff @@ -128,3 +135,5 @@ unset LISF_LIBS_GDAL unset LISF_LIBS_FORTRANGIS unset LISF_LIBS_LIBGEOTIFF unset LISF_LIBS_TIFF +unset LISF_LIBS_LAPACK +unset LISF_LIBS_PETSC diff --git a/.github/scripts/appimage/prep_appdir b/.github/scripts/appimage/prep_appdir index d2b7efcf1..04deec23a 100755 --- a/.github/scripts/appimage/prep_appdir +++ b/.github/scripts/appimage/prep_appdir @@ -29,7 +29,7 @@ rm -rf mpich cd /home/workdir/LISF.AppDir patchelf --clear-symbol-version expf --clear-symbol-version logf --clear-symbol-version powf usr/bin/LDT -patchelf --clear-symbol-version expf --clear-symbol-version glob --clear-symbol-version logf --clear-symbol-version powf usr/bin/LIS +patchelf --clear-symbol-version expf --clear-symbol-version glob --clear-symbol-version logf --clear-symbol-version powf --clear-symbol-version lgamma usr/bin/LIS patchelf --clear-symbol-version expf --clear-symbol-version logf --clear-symbol-version powf usr/bin/LVT patchelf --clear-symbol-version powf usr/lib/hdf5/1.12.0_gnu-11.2.0/lib/libhdf5.so patchelf --clear-symbol-version logf usr/lib/esmf/8.1.1_gnu-11.2.0_mpich-3.4/lib/libO/Linux.gfortran.64.mpich3.default/libesmf.so From 6e4b714ae36aa5c7850b1b531d9c36d4bf75888a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 20 Sep 2023 10:39:31 -0400 Subject: [PATCH 167/328] Attempt at remapping IMERG-FR monthly data. This version uses the precipitationQualityIndex field to screen out apparent data voids (i.e., areas w/o gauge corrections). HOWEVER, a better method may be to use the gaugeRelativeWeighting field, which indicates the Kalman weight given to the GPCC gauge data in the IMERG-Final Run. More work and testing is anticipated. --- .../IMERG_monthly/IMERG_monthly_dataMod.F90 | 2 +- .../IMERG_monthly/readIMERGmonthlydata.F90 | 91 ++++++++++++++++--- lvt/plugins/LVT_datastream_pluginMod.F90 | 2 +- 3 files changed, 80 insertions(+), 15 deletions(-) diff --git a/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 index 5321bdb3e..9a98a1c91 100644 --- a/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 +++ b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 @@ -80,7 +80,7 @@ subroutine IMERG_monthly_datainit(i) call LVT_verify(status, 'IMERG monthly data directory: not defined') ! Get IMERG product - call ESMF_ConfigFindLabel(LVT_config," IMERG monthly product:", & + call ESMF_ConfigFindLabel(LVT_config,"IMERG monthly product:", & rc=status) call LVT_verify(status, 'IMERG monthly product: not defined') call ESMF_ConfigGetAttribute(LVT_config, & diff --git a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 index 1ee98dd7b..ddadcb844 100644 --- a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 +++ b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 @@ -59,8 +59,8 @@ subroutine readIMERGmonthlydata(source) external :: upscaleByAveraging ! Initialize variables - prcp(:) = LVT_rc%udef - prcp_final(:,:) = LVT_rc%udef + prcp = LVT_rc%udef + prcp_final = LVT_rc%udef currTime = float(LVT_rc%dhr(source))*3600 + & 60*LVT_rc%dmn(source) + LVT_rc%dss(source) @@ -77,8 +77,8 @@ subroutine readIMERGmonthlydata(source) hr1 = LVT_rc%dhr(source) mn1 = LVT_rc%dmn(source) ss1 = 0 - call ESMF_TimeSet(time1,yy=yr1, mm=mo1, dd=da1, & - h=hr1,m=mn1,s=ss1,calendar=LVT_calendar,rc=status) + call ESMF_TimeSet(time1, yy=yr1, mm=mo1, dd=da1, & + h=hr1, m=mn1, s=ss1, calendar=LVT_calendar, rc=status) call LVT_verify(status) ! Use previous month file. @@ -92,7 +92,7 @@ subroutine readIMERGmonthlydata(source) call LVT_verify(status) if (alarmCheck) then - call create_IMERG_monthly_filename(source, yr1, mo1, filename) + call create_IMERG_monthly_filename(source, yr2, mo2, filename) inquire(file=trim(filename), exist=file_exists) if (file_exists) then @@ -105,8 +105,8 @@ subroutine readIMERGmonthlydata(source) ! Use budget-bilinear interpolation if IMERG data are at ! coarser resolution than the analysis grid; otherwise, use ! upscale averaging. - prcp_in1(:) = 0 - lb(:) = .false. + prcp_in1 = LVT_rc%udef + lb = .false. t = 1 do r = 1, imergmonthlydata(source)%nr do c = 1,imergmonthlydata(source)%nc @@ -118,6 +118,12 @@ subroutine readIMERGmonthlydata(source) end do ! c end do ! r + write(LVT_logunit,*)'EMK: maxval(prcp_in1) = ', & + maxval(prcp_in1) + write(LVT_logunit,*)'EMK: minval(prcp_in1) = ', & + minval(prcp_in1) + flush(LVT_logunit) + if (LVT_isAtAFinerResolution( & imergmonthlydata(source)%datares)) then call conserv_interp(LVT_rc%gridDesc, lb, prcp_in1, & @@ -181,10 +187,9 @@ subroutine readIMERGmonthlydata(source) lis_ts = time1 - time2 call ESMF_TimeIntervalGet(lis_ts, d=days_in_month, rc=status) call LVT_verify(status) - write(LVT_logunit,*)'EMK: days_in_month = ', days_in_month do r = 1, LVT_rc%lnr do c = 1, LVT_rc%lnc - if (prcp_final(c,r) .ge. 0) then + if (prcp_final(c,r) >= 0) then prcp_final(c,r) = & prcp_final(c,r) * days_in_month * 86400 ! kg/m2 else @@ -195,11 +200,17 @@ subroutine readIMERGmonthlydata(source) call LVT_logSingleDataStreamVar(LVT_MOC_totalprecip, source, & prcp_final, vlevel=1, units='kg/m2') + write(LVT_logunit,*)'EMK: LVT_rc%udef = ', LVT_rc%udef + write(LVT_logunit,*)'EMK: maxval(precip) = ', maxval(prcp_final) + write(LVT_logunit,*)'EMK: minval(precip) = ', minval(prcp_final) + flush(LVT_logunit) + end subroutine readIMERGmonthlydata subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) ! Imports + use LVT_coreMod, only: LVT_rc use LVT_logMod, only: LVT_logunit #if (defined USE_HDF5) @@ -217,14 +228,21 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) ! Local variables integer :: xsize, ysize - character(len=40) :: dsetname='/Grid/precipitation' + character(len=40) :: dsetname = '/Grid/precipitation' + character(len=40) :: dsetname_qi = '/Grid/precipitationQualityIndex' + real :: qiin(row,col) real :: precipin(row,col) integer :: istatus + integer :: i, j #if (defined USE_HDF5) integer(HSIZE_T), dimension(2) :: dims integer(HID_T) :: fileid, dsetid #endif + qiin = LVT_rc%udef + precipin = LVT_rc%udef + precipout = LVT_rc%udef + #if (defined USE_HDF5) xsize = col ysize = row @@ -250,7 +268,42 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! Open dataset + ! Open quality index dataset + call h5dopen_f(fileid, dsetname_qi, dsetid, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error opening IMERG dataset', & + trim(dsetname_qi) + ireaderr = istatus + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Read quality index dataset + call h5dread_f(dsetid, H5T_NATIVE_REAL, & + qiin, dims, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error reading IMERG dataset', & + trim(dsetname_qi) + ireaderr = istatus + call h5dclose_f(dsetid, istatus) ! Close dataset + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Close quality index dataset + call h5dclose_f(dsetid, istatus) + if (istatus .ne. 0) then + write(LVT_logunit,*) 'Error closing IMERG dataset', & + trim(dsetname_qi) + ireaderr = istatus + call h5fclose_f(fileid, istatus) ! Close HDF5 file + call h5close_f(istatus) ! Close HDF5 interface + return + end if + + ! Open precip dataset call h5dopen_f(fileid, dsetname, dsetid, istatus) if (istatus .ne. 0) then write(LVT_logunit,*) 'Error opening IMERG dataset', trim(dsetname) @@ -271,6 +324,17 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if + ! Flag precipin values where quality index is less then 2.5 (interpreted + ! as less than 2.5 gauges used in analysis). Note that polar regions + ! have values ~2.1. + do j = 1, col + do i = 1, row + if (qiin(i,j) < 2.5) then + precipin(i,j) = LVT_rc%udef + end if + end do + end do + ! Put the real(1:,1:) on the precipout(0:,0:) ! precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) precipout(1:xsize,1:ysize) = transpose(precipin) @@ -321,7 +385,8 @@ subroutine create_IMERG_monthly_filename(source, yr, mo, filename) call LVT_endrun() endif - filename = trim(odir) // "/" // cyr // cmo // trim(fstem) // & - cyr // cmo // "01-S000000-E235959." // cmo // trim(imVer) // fext + filename = trim(odir) // "/" // cyr // trim(fstem) // & + cyr // cmo // "01-S000000-E235959." // cmo // "." // & + trim(imVer) // fext end subroutine create_IMERG_monthly_filename diff --git a/lvt/plugins/LVT_datastream_pluginMod.F90 b/lvt/plugins/LVT_datastream_pluginMod.F90 index 9259286b7..8a5302abc 100644 --- a/lvt/plugins/LVT_datastream_pluginMod.F90 +++ b/lvt/plugins/LVT_datastream_pluginMod.F90 @@ -706,7 +706,7 @@ subroutine LVT_datastream_plugin call registerobssetup(trim(LVT_IMERGmonthlydataId)//char(0), & IMERG_monthly_datainit) - call registerobsread(trim(LVT_IMERGdataId)//char(0), & + call registerobsread(trim(LVT_IMERGmonthlydataId)//char(0), & readIMERGmonthlydata) call registerobssetup(trim(LVT_UASNOWdataId)//char(0), UASNOW_obsinit) From 104b16f35a3a6ed88d55a6b5638e0d0c848660d7 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 20 Sep 2023 15:09:45 -0400 Subject: [PATCH 168/328] Add new custom modulefile lisf_7.5_gnu_11.2.0_impi_2021.4.0 This modulefile is for compiling LISF with GNU 11.2 compilers and Intel MPI. It supports compiling LIS with the PETSc library enabled. --- .../lisf_7.5_gnu_11.2.0_impi_2021.4.0 | 171 ++++++++++++++++++ 1 file changed, 171 insertions(+) create mode 100644 env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 diff --git a/env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 b/env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 new file mode 100644 index 000000000..56a3efae1 --- /dev/null +++ b/env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 @@ -0,0 +1,171 @@ +#%Module1.0################################################################### + +proc ModulesHelp { } { + puts stderr "\t[module-info name] - loads the LISF_7_5_GNU_11_2_0_IMPI_2021_4_0 env" + puts stderr "" + puts stderr "This is for use on NCCS' discover system running SLES 12.3." + puts stderr "" + puts stderr "\tThe following env variables are set:" + puts stderr "\t\tDEV_ENV" + puts stderr "\t\tLIS_ARCH" + puts stderr "\t\tLIS_SPMD" + puts stderr "\t\tLIS_FC" + puts stderr "\t\tLIS_CC" + puts stderr "\t\tLIS_JPEG" + puts stderr "\t\tLIS_OPENJPEG" + puts stderr "\t\tLIS_ECCODES" + puts stderr "\t\tLIS_NETCDF" + puts stderr "\t\tLIS_HDF4" + puts stderr "\t\tLIS_HDFEOS" + puts stderr "\t\tLIS_HDF5" + puts stderr "\t\tLIS_MODESMF" + puts stderr "\t\tLIS_LIBESMF" + puts stderr "\t\tLIS_MINPACK" + puts stderr "\t\tLIS_CRTM" + puts stderr "\t\tLIS_CRTM_PROF" + puts stderr "\t\tLIS_CMEM" + puts stderr "\t\tLIS_LAPACK" + puts stderr "\t\tLIS_PETSC" + puts stderr "\t\tLDT_ARCH" + puts stderr "\t\tLDT_FC" + puts stderr "\t\tLDT_CC" + puts stderr "\t\tLDT_JPEG" + puts stderr "\t\tLDT_OPENJPEG" + puts stderr "\t\tLDT_ECCODES" + puts stderr "\t\tLDT_NETCDF" + puts stderr "\t\tLDT_HDF4" + puts stderr "\t\tLDT_HDFEOS" + puts stderr "\t\tLDT_HDF5" + puts stderr "\t\tLDT_MODESMF" + puts stderr "\t\tLDT_LIBESMF" + puts stderr "\t\tLDT_GDAL" + puts stderr "\t\tLDT_FORTRANGIS" + puts stderr "\t\tLDT_LIBGEOTIFF" + puts stderr "\t\tLVT_ARCH" + puts stderr "\t\tLVT_FC" + puts stderr "\t\tLVT_CC" + puts stderr "\t\tLVT_JPEG" + puts stderr "\t\tLVT_OPENJPEG" + puts stderr "\t\tLVT_ECCODES" + puts stderr "\t\tLVT_NETCDF" + puts stderr "\t\tLVT_HDF4" + puts stderr "\t\tLVT_HDFEOS" + puts stderr "\t\tLVT_HDF5" + puts stderr "\t\tLVT_MODESMF" + puts stderr "\t\tLVT_LIBESMF" + puts stderr "\t\tLVT_GDAL" + puts stderr "\t\tLVT_FORTRANGIS" + puts stderr "" + puts stderr "\tThe following modules are loaded:" + puts stderr "\t\tcomp/gcc/11.2.0" + puts stderr "\t\tmpi/impi/2021.4.0" + puts stderr "\t\ttview/2019.0.4" + puts stderr "\t\tgit/2.40.1" + puts stderr "" +} + + +conflict comp mpi + + +module-whatis "loads the [module-info name] environment" + + +set modname [module-info name] +set modmode [module-info mode] + + +module load comp/gcc/11.2.0 +module load mpi/impi/2021.4.0 + +module load tview/2019.0.4 +module load git/2.40.1 + + +set def_lis_jpeg /discover/nobackup/projects/lis/libs/sles-12.3/jpeg/8d +set def_lis_hdf5 /discover/nobackup/projects/lis/libs/sles-12.3/hdf5/1.12.1_gnu-11.2.0 +set def_lis_netcdf /discover/nobackup/projects/lis/libs/sles-12.3/netcdf/4.8.1_gnu-11.2.0 +set def_lis_openjpeg /discover/nobackup/projects/lis/libs/sles-12.3/openjpeg/2.4.0_gnu-11.2.0 +set def_lis_eccodes /discover/nobackup/projects/lis/libs/sles-12.3/ecCodes/2.23.0_gnu-11.2.0 +set def_lis_hdf4 /discover/nobackup/projects/lis/libs/sles-12.3/hdf4/4.2.15_gnu-11.2.0 +set def_lis_hdfeos /discover/nobackup/projects/lis/libs/sles-12.3/hdfeos2/3.0_gnu-11.2.0 +set def_lis_modesmf /discover/nobackup/projects/lis/libs/sles-12.3/esmf/8.1.1_gnu-11.2.0_impi-2021.4.0/mod/modO/Linux.gfortran.64.intelmpi.default +set def_lis_libesmf /discover/nobackup/projects/lis/libs/sles-12.3/esmf/8.1.1_gnu-11.2.0_impi-2021.4.0/lib/libO/Linux.gfortran.64.intelmpi.default +#set def_lis_minpack /discover/nobackup/projects/lis/libs/minpack/intel_11_1_038 +#set def_lis_crtm /discover/nobackup/projects/lis/libs/JCSDA_CRTM/REL-2.0.2.Surface-rev_intel_18_0_3_222 +#set def_lis_crtm_prof /discover/nobackup/projects/lis/libs/CRTM_Profile_Utility/intel_18_0_3_222 +#set def_lis_cmem /discover/nobackup/projects/lis/libs/LIS-MEM/intel_18_0_3_222 +set def_lis_lapack /discover/nobackup/projects/lis/libs/sles-12.3/blaslapack/3.11.0_gnu-11.2.0/lib +set def_lvt_proj /discover/nobackup/projects/lis/libs/sles-12.3/proj/9.1.0_gnu-11.2.0 +set def_lvt_gdal /discover/nobackup/projects/lis/libs/sles-12.3/gdal/3.5.2_gnu-11.2.0 +set def_lvt_fortrangis /discover/nobackup/projects/lis/libs/sles-12.3/fortrangis/2.6_gdal-3.5.2_gnu-11.2.0 +set def_ldt_libgeotiff /discover/nobackup/projects/lis/libs/sles-12.3/geotiff/1.7.0_proj-9.1.0_gnu-11.2.0 +set def_lis_petsc /discover/nobackup/projects/lis/libs/sles-12.3/petsc/3.16.1_gnu-11.2.0 + +setenv DEV_ENV LISF_7_5_GNU_11_2_0_IMPI_2021_4_0 +setenv LIS_ARCH linux_gfortran +setenv LIS_SPMD parallel +setenv LIS_FC mpif90 +setenv LIS_CC mpicc +setenv LIS_JPEG $def_lis_jpeg +setenv LIS_OPENJPEG $def_lis_openjpeg +setenv LIS_ECCODES $def_lis_eccodes +setenv LIS_NETCDF $def_lis_netcdf +setenv LIS_HDF4 $def_lis_hdf4 +setenv LIS_HDFEOS $def_lis_hdfeos +setenv LIS_HDF5 $def_lis_hdf5 +setenv LIS_MODESMF $def_lis_modesmf +setenv LIS_LIBESMF $def_lis_libesmf +#setenv LIS_MINPACK $def_lis_minpack +#setenv LIS_CRTM $def_lis_crtm +#setenv LIS_CRTM_PROF $def_lis_crtm_prof +#setenv LIS_CMEM $def_lis_cmem +setenv LIS_LAPACK $def_lis_lapack +setenv LIS_PETSC $def_lis_petsc + + +setenv LDT_ARCH linux_gfortran +setenv LDT_FC mpif90 +setenv LDT_CC mpicc +setenv LDT_JPEG $def_lis_jpeg +setenv LDT_OPENJPEG $def_lis_openjpeg +setenv LDT_ECCODES $def_lis_eccodes +setenv LDT_NETCDF $def_lis_netcdf +setenv LDT_HDF4 $def_lis_hdf4 +setenv LDT_HDFEOS $def_lis_hdfeos +setenv LDT_HDF5 $def_lis_hdf5 +setenv LDT_MODESMF $def_lis_modesmf +setenv LDT_LIBESMF $def_lis_libesmf +setenv LDT_GDAL $def_lvt_gdal +setenv LDT_FORTRANGIS $def_lvt_fortrangis +setenv LDT_LIBGEOTIFF $def_ldt_libgeotiff + + +setenv LVT_ARCH linux_gfortran +setenv LVT_FC mpif90 +setenv LVT_CC mpicc +setenv LVT_JPEG $def_lis_jpeg +setenv LVT_OPENJPEG $def_lis_openjpeg +setenv LVT_ECCODES $def_lis_eccodes +setenv LVT_NETCDF $def_lis_netcdf +setenv LVT_HDF4 $def_lis_hdf4 +setenv LVT_HDFEOS $def_lis_hdfeos +setenv LVT_HDF5 $def_lis_hdf5 +setenv LVT_MODESMF $def_lis_modesmf +setenv LVT_LIBESMF $def_lis_libesmf +setenv LVT_GDAL $def_lvt_gdal +setenv LVT_FORTRANGIS $def_lvt_fortrangis + + +prepend-path LD_LIBRARY_PATH "$def_lis_jpeg/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_openjpeg/lib" +prepend-path LD_LIBRARY_PATH "$def_ldt_libgeotiff/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_proj/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_gdal/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf4/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf5/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_libesmf" +prepend-path LD_LIBRARY_PATH "$def_lis_netcdf/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_eccodes/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_petsc/lib" +prepend-path PATH "$def_lis_netcdf/bin:$def_lis_eccodes/bin" From 4bf03adf0b39d8d2699383c29a0e7cf25624a844 Mon Sep 17 00:00:00 2001 From: Mahdi Navari Date: Thu, 21 Sep 2023 12:47:45 -0400 Subject: [PATCH 169/328] Cleaning up the codes. --- .../LISlsmPrecipobs/readLISlsmPrecipobs.F90 | 14 --- ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 | 33 +------ .../LISlsmPrecipobs/read_Precip_climo.F90 | 98 ------------------- 3 files changed, 1 insertion(+), 144 deletions(-) diff --git a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 index 7d6f416e7..109685ceb 100644 --- a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 @@ -102,20 +102,6 @@ end subroutine create_lsm_output_fname write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' call LDT_endrun() -#if 0 - ftn = LDT_getNextUnitNumber() - open(ftn,file=trim(fname), form='unformatted') - if(file_exists) then - do index=1,LDT_MOC_COUNT - call LDT_readLISSingleBinaryVar(n,ftn,LDT_DAobsDataPtr(n,index)%dataEntryPtr) - enddo - else - print*, 'LSM file ',trim(fname),' does not exist' - print*, 'Program stopping.. ' - stop - endif - call LDT_releaseUnitNumber(ftn) -#endif elseif(lsmprecipobs%format.eq."grib1") then if(lsmprecipobs%wstyle.ne."WMO convention") then write(LDT_logunit,*) '[ERR] LDT currently does not support this style of grib output' diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 index bb97f1c6f..69f85fdf3 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 @@ -64,7 +64,6 @@ subroutine read_Drange(ngrid, filename, varname, xrange) #if(defined USE_NETCDF3 || defined USE_NETCDF4) write(LDT_logunit,*) '[INFO] Reading Drange form CDF file ',trim(filename) - !if(ngrid.gt.0) then call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& ncid=nid),'failed to open file '//trim(filename)) @@ -87,14 +86,6 @@ subroutine read_Drange(ngrid, filename, varname, xrange) call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& 'nf90_inquire_dimension failed for ntimes') - !if(nbins.ne.nbins_file) then - ! write(LDT_logunit,*) '[ERR] The number of bins specified in the file '//& - ! trim(filename) - ! write(LDT_logunit,*) '[ERR] (',nbins_file, & - ! ') is different from the number of bins specified' - ! write(LDT_logunit,*) '[ERR] in the lis.config file (',nbins,')' - ! call LDT_endrun() - !endif if (ntimes_file .gt. 1) then write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& @@ -104,48 +95,26 @@ subroutine read_Drange(ngrid, filename, varname, xrange) call LDT_endrun() endif - !allocate(xrange(ngrid_file,2)) allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) - !allocate(cdf_file(ngrid_file,nlevs_file, nbins)) do j=1,ntimes_file call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') - !call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_CDF',cdfid),& - ! 'nf90_inq_varid failed for '//trim(varname)//'_CDF') call LDT_verify(nf90_get_var(nid,xid,xrange_file, & start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& 'nf90_get_var failed for '//trim(varname)//'_xrange') - !call LDT_verify(nf90_get_var(nid,cdfid,cdf_file,& - ! start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins/)),& - ! 'nf90_get_var failed for '//trim(varname)//'_CDF') - -! Note: CDF is generated by LDT --> therefore data is in the LDT domain -#if 0 - if(ngrid.gt.0) then - do kk=1,nbins - call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & - xrange(:,j,kk)) - call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & - cdf(:,j,kk)) - enddo - endif -#endif + enddo xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell -! xrange = xrange_file -! cdf = cdf_file deallocate(xrange_file) - !deallocate(cdf_file) call LDT_verify(nf90_close(nid),& 'failed to close file '//trim(filename)) write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) - !endif #endif end subroutine read_Drange diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 index 3a487468e..a97d54259 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -28,15 +28,9 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) implicit none ! !ARGUMENTS: -! integer, intent(in) :: n -! integer, intent(in) :: k -! integer, intent(in) :: nbins -! integer, intent(in) :: ntimes integer, intent(in) :: ncol, nrow character(len=*), intent(in) :: filename -! character(len=*) :: varname real :: precip(ncol,nrow,12) - !real :: cdf(ngrid,ntimes, nbins) logical :: file_exists ! ! !DESCRIPTION: @@ -54,13 +48,7 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) ! \item[cdf] y-axis (CDF) values corresponding to the CDF ! \end{description} !EOP - ! integer :: j,kk - ! integer :: ngridId, nbinsId, nlevsId, ntimesId - ! integer :: ngrid_file, nbins_file, nlevs_file, ntimes_file - ! integer :: xid, cdfid real, allocatable :: precip_climo(:,:,:) - !real, allocatable :: P_month(:,:) - !integer :: nid integer :: ios,nid,ncId,nrId,varId integer :: nc,nr,i,c,r character*3 :: month_name(12) @@ -78,10 +66,8 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) call LDT_endrun() end if - !if(file_exists) then write(LDT_logunit,*) '[INFO] Reading Precipitation climatology from CDF file ',trim(filename) - !if(ngrid.gt.0) then call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& ncid=nid),'failed to open file '//trim(filename)) @@ -107,7 +93,6 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) call LDT_endrun() endif - ! allocate(P_month(nc,nr)) allocate(precip_climo(nc,nr,12)) do i=1,12 @@ -121,93 +106,10 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) ios = nf90_close(nid) call LDT_verify(ios,'Error in nf90_close in readldtparam_real_2d') write(LDT_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) - !endif precip = precip_climo deallocate(precip_climo) - -#if 0 - call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & - 'nf90_inq_dimid failed for ngrid') - call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & - 'nf90_inq_dimid failed for nbins') - call LDT_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & - 'nf90_inq_dimid failed for '//trim(varname)//"_levels") - call LDT_verify(nf90_inq_dimid(nid,"ntimes",ntimesId), & - 'nf90_inq_dimid failed for ntimes') - - - call LDT_verify(nf90_inquire_dimension(nid,ngridId, len=ngrid_file),& - 'nf90_inquire_dimension failed for ngrid') - call LDT_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& - 'nf90_inquire_dimension failed for nbins') - call LDT_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& - 'nf90_inquire_dimension failed for nbins') - call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& - 'nf90_inquire_dimension failed for ntimes') - - !if(nbins.ne.nbins_file) then - ! write(LDT_logunit,*) '[ERR] The number of bins specified in the file '//& - ! trim(filename) - ! write(LDT_logunit,*) '[ERR] (',nbins_file, & - ! ') is different from the number of bins specified' - ! write(LDT_logunit,*) '[ERR] in the lis.config file (',nbins,')' - ! call LDT_endrun() - !endif - - if (ntimes_file .gt. 1) then - write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& - trim(filename) - write(LDT_logunit,*) '[ERR] (',ntimes_file, & - ') should be 1 set the Temporal resolution of precipitation CDFs to "yearly" ' - call LDT_endrun() - endif - - !allocate(xrange(ngrid_file,2)) - allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) - !allocate(cdf_file(ngrid_file,nlevs_file, nbins)) - - do j=1,ntimes_file - call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& - 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') - !call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_CDF',cdfid),& - ! 'nf90_inq_varid failed for '//trim(varname)//'_CDF') - - call LDT_verify(nf90_get_var(nid,xid,xrange_file, & - start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& - 'nf90_get_var failed for '//trim(varname)//'_xrange') - !call LDT_verify(nf90_get_var(nid,cdfid,cdf_file,& - ! start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins/)),& - ! 'nf90_get_var failed for '//trim(varname)//'_CDF') - -! Note: CDF is generated by LDT --> therefore data is in the LDT domain -#if 0 - if(ngrid.gt.0) then - do kk=1,nbins - call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & - xrange(:,j,kk)) - call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & - cdf(:,j,kk)) - enddo - endif -#endif - enddo - - xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell - xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell -! xrange = xrange_file -! cdf = cdf_file - - deallocate(xrange_file) - !deallocate(cdf_file) - - call LDT_verify(nf90_close(nid),& - 'failed to close file '//trim(filename)) - write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) - !endif -#endif - ! end USE_NETCDF4 #endif From 86196d6033e728efedf08f2998eddd209a265ec4 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 2 Oct 2023 10:05:19 -0400 Subject: [PATCH 170/328] Correct grammar --- docs/working_with_github/working_with_github.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/working_with_github/working_with_github.adoc b/docs/working_with_github/working_with_github.adoc index 230c7fe5f..11dc47a2d 100644 --- a/docs/working_with_github/working_with_github.adoc +++ b/docs/working_with_github/working_with_github.adoc @@ -942,7 +942,7 @@ Again, the specific command will depend on which private repository you need to Now you have a repository (for the restricted-access component) within a repository (for LISF). To carry out your work for the restricted-access component, follow the instructions in <> and/or <>. -Yes, you may two sets of commits and two sets of pull requests for your work. +Yes, you may have two sets of commits and two sets of pull requests for your work. [WARNING] ==== From 34e09ce97689af85e77e7a0ea9b85cc08e1ddc80 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Mon, 2 Oct 2023 10:07:17 -0400 Subject: [PATCH 171/328] Add section "Explicitly add files" --- .../working_with_github/working_with_github.adoc | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/docs/working_with_github/working_with_github.adoc b/docs/working_with_github/working_with_github.adoc index 11dc47a2d..6597b2f1f 100644 --- a/docs/working_with_github/working_with_github.adoc +++ b/docs/working_with_github/working_with_github.adoc @@ -14,6 +14,7 @@ :lisf: LISF :lisf_git: LISF.git :lisf_test_git: lisf-test.git +:emdash: — == General notes @@ -947,7 +948,7 @@ Yes, you may have two sets of commits and two sets of pull requests for your wor [WARNING] ==== -In general, do not run `git add --all`; this always ends up adding files to your commit that do not belong. And, in particular, do not run `git add --all` when working with private/restricted repositories. If you accidentally do, then you will see the following warning. Follow the hint for running `git rm`. +In general, do not run `git add --all`; this always ends up adding files to your commit that do not belong. (See Section <>.) And, in particular, do not run `git add --all` when working with private/restricted repositories. If you accidentally do, then you will see the following warning. Follow the hint for running `git rm`. .Accidental `git add --all` .... @@ -972,6 +973,19 @@ add 'RESTRICTED/restricted-ua-lsm/' ==== +== Explicitly add files + +Do not run commands like `git add .` or `git add --all`. These commands will add files to your commit that do not belong. For example, you may end up adding restricted code, backup files, temporary build scripts, and executables {emdash} files that do not belong in the repository. + +Add files to a commit explicitly. For example, you added a new output variable to NoahMP 4.0.1: + +.... +% git add core/LIS_histDataMod.F90 surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 +.... + +See `git help add` for more information about adding files to a commit. + + == Useful commands .... From 4981e5724ef82ed09289cb32436f7045bad64d7b Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 3 Oct 2023 10:44:02 -0400 Subject: [PATCH 172/328] Update revision history for Users' Guides for LISF Public 7.4.3 release --- docs/LDT_users_guide/LDT_users_guide.adoc | 4 ++-- docs/LDT_users_guide/revision_table.adoc | 1 + 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/docs/LDT_users_guide/LDT_users_guide.adoc b/docs/LDT_users_guide/LDT_users_guide.adoc index a9e4d2096..965dda9b2 100644 --- a/docs/LDT_users_guide/LDT_users_guide.adoc +++ b/docs/LDT_users_guide/LDT_users_guide.adoc @@ -1,6 +1,6 @@ = Land Data Toolkit (LDT): LDT {lisfrevision} Users`' Guide -:revnumber: 2.0 -:revdate: 22 Jun 2022 +:revnumber: 2.1 +:revdate: 03 Oct 2023 :doctype: book :sectnums: :toc: diff --git a/docs/LDT_users_guide/revision_table.adoc b/docs/LDT_users_guide/revision_table.adoc index a7d72b8e2..f41ca5ba0 100644 --- a/docs/LDT_users_guide/revision_table.adoc +++ b/docs/LDT_users_guide/revision_table.adoc @@ -2,6 +2,7 @@ |==== | Revision | Summary of Changes | Date +| 2.1 | LISF Public 7.4.3 release | Oct 03, 2023 | 2.0 | LISF Public 7.4.0 release | Jun 22, 2022 | 1.18 | LISF Public 7.3.5 release | Jun 10, 2022 | 1.17 | LISF 557WW 7.4.8 release | Jan 20, 2022 From 95afa5276ea78b6da035486af25340e06190a0a0 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 4 Oct 2023 15:23:16 -0400 Subject: [PATCH 173/328] Alternative QC check. --- .../IMERG_monthly/readIMERGmonthlydata.F90 | 93 ++++++++++++++----- 1 file changed, 72 insertions(+), 21 deletions(-) diff --git a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 index ddadcb844..596b275d1 100644 --- a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 +++ b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 @@ -229,8 +229,10 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) ! Local variables integer :: xsize, ysize character(len=40) :: dsetname = '/Grid/precipitation' - character(len=40) :: dsetname_qi = '/Grid/precipitationQualityIndex' - real :: qiin(row,col) + !character(len=40) :: dsetname_qi = '/Grid/precipitationQualityIndex' + character(len=40) :: dsetname_wgt = '/Grid/gaugeRelativeWeighting' + !real :: qiin(row,col) + real :: wgtin(row,col) real :: precipin(row,col) integer :: istatus integer :: i, j @@ -239,7 +241,8 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) integer(HID_T) :: fileid, dsetid #endif - qiin = LVT_rc%udef + !qiin = LVT_rc%udef + wgtin = LVT_rc%udef precipin = LVT_rc%udef precipout = LVT_rc%udef @@ -268,23 +271,58 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! Open quality index dataset - call h5dopen_f(fileid, dsetname_qi, dsetid, istatus) + ! ! Open quality index dataset + ! call h5dopen_f(fileid, dsetname_qi, dsetid, istatus) + ! if (istatus .ne. 0) then + ! write(LVT_logunit,*) 'Error opening IMERG dataset', & + ! trim(dsetname_qi) + ! ireaderr = istatus + ! call h5fclose_f(fileid, istatus) ! Close HDF5 file + ! call h5close_f(istatus) ! Close HDF5 interface + ! return + ! end if + + ! ! Read quality index dataset + ! call h5dread_f(dsetid, H5T_NATIVE_REAL, & + ! qiin, dims, istatus) + ! if (istatus .ne. 0) then + ! write(LVT_logunit,*) 'Error reading IMERG dataset', & + ! trim(dsetname_qi) + ! ireaderr = istatus + ! call h5dclose_f(dsetid, istatus) ! Close dataset + ! call h5fclose_f(fileid, istatus) ! Close HDF5 file + ! call h5close_f(istatus) ! Close HDF5 interface + ! return + ! end if + + ! ! Close quality index dataset + ! call h5dclose_f(dsetid, istatus) + ! if (istatus .ne. 0) then + ! write(LVT_logunit,*) 'Error closing IMERG dataset', & + ! trim(dsetname_qi) + ! ireaderr = istatus + ! call h5fclose_f(fileid, istatus) ! Close HDF5 file + ! call h5close_f(istatus) ! Close HDF5 interface + ! return + ! end if + + ! Open gauge relative weight dataset + call h5dopen_f(fileid, dsetname_wgt, dsetid, istatus) if (istatus .ne. 0) then write(LVT_logunit,*) 'Error opening IMERG dataset', & - trim(dsetname_qi) + trim(dsetname_wgt) ireaderr = istatus call h5fclose_f(fileid, istatus) ! Close HDF5 file call h5close_f(istatus) ! Close HDF5 interface return end if - ! Read quality index dataset + ! Read gauge relative weight dataset call h5dread_f(dsetid, H5T_NATIVE_REAL, & - qiin, dims, istatus) + wgtin, dims, istatus) if (istatus .ne. 0) then write(LVT_logunit,*) 'Error reading IMERG dataset', & - trim(dsetname_qi) + trim(dsetname_wgt) ireaderr = istatus call h5dclose_f(dsetid, istatus) ! Close dataset call h5fclose_f(fileid, istatus) ! Close HDF5 file @@ -292,11 +330,11 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! Close quality index dataset + ! Close gauge relative weight dataset call h5dclose_f(dsetid, istatus) if (istatus .ne. 0) then write(LVT_logunit,*) 'Error closing IMERG dataset', & - trim(dsetname_qi) + trim(dsetname_wgt) ireaderr = istatus call h5fclose_f(fileid, istatus) ! Close HDF5 file call h5close_f(istatus) ! Close HDF5 interface @@ -324,16 +362,29 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! Flag precipin values where quality index is less then 2.5 (interpreted - ! as less than 2.5 gauges used in analysis). Note that polar regions - ! have values ~2.1. - do j = 1, col - do i = 1, row - if (qiin(i,j) < 2.5) then - precipin(i,j) = LVT_rc%udef - end if - end do - end do + ! ! Flag precipin values where quality index is less then 2.5 (interpreted + ! ! as less than 2.5 gauges used in analysis). Note that polar regions + ! ! have values ~2.1. + ! do j = 1, col + ! do i = 1, row + ! if (qiin(i,j) < 2.5) then + ! precipin(i,j) = LVT_rc%udef + ! end if + ! end do + ! end do + + ! Flag precipin values where gauge relative weighting is less then + ! 0.5 (meaning raw IMERG was weighted at least 50% of final product) + ! do j = 1, col + ! do i = 1, row + ! if (wgtin(i,j) < 0.50) then + ! !if (wgtin(i,j) < 0.25) then + ! !if (wgtin(i,j) < 0.1) then + ! !if (wgtin(i,j) < 0.01) then + ! precipin(i,j) = LVT_rc%udef + ! end if + ! end do + ! end do ! Put the real(1:,1:) on the precipout(0:,0:) ! precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) From 96d78c26001d0f2124e3f6d933e84c1c7d0859b4 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 4 Oct 2023 15:33:21 -0400 Subject: [PATCH 174/328] Removed QC of IMERG data. All monthly data will be interpolated as-is. --- .../IMERG_monthly/readIMERGmonthlydata.F90 | 111 ------------------ 1 file changed, 111 deletions(-) diff --git a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 index 596b275d1..b0da4236e 100644 --- a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 +++ b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 @@ -118,12 +118,6 @@ subroutine readIMERGmonthlydata(source) end do ! c end do ! r - write(LVT_logunit,*)'EMK: maxval(prcp_in1) = ', & - maxval(prcp_in1) - write(LVT_logunit,*)'EMK: minval(prcp_in1) = ', & - minval(prcp_in1) - flush(LVT_logunit) - if (LVT_isAtAFinerResolution( & imergmonthlydata(source)%datares)) then call conserv_interp(LVT_rc%gridDesc, lb, prcp_in1, & @@ -200,11 +194,6 @@ subroutine readIMERGmonthlydata(source) call LVT_logSingleDataStreamVar(LVT_MOC_totalprecip, source, & prcp_final, vlevel=1, units='kg/m2') - write(LVT_logunit,*)'EMK: LVT_rc%udef = ', LVT_rc%udef - write(LVT_logunit,*)'EMK: maxval(precip) = ', maxval(prcp_final) - write(LVT_logunit,*)'EMK: minval(precip) = ', minval(prcp_final) - flush(LVT_logunit) - end subroutine readIMERGmonthlydata subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) @@ -229,10 +218,6 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) ! Local variables integer :: xsize, ysize character(len=40) :: dsetname = '/Grid/precipitation' - !character(len=40) :: dsetname_qi = '/Grid/precipitationQualityIndex' - character(len=40) :: dsetname_wgt = '/Grid/gaugeRelativeWeighting' - !real :: qiin(row,col) - real :: wgtin(row,col) real :: precipin(row,col) integer :: istatus integer :: i, j @@ -241,8 +226,6 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) integer(HID_T) :: fileid, dsetid #endif - !qiin = LVT_rc%udef - wgtin = LVT_rc%udef precipin = LVT_rc%udef precipout = LVT_rc%udef @@ -271,76 +254,6 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! ! Open quality index dataset - ! call h5dopen_f(fileid, dsetname_qi, dsetid, istatus) - ! if (istatus .ne. 0) then - ! write(LVT_logunit,*) 'Error opening IMERG dataset', & - ! trim(dsetname_qi) - ! ireaderr = istatus - ! call h5fclose_f(fileid, istatus) ! Close HDF5 file - ! call h5close_f(istatus) ! Close HDF5 interface - ! return - ! end if - - ! ! Read quality index dataset - ! call h5dread_f(dsetid, H5T_NATIVE_REAL, & - ! qiin, dims, istatus) - ! if (istatus .ne. 0) then - ! write(LVT_logunit,*) 'Error reading IMERG dataset', & - ! trim(dsetname_qi) - ! ireaderr = istatus - ! call h5dclose_f(dsetid, istatus) ! Close dataset - ! call h5fclose_f(fileid, istatus) ! Close HDF5 file - ! call h5close_f(istatus) ! Close HDF5 interface - ! return - ! end if - - ! ! Close quality index dataset - ! call h5dclose_f(dsetid, istatus) - ! if (istatus .ne. 0) then - ! write(LVT_logunit,*) 'Error closing IMERG dataset', & - ! trim(dsetname_qi) - ! ireaderr = istatus - ! call h5fclose_f(fileid, istatus) ! Close HDF5 file - ! call h5close_f(istatus) ! Close HDF5 interface - ! return - ! end if - - ! Open gauge relative weight dataset - call h5dopen_f(fileid, dsetname_wgt, dsetid, istatus) - if (istatus .ne. 0) then - write(LVT_logunit,*) 'Error opening IMERG dataset', & - trim(dsetname_wgt) - ireaderr = istatus - call h5fclose_f(fileid, istatus) ! Close HDF5 file - call h5close_f(istatus) ! Close HDF5 interface - return - end if - - ! Read gauge relative weight dataset - call h5dread_f(dsetid, H5T_NATIVE_REAL, & - wgtin, dims, istatus) - if (istatus .ne. 0) then - write(LVT_logunit,*) 'Error reading IMERG dataset', & - trim(dsetname_wgt) - ireaderr = istatus - call h5dclose_f(dsetid, istatus) ! Close dataset - call h5fclose_f(fileid, istatus) ! Close HDF5 file - call h5close_f(istatus) ! Close HDF5 interface - return - end if - - ! Close gauge relative weight dataset - call h5dclose_f(dsetid, istatus) - if (istatus .ne. 0) then - write(LVT_logunit,*) 'Error closing IMERG dataset', & - trim(dsetname_wgt) - ireaderr = istatus - call h5fclose_f(fileid, istatus) ! Close HDF5 file - call h5close_f(istatus) ! Close HDF5 interface - return - end if - ! Open precip dataset call h5dopen_f(fileid, dsetname, dsetid, istatus) if (istatus .ne. 0) then @@ -362,30 +275,6 @@ subroutine read_imergmonthly_hdf(filename, col, row, precipout, ireaderr) return end if - ! ! Flag precipin values where quality index is less then 2.5 (interpreted - ! ! as less than 2.5 gauges used in analysis). Note that polar regions - ! ! have values ~2.1. - ! do j = 1, col - ! do i = 1, row - ! if (qiin(i,j) < 2.5) then - ! precipin(i,j) = LVT_rc%udef - ! end if - ! end do - ! end do - - ! Flag precipin values where gauge relative weighting is less then - ! 0.5 (meaning raw IMERG was weighted at least 50% of final product) - ! do j = 1, col - ! do i = 1, row - ! if (wgtin(i,j) < 0.50) then - ! !if (wgtin(i,j) < 0.25) then - ! !if (wgtin(i,j) < 0.1) then - ! !if (wgtin(i,j) < 0.01) then - ! precipin(i,j) = LVT_rc%udef - ! end if - ! end do - ! end do - ! Put the real(1:,1:) on the precipout(0:,0:) ! precipin is (ysize,xsize) starting at (lon=-179.9,lat=-89.9) precipout(1:xsize,1:ysize) = transpose(precipin) From 5ea34c7a7e28f9cb039da6d8b20fa85fc5face61 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 4 Oct 2023 15:34:37 -0400 Subject: [PATCH 175/328] First cut of script to calculate bias ratios for NAFPA. Targets GFS and GALWEM background fields across multiple years, producing 12 monthly fields. IMERG-FR V07A monthly data are used as "truth". TODO: Add code to move most currently hardwired settings to a config file. --- .../calc_gfsgalwem_biasratios_multiyear.py | 189 ++++++++++++++++++ 1 file changed, 189 insertions(+) create mode 100755 lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py new file mode 100755 index 000000000..8c0c7ed21 --- /dev/null +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -0,0 +1,189 @@ +#!/usr/bin/env python3 + +import datetime +import os +import sys + +from netCDF4 import Dataset as nc4_dataset +import numpy as np + +# Start and end date of GFS period for NAFPA +back_source = "GFS" +#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # GFS-Spectral +#enddt = datetime.datetime(2019, 6, 1, 0, 0, 0) # GFS-Spectral +#startdt = datetime.datetime(2019, 7, 1, 0, 0, 0) # GFS-FV3 +#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # GFS-FV3 +#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # All GFS +#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # All GFS +#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # Pre-GALWEM +#enddt = datetime.datetime(2017, 9, 1, 0, 0, 0) # Pre-GALWEM +startdt = datetime.datetime(2017, 10, 1, 0, 0, 0) # GALWEM Era +enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # GALWEM Era + +topdir_back = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GFS_NAFPA_Monthly_all" + +# Start and end date of GALWEM period for NAFPA +#back_source = "GALWEM" +#startdt = datetime.datetime(2017, 10, 1, 0, 0, 0) +#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) +#topdir_back = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GALWEM_NAFPA_Monthly_all" + +timedelta = datetime.timedelta(days=1) + +# Other data +topdir_imergf = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/IMERGF_V07A_NAFPA_Monthly" +topdir_biasratio = f"testdir_{back_source}" + +def _main(): + """Main driver""" + + ny = 1920 + nx = 2560 + nmon = 12 + + sum_blended = np.zeros([nmon,ny,nx]) + sum_back = np.zeros([nmon,ny,nx]) + precip_ratio = np.zeros([nmon,ny,nx]) + + # Loop through each month + curdt = startdt + while curdt <= enddt: + + # LVT output files have data from the prior month, so we must + # advance one month to find the appropriate file. Python's + # timedelta object isn't smart enough to jump a whole month, so + # we loop through each day instead. + nextdt = curdt + timedelta + while nextdt.day != 1: + nextdt += timedelta + + # First, the IMERG file + filename = f"{topdir_imergf}/SUM_TS." + filename += f"{nextdt.year:04d}{nextdt.month:02d}{nextdt.day:02d}" + filename += "0000.d01.nc" + ncid_imerg = nc4_dataset(filename, mode='r', \ + format="NETCDF4_CLASSIC") + precip_imerg = ncid_imerg.variables['TotalPrecip'][:,:] + lats_imerg = ncid_imerg.variables["latitude"][:,:] + lons_imerg = ncid_imerg.variables["longitude"][:,:] + north_south = ncid_imerg.dimensions['north_south'].size + east_west = ncid_imerg.dimensions['east_west'].size + del ncid_imerg + + # Next, the GFS or GALWEM file + filename = f"{topdir_back}/SUM_TS." + filename += f"{nextdt.year:04d}{nextdt.month:02d}{nextdt.day:02d}" + filename += "0000.d01.nc" + ncid_back = nc4_dataset(filename, mode='r', \ + format="NETCDF4_CLASSIC") + precip_back = ncid_back.variables['TotalPrecip'][:,:] + del ncid_back + + # Use IMERG from 40S to 40N, use linear tapers from 40S to 60S, + # and 40N to 60N, and don't use IMERG poleward of 60N and 60S. + # RATIONALE: No IR data is available poleward of 60N and 60S, + # and PMW data has diminished performance over frozen surfaces. + # Also, GPCC gage coverage tends to thin out in poleward regions, + # (no GPCC gages at all in Antarctica), so we screen out these + # areas for simplicity. Finally, the 20 degree linear taper + # mimicks MERRA-2 usage of CPCU gauge analyses. + precip_imerg_weights = np.ones(np.shape(lats_imerg)) + precip_imerg_weights = np.where(lats_imerg < -60, + 0, + precip_imerg_weights) + precip_imerg_weights = np.where( (lats_imerg >= -60) & + (lats_imerg < -40), + ( (lats_imerg + 60.) / 20.), + precip_imerg_weights) + #precip_imerg_weights = np.where( (lats_imerg > 40) & + # (lats_imerg <= 60), + # ( (60. - lats_imerg) / 20.), + # precip_imerg_weights) + #precip_imerg_weights = np.where(lats_imerg > 60, + # 0, + # precip_imerg_weights) + # EMK Alternative...Move the northern linear taper region to + # 51N to 71N. Rationale is to leverage the relatively high + # GPCC gauge density in the Scandinavian Peninsula. + precip_imerg_weights = np.where( (lats_imerg > 51) & + (lats_imerg <= 71), + ( (71. - lats_imerg) / 20.), + precip_imerg_weights) + precip_imerg_weights = np.where(lats_imerg > 71, + 0, + precip_imerg_weights) + + precip_blended = precip_imerg_weights[:,:]*precip_imerg[:,:] + \ + (1. - precip_imerg_weights[:,:])*precip_back[:,:] + + sum_blended[(curdt.month-1),:,:] += precip_blended[:,:] + 0.05 + sum_back[(curdt.month-1),:,:] += precip_back[:,:] + 0.05 + + # Move on to next month + curdt = nextdt + + # Output to file + filename = f"{topdir_biasratio}/{back_source}_pcp_biasratio.nc" + + rootgrp = nc4_dataset(filename, "w", format="NETCDF4") + rootgrp.missing_value = np.float32("-9999.") + rootgrp.title = f"Monthly bias ratio for IMERG / {back_source}" + rootgrp.institution = "NASA GSFC" + now = datetime.datetime.utcnow() + history = "created on date: " + history += f"{now.year:04d}-{now.month:02d}-{now.day:02d}" + history += f"T{now.hour:02d}:{now.minute:02d}:{now.second:02d}" + rootgrp.history = f"created on date: {history}" + rootgrp.comment = "website: http://lis.gsfc.nasa.gov/" + rootgrp.MAP_PROJECTION = "EQUIDISTANT CYLINDRICAL" + rootgrp.SOUTH_WEST_CORNER_LAT = np.float32("-89.95312") + rootgrp.SOUTH_WEST_CORNER_LON = np.float32("-179.9297") + rootgrp.DX = np.float32("0.140625") + rootgrp.DY = np.float32("0.09375") + + # Define dimensions + months = rootgrp.createDimension("months", 12) + north_south = rootgrp.createDimension("north_south", north_south) + east_west = rootgrp.createDimension("east_west", east_west) + + # Define latitude + latitude = rootgrp.createVariable("latitude", "f4", \ + ("north_south", "east_west",)) + latitude.units = "degree_north" + latitude.standard_name = "latitude" + latitude.long_name = "latitude" + latitude.scale_factor = np.float32("1.") + latitude.add_offset = np.float32("0.") + latitude.missing_value = np.float32("-9999.") + + # Define longitude + longitude = rootgrp.createVariable("longitude", "f4", \ + ("north_south", "east_west",)) + longitude.units = "degree_east" + longitude.standard_name = "longitude" + longitude.long_name = "longitude" + longitude.scale_factor = np.float32("1.") + longitude.add_offset = np.float32("0.") + longitude.missing_value = np.float32("-9999.") + + # Define biasRatio + biasRatio = rootgrp.createVariable("biasRatio", "f4", \ + ("months", "north_south", "east_west",)) + biasRatio.units = "-" + biasRatio.long_name = f"bias_ratio_for_{back_source}_precipitation" + biasRatio.scale_factor = np.float32("1.") + biasRatio.add_offset = np.float32("0.") + biasRatio.missing_value = np.float32("-9999.") + + latitude[:,:] = lats_imerg[:,:] + longitude[:,:] = lons_imerg[:,:] + + precip_ratio[:,:,:] = sum_blended[:,:,:] / sum_back[:,:,:] + precip_ratio[:,:,:] = np.where(precip_ratio == 0, 1, precip_ratio) + biasRatio[:,:,:] = precip_ratio[:,:,:] + + rootgrp.close() + + +if __name__ == "__main__": + _main() From 138a2620bcc37abd271ac4752689aefab57a946f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 4 Oct 2023 17:35:26 -0400 Subject: [PATCH 176/328] Revisions to use config file and command line arguments. Some testing and further tweaks are still pending. --- .../calc_gfsgalwem_biasratios_multiyear.py | 218 ++++++++++++++---- 1 file changed, 167 insertions(+), 51 deletions(-) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index 8c0c7ed21..9b98dd40f 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -1,5 +1,18 @@ #!/usr/bin/env python3 +""" +SCRIPT: calc_gfsgalwem_biasratios_multiyear.py + +Calculates bias ratio fields using monthly IMERG-FR V07A, GFS, and GALWEM +data, all already interpolated to the NAFPA grid and summed to monthly +totals via LVT. Outputs 12 fields total, each covering a month based +on multiple years of data. + +REVISION HISTORY: +04 Oct 2023: Eric Kemp: Initial specification. +""" + +import configparser import datetime import os import sys @@ -34,8 +47,64 @@ topdir_imergf = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/IMERGF_V07A_NAFPA_Monthly" topdir_biasratio = f"testdir_{back_source}" -def _main(): - """Main driver""" +def _usage(): + """Print usage message for this script.""" + print(f"Usage: {sys.argv[0]} CFGFILE BACKSOURCE STARTDATE ENDDATE") + print(" CFGFILE is path to config file") + print(" BACKSOURCE is GFS or GALWEM") + print(" STARTDATE is start date of calculation (YYYYMM)") + print(" ENDDATE is end date of calculateion (YYYYMM)") + +def _process_cmd_line(): + """Process command line arguments.""" + if len(sys.argv) != 5: + _usage() + sys.exit(1) + + cfgfile = sys.argv[1] + if not os.path.exists(cfgfile): + print(f"[ERR] {cfgfile} does not exist!") + sys.exit(1) + + backsource = sys.argv[2] + if backsource not in ["GFS", "GALWEM"]: + print(f"[ERR] {backsource} is not a valid background source") + print("[ERR] Only GFS and GALWEM recognized") + sys.exit(1) + + yyyymm = sys.argv[3] + year = int(yyyymm[0:4]) + month = int(yyyymm[4:6]) + startdate = datetime.datetime(year, month, 1) + + yyyymm = sys.argv[4] + year = int(yyyymm[0:4]) + month = int(yyyymm[4:6]) + enddate = datetime.datetime(year, month, 1) + + if startdate > enddate: + print("[ERR] STARTDATE is beyond ENDDATE!") + sys.exit(1) + + return cfgfile, backsource, startdate, enddate + +def _process_cfg_file(cfgfile, backsource): + """Processes config file for this script.""" + config = configparser.ConfigParser() + config.read(cfgfile) + + if backsource == "GFS": + backindir = config.get('Input', 'gfsdir') + backoutdir = config.get('Output', 'gfsdir') + elif backsource == "GALWEM": + backindir = config.get('Input', 'galwemdir') + backoutdir = config.get('Output', 'galwemdir') + imergdir = config.get('Input', 'imergdir') + + return backindir, backoutdir, imergdir + +def _calc_biasratios(imergdir, backindir, startdate, enddate): + """Calculate the bias ratios from the input data files.""" ny = 1920 nx = 2560 @@ -45,22 +114,25 @@ def _main(): sum_back = np.zeros([nmon,ny,nx]) precip_ratio = np.zeros([nmon,ny,nx]) + timedelta = datetime.timedelta(days=1) + # Loop through each month - curdt = startdt - while curdt <= enddt: + curdate = startdate + while curdate <= enddate: # LVT output files have data from the prior month, so we must - # advance one month to find the appropriate file. Python's + # advance one month to find the appropriate file, e.g., data + # for May 2020 will be in SUM_TS.202006010000.d01.nc. Python's # timedelta object isn't smart enough to jump a whole month, so # we loop through each day instead. - nextdt = curdt + timedelta - while nextdt.day != 1: - nextdt += timedelta + nextdate = curdate + timedelta + while nextdate.day != 1: + nextdate += timedelta # First, the IMERG file - filename = f"{topdir_imergf}/SUM_TS." - filename += f"{nextdt.year:04d}{nextdt.month:02d}{nextdt.day:02d}" - filename += "0000.d01.nc" + filename = f"{imergdir}/SUM_TS." + filename += f"{nextdate.year:04d}{nextdate.month:02d}" + filename += f"{nextdate.day:02d}0000.d01.nc" ncid_imerg = nc4_dataset(filename, mode='r', \ format="NETCDF4_CLASSIC") precip_imerg = ncid_imerg.variables['TotalPrecip'][:,:] @@ -70,23 +142,23 @@ def _main(): east_west = ncid_imerg.dimensions['east_west'].size del ncid_imerg - # Next, the GFS or GALWEM file - filename = f"{topdir_back}/SUM_TS." - filename += f"{nextdt.year:04d}{nextdt.month:02d}{nextdt.day:02d}" - filename += "0000.d01.nc" + # Next, the background data (GFS or GALWEM) + filename = f"{backindir}/SUM_TS." + filename += f"{nextdate.year:04d}{nextdate.month:02d}" + filename += f"{nextdate.day:02d}0000.d01.nc" ncid_back = nc4_dataset(filename, mode='r', \ format="NETCDF4_CLASSIC") precip_back = ncid_back.variables['TotalPrecip'][:,:] del ncid_back - # Use IMERG from 40S to 40N, use linear tapers from 40S to 60S, - # and 40N to 60N, and don't use IMERG poleward of 60N and 60S. - # RATIONALE: No IR data is available poleward of 60N and 60S, - # and PMW data has diminished performance over frozen surfaces. - # Also, GPCC gage coverage tends to thin out in poleward regions, - # (no GPCC gages at all in Antarctica), so we screen out these - # areas for simplicity. Finally, the 20 degree linear taper - # mimicks MERRA-2 usage of CPCU gauge analyses. + # Use IMERG from 40S to 71N; use linear tapers from 40S to 60S, + # and 51N to 71N; and don't use IMERG south of 60S and north of + # 71N. Rationale: No IR and little gauge data is available + # south of 60S, so we don't expect IMERG to be useful here. + # In the northern hemisphere, there is no IR data north of 60N, + # but there is good GPCC gauge density in Scandinavia up to 71N. + # Finally, the 20 degree latitude linear taper mimicks MERRA-2 + # usage of CPCU gauge analyses. precip_imerg_weights = np.ones(np.shape(lats_imerg)) precip_imerg_weights = np.where(lats_imerg < -60, 0, @@ -95,16 +167,6 @@ def _main(): (lats_imerg < -40), ( (lats_imerg + 60.) / 20.), precip_imerg_weights) - #precip_imerg_weights = np.where( (lats_imerg > 40) & - # (lats_imerg <= 60), - # ( (60. - lats_imerg) / 20.), - # precip_imerg_weights) - #precip_imerg_weights = np.where(lats_imerg > 60, - # 0, - # precip_imerg_weights) - # EMK Alternative...Move the northern linear taper region to - # 51N to 71N. Rationale is to leverage the relatively high - # GPCC gauge density in the Scandinavian Peninsula. precip_imerg_weights = np.where( (lats_imerg > 51) & (lats_imerg <= 71), ( (71. - lats_imerg) / 20.), @@ -113,26 +175,58 @@ def _main(): 0, precip_imerg_weights) + # Conservative alternative: Linear taper from 40N to 60N, and + # screen out everything north of 60N. We'll do this as a backup + # if we find unphysical IMERG patterns north of 60N + #precip_imerg_weights = np.where( (lats_imerg > 40) & + # (lats_imerg <= 60), + # ( (60. - lats_imerg) / 20.), + # precip_imerg_weights) + #precip_imerg_weights = np.where(lats_imerg > 60, + # 0, + # precip_imerg_weights) + precip_blended = precip_imerg_weights[:,:]*precip_imerg[:,:] + \ (1. - precip_imerg_weights[:,:])*precip_back[:,:] - sum_blended[(curdt.month-1),:,:] += precip_blended[:,:] + 0.05 - sum_back[(curdt.month-1),:,:] += precip_back[:,:] + 0.05 + # Add trace precipitation every month to prevent undefined + # ratios in deserts. + sum_blended[(curdate.month-1),:,:] += precip_blended[:,:] + 0.05 + sum_back[(curdate.month-1),:,:] += precip_back[:,:] + 0.05 # Move on to next month - curdt = nextdt + curdate = nextdate - # Output to file - filename = f"{topdir_biasratio}/{back_source}_pcp_biasratio.nc" + # Finish calculation + precip_ratio[:,:,:] = sum_blended[:,:,:] / sum_back[:,:,:] + precip_ratio[:,:,:] = np.where(precip_ratio == 0, 1, precip_ratio) + + return lats_imerg, lons_imerg, precip_ratio, east_west, north_south + +def _create_output_filename(backoutdir, backsource, startdate, enddate): + """Create output netCDF file name""" + filename = f"{backoutdir}" + filename += f"/{backsource}_pcp_biasratios_" + filename += f"{startdate.year:04d}{startdate.month:02d}_" + filename += f"{enddate.year:04d}{enddate.month:02d}.nc" + return filename + +def _write_biasratios(args): + """Write out bias ratios to netCDF file""" + + os.makedirs(args['backoutdir'], exist_ok=True) - rootgrp = nc4_dataset(filename, "w", format="NETCDF4") - rootgrp.missing_value = np.float32("-9999.") - rootgrp.title = f"Monthly bias ratio for IMERG / {back_source}" - rootgrp.institution = "NASA GSFC" now = datetime.datetime.utcnow() + history = "created on date: " history += f"{now.year:04d}-{now.month:02d}-{now.day:02d}" history += f"T{now.hour:02d}:{now.minute:02d}:{now.second:02d}" + + rootgrp = nc4_dataset(args['outfile'], "w", format="NETCDF4") + rootgrp.missing_value = np.float32("-9999.") + rootgrp.title = f"Monthly bias ratio for IMERG / {args['backsource']}" + rootgrp.institution = "NASA GSFC" + rootgrp.history = f"created on date: {history}" rootgrp.comment = "website: http://lis.gsfc.nasa.gov/" rootgrp.MAP_PROJECTION = "EQUIDISTANT CYLINDRICAL" @@ -143,8 +237,10 @@ def _main(): # Define dimensions months = rootgrp.createDimension("months", 12) - north_south = rootgrp.createDimension("north_south", north_south) - east_west = rootgrp.createDimension("east_west", east_west) + north_south = rootgrp.createDimension("north_south", \ + args['north_south']) + east_west = rootgrp.createDimension("east_west", \ + args['east_west']) # Define latitude latitude = rootgrp.createVariable("latitude", "f4", \ @@ -170,20 +266,40 @@ def _main(): biasRatio = rootgrp.createVariable("biasRatio", "f4", \ ("months", "north_south", "east_west",)) biasRatio.units = "-" - biasRatio.long_name = f"bias_ratio_for_{back_source}_precipitation" + biasRatio.long_name = \ + f"bias_ratio_for_{args['backsource']}_precipitation" biasRatio.scale_factor = np.float32("1.") biasRatio.add_offset = np.float32("0.") biasRatio.missing_value = np.float32("-9999.") - latitude[:,:] = lats_imerg[:,:] - longitude[:,:] = lons_imerg[:,:] - - precip_ratio[:,:,:] = sum_blended[:,:,:] / sum_back[:,:,:] - precip_ratio[:,:,:] = np.where(precip_ratio == 0, 1, precip_ratio) - biasRatio[:,:,:] = precip_ratio[:,:,:] + latitude[:,:] = args['lats_imerg'][:,:] + longitude[:,:] = args['lons_imerg'][:,:] + biasRatio[:,:,:] = args['precip_ratio'][:,:,:] rootgrp.close() +def _main(): + """Main driver""" + + cfgfile, backsource, startdate, enddate = _process_cmd_line() + backindir, backoutdir, imergdir = \ + _process_cfg_file(cfgfile, backsource) + lats_imerg, lons_imerg, precip_ratio, east_west, north_south = \ + _calc_biasratios(imergdir, backindir, startdate, enddate) + outfile = _create_output_filename(backoutdir, backsource, + startdate, enddate) + # To satisfy pylint.... + args = { + "outfile" : outfile, + "backoutdir" : backoutdir, + "backsource" : backsource, + "north_south" : north_south, + "east_west" : east_west, + "lats_imerg" : lats_imerg, + "lons_imerg" : lons_imerg, + "precip_ratio" : precip_ratio, + } + _write_biasratios(args) if __name__ == "__main__": _main() From 6927a6bfec0f12d79a4d388e2b5c10fd4b0e420e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 5 Oct 2023 13:39:42 -0400 Subject: [PATCH 177/328] Revised code to only use single output directory. --- lvt/utils/usaf/nafpa/biasratio.cfg | 17 +++++++++++++++++ .../calc_gfsgalwem_biasratios_multiyear.py | 17 ++++++++--------- 2 files changed, 25 insertions(+), 9 deletions(-) create mode 100644 lvt/utils/usaf/nafpa/biasratio.cfg diff --git a/lvt/utils/usaf/nafpa/biasratio.cfg b/lvt/utils/usaf/nafpa/biasratio.cfg new file mode 100644 index 000000000..c8ea41fa9 --- /dev/null +++ b/lvt/utils/usaf/nafpa/biasratio.cfg @@ -0,0 +1,17 @@ +# +# Entries for calc_gfsgalwem_biasratios_multiyear.py +# + +[Input] +gfsdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GFS_NAFPA_Monthly_all + +galwemdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GALWEM_NAFPA_Monthly_all + +imergdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/IMERGF_V07A_NAFPA_Monthly + +[Output] +outdir: biasratios + + + + diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index 9b98dd40f..067b6a4f1 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -95,13 +95,12 @@ def _process_cfg_file(cfgfile, backsource): if backsource == "GFS": backindir = config.get('Input', 'gfsdir') - backoutdir = config.get('Output', 'gfsdir') elif backsource == "GALWEM": backindir = config.get('Input', 'galwemdir') - backoutdir = config.get('Output', 'galwemdir') imergdir = config.get('Input', 'imergdir') + outdir = config.get('Output', 'outdir') - return backindir, backoutdir, imergdir + return backindir, imergdir, outdir def _calc_biasratios(imergdir, backindir, startdate, enddate): """Calculate the bias ratios from the input data files.""" @@ -203,9 +202,9 @@ def _calc_biasratios(imergdir, backindir, startdate, enddate): return lats_imerg, lons_imerg, precip_ratio, east_west, north_south -def _create_output_filename(backoutdir, backsource, startdate, enddate): +def _create_output_filename(outdir, backsource, startdate, enddate): """Create output netCDF file name""" - filename = f"{backoutdir}" + filename = f"{outdir}" filename += f"/{backsource}_pcp_biasratios_" filename += f"{startdate.year:04d}{startdate.month:02d}_" filename += f"{enddate.year:04d}{enddate.month:02d}.nc" @@ -214,7 +213,7 @@ def _create_output_filename(backoutdir, backsource, startdate, enddate): def _write_biasratios(args): """Write out bias ratios to netCDF file""" - os.makedirs(args['backoutdir'], exist_ok=True) + os.makedirs(args['outdir'], exist_ok=True) now = datetime.datetime.utcnow() @@ -282,16 +281,16 @@ def _main(): """Main driver""" cfgfile, backsource, startdate, enddate = _process_cmd_line() - backindir, backoutdir, imergdir = \ + backindir, imergdir, outdir = \ _process_cfg_file(cfgfile, backsource) lats_imerg, lons_imerg, precip_ratio, east_west, north_south = \ _calc_biasratios(imergdir, backindir, startdate, enddate) - outfile = _create_output_filename(backoutdir, backsource, + outfile = _create_output_filename(outdir, backsource, startdate, enddate) # To satisfy pylint.... args = { "outfile" : outfile, - "backoutdir" : backoutdir, + "outdir" : outdir, "backsource" : backsource, "north_south" : north_south, "east_west" : east_west, From bd690dbd9b2ba715e059650987d6ecc50e19b671 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 6 Oct 2023 09:14:15 -0400 Subject: [PATCH 178/328] Removed dead code. --- .../calc_gfsgalwem_biasratios_multiyear.py | 27 ------------------- 1 file changed, 27 deletions(-) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index 067b6a4f1..be534d002 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -20,33 +20,6 @@ from netCDF4 import Dataset as nc4_dataset import numpy as np -# Start and end date of GFS period for NAFPA -back_source = "GFS" -#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # GFS-Spectral -#enddt = datetime.datetime(2019, 6, 1, 0, 0, 0) # GFS-Spectral -#startdt = datetime.datetime(2019, 7, 1, 0, 0, 0) # GFS-FV3 -#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # GFS-FV3 -#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # All GFS -#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # All GFS -#startdt = datetime.datetime(2008, 1, 1, 0, 0, 0) # Pre-GALWEM -#enddt = datetime.datetime(2017, 9, 1, 0, 0, 0) # Pre-GALWEM -startdt = datetime.datetime(2017, 10, 1, 0, 0, 0) # GALWEM Era -enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) # GALWEM Era - -topdir_back = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GFS_NAFPA_Monthly_all" - -# Start and end date of GALWEM period for NAFPA -#back_source = "GALWEM" -#startdt = datetime.datetime(2017, 10, 1, 0, 0, 0) -#enddt = datetime.datetime(2023, 4, 1, 0, 0, 0) -#topdir_back = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/GALWEM_NAFPA_Monthly_all" - -timedelta = datetime.timedelta(days=1) - -# Other data -topdir_imergf = "/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_imergf_biascorr/data/IMERGF_V07A_NAFPA_Monthly" -topdir_biasratio = f"testdir_{back_source}" - def _usage(): """Print usage message for this script.""" print(f"Usage: {sys.argv[0]} CFGFILE BACKSOURCE STARTDATE ENDDATE") From 88dd51755330494f2cdcc540d31e4be94f74ceaf Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 6 Oct 2023 09:43:13 -0400 Subject: [PATCH 179/328] Added log10 transform to output file for plotting. --- .../nafpa/calc_gfsgalwem_biasratios_multiyear.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index be534d002..1be185a43 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -10,6 +10,7 @@ REVISION HISTORY: 04 Oct 2023: Eric Kemp: Initial specification. +06 Oct 2023: Eric Kemp: Added log10 transform to output for plotting. """ import configparser @@ -244,9 +245,20 @@ def _write_biasratios(args): biasRatio.add_offset = np.float32("0.") biasRatio.missing_value = np.float32("-9999.") + # Define log10BiasRatio + log10BiasRatio = rootgrp.createVariable("log10BiasRatio", "f4", \ + ("months", "north_south", "east_west",)) + log10BiasRatio.units = "-" + log10BiasRatio.long_name = \ + f"log10_bias_ratio_for_{args['backsource']}_precipitation" + log10BiasRatio.scale_factor = np.float32("1.") + log10BiasRatio.add_offset = np.float32("0.") + log10BiasRatio.missing_value = np.float32("-9999.") + latitude[:,:] = args['lats_imerg'][:,:] longitude[:,:] = args['lons_imerg'][:,:] biasRatio[:,:,:] = args['precip_ratio'][:,:,:] + log10BiasRatio[:,:,:] = np.log10(args['precip_ratio'][:,:,:]) rootgrp.close() From 886df022763ec1611405d5ca56f49ba3c4a59dac Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 6 Oct 2023 10:15:13 -0400 Subject: [PATCH 180/328] Some refactoring to appease pylint. --- .../calc_gfsgalwem_biasratios_multiyear.py | 131 ++++++++++-------- 1 file changed, 77 insertions(+), 54 deletions(-) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index 1be185a43..d30c92080 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -18,7 +18,11 @@ import os import sys +# Disable false alarm in pylint (Dataset is not visible in netCDF4 module +# because it is not implemented in python) +# pylint: disable=no-name-in-module from netCDF4 import Dataset as nc4_dataset +# pylint: enable=no-name-in-module import numpy as np def _usage(): @@ -76,16 +80,20 @@ def _process_cfg_file(cfgfile, backsource): return backindir, imergdir, outdir +def _create_arrays(): + """Allocate and zero out numpy arrays""" + nlat = 1920 + nlon = 2560 + nmon = 12 + sum_blended = np.zeros([nmon,nlat,nlon]) + sum_back = np.zeros([nmon,nlat,nlon]) + precip_ratio = np.zeros([nmon,nlat,nlon]) + return sum_blended, sum_back, precip_ratio + def _calc_biasratios(imergdir, backindir, startdate, enddate): """Calculate the bias ratios from the input data files.""" - ny = 1920 - nx = 2560 - nmon = 12 - - sum_blended = np.zeros([nmon,ny,nx]) - sum_back = np.zeros([nmon,ny,nx]) - precip_ratio = np.zeros([nmon,ny,nx]) + sum_blended, sum_back, precip_ratio = _create_arrays() timedelta = datetime.timedelta(days=1) @@ -184,6 +192,54 @@ def _create_output_filename(outdir, backsource, startdate, enddate): filename += f"{enddate.year:04d}{enddate.month:02d}.nc" return filename +def _create_latitude(rootgrp): + """Create latitude dataset in output file""" + latitude = rootgrp.createVariable("latitude", "f4", \ + ("north_south", "east_west",)) + latitude.units = "degree_north" + latitude.standard_name = "latitude" + latitude.long_name = "latitude" + latitude.scale_factor = np.float32("1.") + latitude.add_offset = np.float32("0.") + latitude.missing_value = np.float32("-9999.") + return latitude + +def _create_longitude(rootgrp): + """Create longitude dataset in output file.""" + longitude = rootgrp.createVariable("longitude", "f4", \ + ("north_south", "east_west",)) + longitude.units = "degree_east" + longitude.standard_name = "longitude" + longitude.long_name = "longitude" + longitude.scale_factor = np.float32("1.") + longitude.add_offset = np.float32("0.") + longitude.missing_value = np.float32("-9999.") + return longitude + +def _create_bias_ratio(rootgrp, backsource): + """Create the biasRatio dataset in the output file.""" + bias_ratio = rootgrp.createVariable("biasRatio", "f4", \ + ("months", "north_south", "east_west",)) + bias_ratio.units = "-" + bias_ratio.long_name = \ + f"bias_ratio_for_{backsource}_precipitation" + bias_ratio.scale_factor = np.float32("1.") + bias_ratio.add_offset = np.float32("0.") + bias_ratio.missing_value = np.float32("-9999.") + return bias_ratio + +def _create_log10_bias_ratio(rootgrp, backsource): + """Create the log10BiasRatio dataset in the output file.""" + log10_bias_ratio = rootgrp.createVariable("log10BiasRatio", "f4", \ + ("months", "north_south", "east_west",)) + log10_bias_ratio.units = "-" + log10_bias_ratio.long_name = \ + f"log10_bias_ratio_for_{backsource}_precipitation" + log10_bias_ratio.scale_factor = np.float32("1.") + log10_bias_ratio.add_offset = np.float32("0.") + log10_bias_ratio.missing_value = np.float32("-9999.") + return log10_bias_ratio + def _write_biasratios(args): """Write out bias ratios to netCDF file""" @@ -209,56 +265,23 @@ def _write_biasratios(args): rootgrp.DY = np.float32("0.09375") # Define dimensions - months = rootgrp.createDimension("months", 12) - north_south = rootgrp.createDimension("north_south", \ - args['north_south']) - east_west = rootgrp.createDimension("east_west", \ - args['east_west']) - - # Define latitude - latitude = rootgrp.createVariable("latitude", "f4", \ - ("north_south", "east_west",)) - latitude.units = "degree_north" - latitude.standard_name = "latitude" - latitude.long_name = "latitude" - latitude.scale_factor = np.float32("1.") - latitude.add_offset = np.float32("0.") - latitude.missing_value = np.float32("-9999.") - - # Define longitude - longitude = rootgrp.createVariable("longitude", "f4", \ - ("north_south", "east_west",)) - longitude.units = "degree_east" - longitude.standard_name = "longitude" - longitude.long_name = "longitude" - longitude.scale_factor = np.float32("1.") - longitude.add_offset = np.float32("0.") - longitude.missing_value = np.float32("-9999.") - - # Define biasRatio - biasRatio = rootgrp.createVariable("biasRatio", "f4", \ - ("months", "north_south", "east_west",)) - biasRatio.units = "-" - biasRatio.long_name = \ - f"bias_ratio_for_{args['backsource']}_precipitation" - biasRatio.scale_factor = np.float32("1.") - biasRatio.add_offset = np.float32("0.") - biasRatio.missing_value = np.float32("-9999.") - - # Define log10BiasRatio - log10BiasRatio = rootgrp.createVariable("log10BiasRatio", "f4", \ - ("months", "north_south", "east_west",)) - log10BiasRatio.units = "-" - log10BiasRatio.long_name = \ - f"log10_bias_ratio_for_{args['backsource']}_precipitation" - log10BiasRatio.scale_factor = np.float32("1.") - log10BiasRatio.add_offset = np.float32("0.") - log10BiasRatio.missing_value = np.float32("-9999.") + rootgrp.createDimension("months", 12) + rootgrp.createDimension("north_south", \ + args['north_south']) + rootgrp.createDimension("east_west", \ + args['east_west']) + + # Define output variables + latitude = _create_latitude(rootgrp) + longitude = _create_longitude(rootgrp) + bias_ratio = _create_bias_ratio(rootgrp, args['backsource']) + log10_bias_ratio = _create_log10_bias_ratio(rootgrp, + args['backsource']) latitude[:,:] = args['lats_imerg'][:,:] longitude[:,:] = args['lons_imerg'][:,:] - biasRatio[:,:,:] = args['precip_ratio'][:,:,:] - log10BiasRatio[:,:,:] = np.log10(args['precip_ratio'][:,:,:]) + bias_ratio[:,:,:] = args['precip_ratio'][:,:,:] + log10_bias_ratio[:,:,:] = np.log10(args['precip_ratio'][:,:,:]) rootgrp.close() From f0bfb64a4c7882fe18b3414602761952c309dbb7 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 6 Oct 2023 12:15:57 -0400 Subject: [PATCH 181/328] Refactored to appease pylint. --- .../calc_gfsgalwem_biasratios_multiyear.py | 185 +++++++++++------- 1 file changed, 114 insertions(+), 71 deletions(-) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index d30c92080..4d2e12b45 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -11,6 +11,7 @@ REVISION HISTORY: 04 Oct 2023: Eric Kemp: Initial specification. 06 Oct 2023: Eric Kemp: Added log10 transform to output for plotting. + Refactored to please pylint. """ import configparser @@ -90,88 +91,127 @@ def _create_arrays(): precip_ratio = np.zeros([nmon,nlat,nlon]) return sum_blended, sum_back, precip_ratio -def _calc_biasratios(imergdir, backindir, startdate, enddate): +def _read_imerg_file(imergdir, nextdate): + """Read the interpolated monthly IMERG file.""" + filename = f"{imergdir}/SUM_TS." + filename += f"{nextdate.year:04d}{nextdate.month:02d}" + filename += f"{nextdate.day:02d}0000.d01.nc" + ncid_imerg = nc4_dataset(filename, mode='r', \ + format="NETCDF4_CLASSIC") + precip_imerg = ncid_imerg.variables['TotalPrecip'][:,:] + del ncid_imerg + return precip_imerg + +def _read_imerg_file_latlondims(imergdir, startdate): + """Read the interpolated monthly IMERG file.""" + nextdate = _get_nextdate(startdate) + filename = f"{imergdir}/SUM_TS." + filename += f"{nextdate.year:04d}{nextdate.month:02d}" + filename += f"{nextdate.day:02d}0000.d01.nc" + ncid_imerg = nc4_dataset(filename, mode='r', \ + format="NETCDF4_CLASSIC") + lats_imerg = ncid_imerg.variables["latitude"][:,:] + lons_imerg = ncid_imerg.variables["longitude"][:,:] + north_south = ncid_imerg.dimensions['north_south'].size + east_west = ncid_imerg.dimensions['east_west'].size + del ncid_imerg + return lats_imerg, lons_imerg, north_south, east_west + +def _read_background_file(backindir, nextdate): + """Read interpolated monthly background file.""" + filename = f"{backindir}/SUM_TS." + filename += f"{nextdate.year:04d}{nextdate.month:02d}" + filename += f"{nextdate.day:02d}0000.d01.nc" + ncid_back = nc4_dataset(filename, mode='r', \ + format="NETCDF4_CLASSIC") + precip_back = ncid_back.variables['TotalPrecip'][:,:] + del ncid_back + return precip_back + +def _calc_precip_blended(lats_imerg, precip_imerg, precip_back): + """Calculate weighted blend of IMERG and background precip""" + + # Use IMERG from 40S to 71N; use linear tapers from 40S to 60S, + # and 51N to 71N; and don't use IMERG south of 60S and north of + # 71N. Rationale: No IR and little gauge data is available + # south of 60S, so we don't expect IMERG to be useful here for + # bias correction. In the northern hemisphere, there is no IR data + # north of 60N, but there is good GPCC gauge density in Scandinavia + # up to 71N. Finally, the 20 degree latitude linear tapers mimicks + # MERRA-2 usage of CPCU gauge analyses. + precip_imerg_weights = np.ones(np.shape(lats_imerg)) + precip_imerg_weights = np.where(lats_imerg < -60, + 0, + precip_imerg_weights) + precip_imerg_weights = np.where( (lats_imerg >= -60) & + (lats_imerg < -40), + ( (lats_imerg + 60.) / 20.), + precip_imerg_weights) + precip_imerg_weights = np.where( (lats_imerg > 51) & + (lats_imerg <= 71), + ( (71. - lats_imerg) / 20.), + precip_imerg_weights) + precip_imerg_weights = np.where(lats_imerg > 71, + 0, + precip_imerg_weights) + + # Conservative alternative: Linear taper from 40N to 60N, and + # screen out everything north of 60N. We'll do this as a backup + # if we find unphysical IMERG patterns north of 60N + #precip_imerg_weights = np.where( (lats_imerg > 40) & + # (lats_imerg <= 60), + # ( (60. - lats_imerg) / 20.), + # precip_imerg_weights) + #precip_imerg_weights = np.where(lats_imerg > 60, + # 0, + # precip_imerg_weights) + + precip_blended = precip_imerg_weights[:,:]*precip_imerg[:,:] + \ + (1. - precip_imerg_weights[:,:])*precip_back[:,:] + + return precip_blended + +def _get_nextdate(curdate): + """Determine next date (first of next month)""" + # LVT output files have data from the prior month, so we must + # advance one month to find the appropriate file, e.g., data + # for May 2020 will be in SUM_TS.202006010000.d01.nc. Python's + # timedelta object isn't smart enough to jump a whole month, so + # we loop through each day instead. + timedelta = datetime.timedelta(days=1) + nextdate = curdate + timedelta + while nextdate.day != 1: + nextdate += timedelta + return nextdate + +def _calc_biasratios(imergdir, backindir, startdate, enddate, lats_imerg): """Calculate the bias ratios from the input data files.""" sum_blended, sum_back, precip_ratio = _create_arrays() - timedelta = datetime.timedelta(days=1) - # Loop through each month curdate = startdate while curdate <= enddate: # LVT output files have data from the prior month, so we must # advance one month to find the appropriate file, e.g., data - # for May 2020 will be in SUM_TS.202006010000.d01.nc. Python's - # timedelta object isn't smart enough to jump a whole month, so - # we loop through each day instead. - nextdate = curdate + timedelta - while nextdate.day != 1: - nextdate += timedelta + # for May 2020 will be in SUM_TS.202006010000.d01.nc. + nextdate = _get_nextdate(curdate) # First, the IMERG file - filename = f"{imergdir}/SUM_TS." - filename += f"{nextdate.year:04d}{nextdate.month:02d}" - filename += f"{nextdate.day:02d}0000.d01.nc" - ncid_imerg = nc4_dataset(filename, mode='r', \ - format="NETCDF4_CLASSIC") - precip_imerg = ncid_imerg.variables['TotalPrecip'][:,:] - lats_imerg = ncid_imerg.variables["latitude"][:,:] - lons_imerg = ncid_imerg.variables["longitude"][:,:] - north_south = ncid_imerg.dimensions['north_south'].size - east_west = ncid_imerg.dimensions['east_west'].size - del ncid_imerg + precip_imerg = \ + _read_imerg_file(imergdir, nextdate) # Next, the background data (GFS or GALWEM) - filename = f"{backindir}/SUM_TS." - filename += f"{nextdate.year:04d}{nextdate.month:02d}" - filename += f"{nextdate.day:02d}0000.d01.nc" - ncid_back = nc4_dataset(filename, mode='r', \ - format="NETCDF4_CLASSIC") - precip_back = ncid_back.variables['TotalPrecip'][:,:] - del ncid_back - - # Use IMERG from 40S to 71N; use linear tapers from 40S to 60S, - # and 51N to 71N; and don't use IMERG south of 60S and north of - # 71N. Rationale: No IR and little gauge data is available - # south of 60S, so we don't expect IMERG to be useful here. - # In the northern hemisphere, there is no IR data north of 60N, - # but there is good GPCC gauge density in Scandinavia up to 71N. - # Finally, the 20 degree latitude linear taper mimicks MERRA-2 - # usage of CPCU gauge analyses. - precip_imerg_weights = np.ones(np.shape(lats_imerg)) - precip_imerg_weights = np.where(lats_imerg < -60, - 0, - precip_imerg_weights) - precip_imerg_weights = np.where( (lats_imerg >= -60) & - (lats_imerg < -40), - ( (lats_imerg + 60.) / 20.), - precip_imerg_weights) - precip_imerg_weights = np.where( (lats_imerg > 51) & - (lats_imerg <= 71), - ( (71. - lats_imerg) / 20.), - precip_imerg_weights) - precip_imerg_weights = np.where(lats_imerg > 71, - 0, - precip_imerg_weights) - - # Conservative alternative: Linear taper from 40N to 60N, and - # screen out everything north of 60N. We'll do this as a backup - # if we find unphysical IMERG patterns north of 60N - #precip_imerg_weights = np.where( (lats_imerg > 40) & - # (lats_imerg <= 60), - # ( (60. - lats_imerg) / 20.), - # precip_imerg_weights) - #precip_imerg_weights = np.where(lats_imerg > 60, - # 0, - # precip_imerg_weights) - - precip_blended = precip_imerg_weights[:,:]*precip_imerg[:,:] + \ - (1. - precip_imerg_weights[:,:])*precip_back[:,:] - - # Add trace precipitation every month to prevent undefined - # ratios in deserts. + precip_back = _read_background_file(backindir, nextdate) + + # Calculate blended precipitation (weighted average of IMERG + # and background, varying by latitude). + precip_blended = \ + _calc_precip_blended(lats_imerg, precip_imerg, precip_back) + + # Updated precip sums. Add trace precipitation every month to + # prevent undefined ratios in deserts. sum_blended[(curdate.month-1),:,:] += precip_blended[:,:] + 0.05 sum_back[(curdate.month-1),:,:] += precip_back[:,:] + 0.05 @@ -182,7 +222,7 @@ def _calc_biasratios(imergdir, backindir, startdate, enddate): precip_ratio[:,:,:] = sum_blended[:,:,:] / sum_back[:,:,:] precip_ratio[:,:,:] = np.where(precip_ratio == 0, 1, precip_ratio) - return lats_imerg, lons_imerg, precip_ratio, east_west, north_south + return precip_ratio def _create_output_filename(outdir, backsource, startdate, enddate): """Create output netCDF file name""" @@ -291,8 +331,11 @@ def _main(): cfgfile, backsource, startdate, enddate = _process_cmd_line() backindir, imergdir, outdir = \ _process_cfg_file(cfgfile, backsource) - lats_imerg, lons_imerg, precip_ratio, east_west, north_south = \ - _calc_biasratios(imergdir, backindir, startdate, enddate) + lats_imerg, lons_imerg, north_south, east_west = \ + _read_imerg_file_latlondims(imergdir, startdate) + precip_ratio = \ + _calc_biasratios(imergdir, backindir, startdate, enddate, \ + lats_imerg) outfile = _create_output_filename(outdir, backsource, startdate, enddate) # To satisfy pylint.... From a18cca2df55f6f2cb2785bb34c24c804dd445654 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 6 Oct 2023 16:27:30 -0400 Subject: [PATCH 182/328] Added print statements for when bias ratio data are read in. Also, minor code clean up. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 3995698ec..cc4754641 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -6464,9 +6464,7 @@ subroutine USAF_pcpBackBiasRatio_s2s(n, yyyymmddhh) ! Imports use AGRMET_forcingMod, only: agrmet_struc - use LIS_coreMod, only: LIS_rc!, LIS_localPet, & - !LIS_ews_halo_ind, LIS_ewe_halo_ind, & - !LIS_nss_halo_ind, LIS_nse_halo_ind + use LIS_coreMod, only: LIS_rc use LIS_logMod, only: LIS_logunit, LIS_endrun, LIS_verify #if ( defined USE_NETCDF3 || defined USE_NETCDF4 ) use netcdf @@ -6598,6 +6596,9 @@ subroutine USAF_pcpBackBiasRatio_nrt(n, yyyymmddhh) start=(/1,1,imonth/), & count=(/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)), & 'n90_get_var failed for biasRatio in LIS param file') + write(LIS_logunit,*) & + '[INFO] Read GFS bias ratios for month ', imonth, & + ' from ', trim(agrmet_struc(n)%gfs_nrt_bias_ratio_file) call LIS_verify(nf90_close(ncid),& 'nf90_close failed in USAF_pcpBackBiasRatio_nrt') @@ -6620,6 +6621,9 @@ subroutine USAF_pcpBackBiasRatio_nrt(n, yyyymmddhh) start=(/1,1,imonth/), & count=(/LIS_rc%gnc(n),LIS_rc%gnr(n),1/)),& 'n90_get_var failed for biasRatio in LIS param file') + write(LIS_logunit,*) & + '[INFO] Read GALWEM bias ratios for month ', imonth, & + ' from ', trim(agrmet_struc(n)%galwem_nrt_bias_ratio_file) call LIS_verify(nf90_close(ncid),& 'nf90_close failed in USAF_pcpBackBiasRatio_nrt') From b6cd67f4d00649b80af64a38f68423ed66dba139 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 10 Oct 2023 14:04:48 -0400 Subject: [PATCH 183/328] Updated LVT documentation to add "GPM IMERG Monthly" datastream. --- lvt/configs/lvt.config.adoc | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/lvt/configs/lvt.config.adoc b/lvt/configs/lvt.config.adoc index 9ba94fea5..0c3f15a93 100644 --- a/lvt/configs/lvt.config.adoc +++ b/lvt/configs/lvt.config.adoc @@ -118,6 +118,7 @@ LVT output methodology: "2d gridspace" | "`ANSA SWE`" | ANSA SWE retrievals | "`CPC precipitation`" | CPC unified precipitation product | "`GPM IMERG`" | IMERG precipitation data product +| "`GPM IMERG Monthly`" | IMERG-Monthly precipitation product | "`USGS streamflow`" | USGS streamflow observations | "`Naturalized streamflow`" | Naturalized streamflow estimates | "`FLUXNET MTE`" | Gridded FLUXNET MTE data from MPI @@ -1276,6 +1277,21 @@ IMERG version: V06B IMERG product: final .... +==== GPM IMERG Monthly precipitation data + +`IMERG monthly data directory:` specifies the location of the GPM IMERG Monthly precipitation product + +`IMERG monthly version:` specifies the version of the GPM IMERG Monthly precipitation product. Most current version is V07A. + +`IMERG monthly product:` specifies the GPM IMERG Monthly precipitation product. Current option is: final. (early and late will be added later) + +.Example _lvt.config_ entry +.... +IMERG monthly data directory: input/IMERGF_V07A_Monthly +IMERG monthly version: V07A +IMERG monthly product: final +.... + ==== ESA CCI soil moisture data `ESA CCI soil moisture data directory:` specifies the location of the ESA CCI soil moisture data From 5a8da7c08954def1fa8c31195f256df4690aa5ff Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 12 Oct 2023 12:07:52 -0400 Subject: [PATCH 184/328] Enable compiling RTM support with GNU compilers --- docs/LISF_installation_guide/dependencies.adoc | 10 +++++++--- lis/lib/lis-cmem3/Makefile | 11 +++++++++++ lis/lib/lis-crtm-profile-utility/make.macros | 9 ++++++++- 3 files changed, 26 insertions(+), 4 deletions(-) diff --git a/docs/LISF_installation_guide/dependencies.adoc b/docs/LISF_installation_guide/dependencies.adoc index 105c6ecae..a0dc3965a 100644 --- a/docs/LISF_installation_guide/dependencies.adoc +++ b/docs/LISF_installation_guide/dependencies.adoc @@ -163,9 +163,11 @@ If you wish to enable LIS' RTM support, then you must manually compile an includ .... % cd $WORKING/lib/lis-cmem3 -% gmake +% LIS_ARCH=linux_ifc make .... +NOTE: If using the GNU compilers, set `LIS_ARCH` to linux_gfortran. + ==== LIS-CRTM-PROFILE-UTILITY library NOTE: LIS-only dependency @@ -174,10 +176,12 @@ If you wish to enable LIS' RTM support, then you must manually compile an includ .... % cd $WORKING/lib/lis-crtm-profile-utility -% gmake -% gmake install +% LIS_ARCH=linux_ifc make +% LIS_ARCH=linux_ifc make install .... +NOTE: If using the GNU compilers, set `LIS_ARCH` to linux_gfortran. + === Second order dependencies ==== OpenJPEG version 2.4.0 (or higher) diff --git a/lis/lib/lis-cmem3/Makefile b/lis/lib/lis-cmem3/Makefile index 08ca37f91..29bbfac7d 100644 --- a/lis/lib/lis-cmem3/Makefile +++ b/lis/lib/lis-cmem3/Makefile @@ -1,13 +1,24 @@ # Compiler/Linker +ifeq ($(LIS_ARCH),linux_ifc) FC = ifort LD = ifort +else ifeq ($(LIS_ARCH),linux_gfortran) +FC = gfortran +LD = gfortran +else +$(error "Please specify compiler via LIS_ARCH env variable") +endif # compiler/linker flags # Compile with DEBUG messages #FCFLAGS = -DDEBUG -fpp -g -u -traceback -fpe0 -nomixed_str_len_arg -names lowercase -convert big_endian -assume byterecl -I/home/ytian/proj-disk/libs/CRTM_Profile_Utility_intel_11_1_038/include # Compile without DEBUG messages +ifeq ($(LIS_ARCH),linux_ifc) FCFLAGS = -fpp -g -u -traceback -fpe0 -nomixed_str_len_arg -names lowercase -convert big_endian -assume byterecl +else ifeq ($(LIS_ARCH),linux_gfortran) +FCFLAGS = -cpp -g -u -fbacktrace -ffpe-trap=invalid,zero,overflow -fconvert=big-endian +endif #-I/home/ytian/proj-disk/libs/CRTM_Profile_Utility_intel_11_1_038/include #LIBS = /home/ytian/proj-disk/libs/CRTM_Profile_Utility_intel_11_1_038/lib/libProfile_Utility.a diff --git a/lis/lib/lis-crtm-profile-utility/make.macros b/lis/lib/lis-crtm-profile-utility/make.macros index 400645d5b..40eee2488 100755 --- a/lis/lib/lis-crtm-profile-utility/make.macros +++ b/lis/lib/lis-crtm-profile-utility/make.macros @@ -509,8 +509,15 @@ LINUX_FLAGS_ABSOFT_PROD = $(LINUX_FLAGS_ABSOFT) #LINUX_FLAGS = $(LINUX_FLAGS_LAHEY) #LINUX_FLAGS = $(LINUX_FLAGS_PGI) -LINUX_FLAGS = $(LINUX_FLAGS_INTEL) +#LINUX_FLAGS = $(LINUX_FLAGS_INTEL) #LINUX_FLAGS = $(LINUX_FLAGS_G95) #LINUX_FLAGS = $(LINUX_FLAGS_GFORTRAN) #LINUX_FLAGS = $(LINUX_FLAGS_ABSOFT) +ifeq ($(LIS_ARCH),linux_ifc) +LINUX_FLAGS = $(LINUX_FLAGS_INTEL) +else ifeq ($(LIS_ARCH),linux_gfortran) +LINUX_FLAGS = $(LINUX_FLAGS_GFORTRAN) +else +$(error "Please specify compiler via LIS_ARCH env variable") +endif From 22fdc8d4f06ab1246a55bbaebd412d1cf73ee757 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 12 Oct 2023 15:09:17 -0400 Subject: [PATCH 185/328] Note that linux_ifc and linux_gfortran are the only supported architectures for the RTM libraries --- docs/LISF_installation_guide/dependencies.adoc | 10 +++++++--- lis/lib/lis-cmem3/Makefile | 2 +- lis/lib/lis-crtm-profile-utility/make.macros | 2 +- 3 files changed, 9 insertions(+), 5 deletions(-) diff --git a/docs/LISF_installation_guide/dependencies.adoc b/docs/LISF_installation_guide/dependencies.adoc index a0dc3965a..a6eba4131 100644 --- a/docs/LISF_installation_guide/dependencies.adoc +++ b/docs/LISF_installation_guide/dependencies.adoc @@ -133,7 +133,7 @@ NOTE: LDT-only dependency NOTE: LIS-only dependency -If you wish to enable LIS' RTM support, then you must install the CRTM library from the Joint Centers for Satellite Data Assimilation (JCSDA). First go to http://ftp.emc.ncep.noaa.gov/jcsda/CRTM/Repository/ and fill out the CRTM.Subversion_Account_Request.pdf form. Once you have access to their Subversion repository, checkout revision 9604 of the trunk. +If you wish to enable LIS`' RTM support, then you must install the CRTM library from the Joint Centers for Satellite Data Assimilation (JCSDA). First go to http://ftp.emc.ncep.noaa.gov/jcsda/CRTM/Repository/ and fill out the CRTM.Subversion_Account_Request.pdf form. Once you have access to their Subversion repository, checkout revision 9604 of the trunk. Please create a directory outside of the LIS source code to checkout the CRTM library into. Then, within that new directory, run: @@ -159,7 +159,7 @@ Next compile and install the CRTM library: NOTE: LIS-only dependency -If you wish to enable LIS' RTM support, then you must manually compile an included library. +If you wish to enable LIS`' RTM support, then you must manually compile an included library. .... % cd $WORKING/lib/lis-cmem3 @@ -168,11 +168,13 @@ If you wish to enable LIS' RTM support, then you must manually compile an includ NOTE: If using the GNU compilers, set `LIS_ARCH` to linux_gfortran. +IMPORTANT: linux_ifc and linux_gfortran are the only supported architectures. + ==== LIS-CRTM-PROFILE-UTILITY library NOTE: LIS-only dependency -If you wish to enable LIS' RTM support, then you must manually compile an included library. +If you wish to enable LIS`' RTM support, then you must manually compile an included library. .... % cd $WORKING/lib/lis-crtm-profile-utility @@ -182,6 +184,8 @@ If you wish to enable LIS' RTM support, then you must manually compile an includ NOTE: If using the GNU compilers, set `LIS_ARCH` to linux_gfortran. +IMPORTANT: linux_ifc and linux_gfortran are the only supported architectures. + === Second order dependencies ==== OpenJPEG version 2.4.0 (or higher) diff --git a/lis/lib/lis-cmem3/Makefile b/lis/lib/lis-cmem3/Makefile index 29bbfac7d..e4466d283 100644 --- a/lis/lib/lis-cmem3/Makefile +++ b/lis/lib/lis-cmem3/Makefile @@ -7,7 +7,7 @@ else ifeq ($(LIS_ARCH),linux_gfortran) FC = gfortran LD = gfortran else -$(error "Please specify compiler via LIS_ARCH env variable") +$(error "Please specify the compiler via the LIS_ARCH env variable. See the LISF Installation Guide for more information.") endif # compiler/linker flags diff --git a/lis/lib/lis-crtm-profile-utility/make.macros b/lis/lib/lis-crtm-profile-utility/make.macros index 40eee2488..b35466570 100755 --- a/lis/lib/lis-crtm-profile-utility/make.macros +++ b/lis/lib/lis-crtm-profile-utility/make.macros @@ -519,5 +519,5 @@ LINUX_FLAGS = $(LINUX_FLAGS_INTEL) else ifeq ($(LIS_ARCH),linux_gfortran) LINUX_FLAGS = $(LINUX_FLAGS_GFORTRAN) else -$(error "Please specify compiler via LIS_ARCH env variable") +$(error "Please specify the compiler via the LIS_ARCH env variable. See the LISF Installation Guide for more information.") endif From 40ca88208a0ee3ca68cba4d4d761e678dce70f63 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 13 Oct 2023 08:58:47 -0400 Subject: [PATCH 186/328] Cleaned up code (indentation, removal of dead code, etc) Test results are unchanged. --- ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 | 145 +++--- .../LISlsmPrecipobs/read_Precip_climo.F90 | 117 +++-- ldt/core/LDT_CDFMod.F90 | 6 +- ldt/core/LDT_DApreprocMod.F90 | 107 ++--- lis/core/LIS_dataAssimMod.F90 | 348 ++++++-------- .../cdfTransfer_NASASMAPsm_Mod.F90 | 214 ++++----- .../read_cdfTransfer_NASASMAPsm.F90 | 431 ++++++------------ lis/plugins/LIS_DAobs_pluginMod.F90 | 3 +- 8 files changed, 539 insertions(+), 832 deletions(-) diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 index 69f85fdf3..5d4f0b7af 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 @@ -26,25 +26,20 @@ subroutine read_Drange(ngrid, filename, varname, xrange) use netcdf #endif - implicit none -! !ARGUMENTS: -! integer, intent(in) :: n -! integer, intent(in) :: k -! integer, intent(in) :: nbins -! integer, intent(in) :: ntimes - integer, intent(in) :: ngrid - character(len=*) :: filename - character(len=*) :: varname - real :: xrange(ngrid,2) - !real :: cdf(ngrid,ntimes, nbins) - -! -! !DESCRIPTION: + implicit none +! !ARGUMENTS: + integer, intent(in) :: ngrid + character(len=*) :: filename + character(len=*) :: varname + real :: xrange(ngrid,2) + +! +! !DESCRIPTION: ! This routine reads the input CDF file (generated by LDT in NETCDF format) -! The xrange values and the corresponding CDFs are read for each grid point. -! Both these fields are expected to be in the 1-d grid vector dimension. -! -! The arguments are: +! The xrange values and the corresponding CDFs are read for each grid point. +! Both these fields are expected to be in the 1-d grid vector dimension. +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest ! \item[nbins] number of bins used to compute the model and obs CDFs @@ -54,67 +49,63 @@ subroutine read_Drange(ngrid, filename, varname, xrange) ! \item[cdf] y-axis (CDF) values corresponding to the CDF ! \end{description} !EOP - integer :: j,kk - integer :: ngridId, nbinsId, nlevsId,ntimesId - integer :: ngrid_file, nbins_file, nlevs_file, ntimes_file - integer :: xid, cdfid - real, allocatable :: xrange_file(:,:,:) - !real, allocatable :: cdf_file(:,:,:) - integer :: nid + integer :: j,kk + integer :: ngridId, nbinsId, nlevsId,ntimesId + integer :: ngrid_file, nbins_file, nlevs_file, ntimes_file + integer :: xid, cdfid + real, allocatable :: xrange_file(:,:,:) + integer :: nid #if(defined USE_NETCDF3 || defined USE_NETCDF4) - write(LDT_logunit,*) '[INFO] Reading Drange form CDF file ',trim(filename) - call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& - ncid=nid),'failed to open file '//trim(filename)) - - call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & - 'nf90_inq_dimid failed for ngrid') - call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & - 'nf90_inq_dimid failed for nbins') - call LDT_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & - 'nf90_inq_dimid failed for '//trim(varname)//"_levels") - call LDT_verify(nf90_inq_dimid(nid,"ntimes",ntimesId), & - 'nf90_inq_dimid failed for ntimes') - - - call LDT_verify(nf90_inquire_dimension(nid,ngridId, len=ngrid_file),& - 'nf90_inquire_dimension failed for ngrid') - call LDT_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& - 'nf90_inquire_dimension failed for nbins') - call LDT_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& - 'nf90_inquire_dimension failed for nbins') - call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& - 'nf90_inquire_dimension failed for ntimes') - - - if (ntimes_file .gt. 1) then - write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& - trim(filename) - write(LDT_logunit,*) '[ERR] (',ntimes_file, & - ') should be 1 set the Temporal resolution of precipitation CDFs to "yearly" ' - call LDT_endrun() - endif - - allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) - - do j=1,ntimes_file - call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& - 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') - - call LDT_verify(nf90_get_var(nid,xid,xrange_file, & - start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& - 'nf90_get_var failed for '//trim(varname)//'_xrange') - - enddo - - xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell - xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell - - deallocate(xrange_file) - - call LDT_verify(nf90_close(nid),& - 'failed to close file '//trim(filename)) - write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) + write(LDT_logunit,*) '[INFO] Reading Drange form CDF file ',trim(filename) + call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) + + call LDT_verify(nf90_inq_dimid(nid,"ngrid",ngridId), & + 'nf90_inq_dimid failed for ngrid') + call LDT_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & + 'nf90_inq_dimid failed for nbins') + call LDT_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & + 'nf90_inq_dimid failed for '//trim(varname)//"_levels") + call LDT_verify(nf90_inq_dimid(nid,"ntimes",ntimesId), & + 'nf90_inq_dimid failed for ntimes') + + call LDT_verify(nf90_inquire_dimension(nid,ngridId, len=ngrid_file),& + 'nf90_inquire_dimension failed for ngrid') + call LDT_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& + 'nf90_inquire_dimension failed for nbins') + call LDT_verify(nf90_inquire_dimension(nid,ntimesId, len=ntimes_file),& + 'nf90_inquire_dimension failed for ntimes') + + if (ntimes_file .gt. 1) then + write(LDT_logunit,*) '[ERR] The number of times specified in the file '//& + trim(filename) + write(LDT_logunit,*) '[ERR] (',ntimes_file, & + ') should be 1 set the Temporal resolution of precipitation CDFs to "yearly" ' + call LDT_endrun() + endif + + allocate(xrange_file(ngrid_file,nlevs_file, nbins_file)) + + do j=1,ntimes_file + call LDT_verify(nf90_inq_varid(nid,trim(varname)//'_xrange',xid),& + 'nf90_inq_varid failed for for '//trim(varname)//'_xrange') + + call LDT_verify(nf90_get_var(nid,xid,xrange_file, & + start=(/1,j,1,1/), count=(/ngrid_file,1,nlevs_file,nbins_file/)),& + 'nf90_get_var failed for '//trim(varname)//'_xrange') + enddo + + xrange(:,1) = xrange_file(:,1,1) ! min value for each gridcell + xrange(:,2) = xrange_file(:,1,nbins_file) ! max value for each gridcell + + deallocate(xrange_file) + + call LDT_verify(nf90_close(nid),& + 'failed to close file '//trim(filename)) + write(LDT_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) #endif end subroutine read_Drange diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 index a97d54259..34fb4f906 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -13,10 +13,10 @@ ! !ROUTINE: read_Precip_climo ! \label{read_Precip_climo} -! !REVISION HISTORY: +! !REVISION HISTORY: ! 19Jan2022: Mahdi Navari ; Initial Specification ! -! !INTERFACE: +! !INTERFACE: subroutine read_Precip_climo(ncol, nrow, filename, precip) use LDT_coreMod @@ -26,19 +26,19 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) use netcdf #endif - implicit none -! !ARGUMENTS: - integer, intent(in) :: ncol, nrow - character(len=*), intent(in) :: filename - real :: precip(ncol,nrow,12) - logical :: file_exists -! -! !DESCRIPTION: + implicit none + ! !ARGUMENTS: + integer, intent(in) :: ncol, nrow + character(len=*), intent(in) :: filename + real :: precip(ncol,nrow,12) + logical :: file_exists +! +! !DESCRIPTION: ! This routine reads the input CDF file (generated by LDT in NETCDF format) -! The xrange values and the corresponding CDFs are read for each grid point. -! Both these fields are expected to be in the 1-d grid vector dimension. -! -! The arguments are: +! The xrange values and the corresponding CDFs are read for each grid point. +! Both these fields are expected to be in the 1-d grid vector dimension. +! +! The arguments are: ! \begin{description} ! \item[n] index of the nest ! \item[nbins] number of bins used to compute the model and obs CDFs @@ -48,67 +48,66 @@ subroutine read_Precip_climo(ncol, nrow, filename, precip) ! \item[cdf] y-axis (CDF) values corresponding to the CDF ! \end{description} !EOP - real, allocatable :: precip_climo(:,:,:) - integer :: ios,nid,ncId,nrId,varId - integer :: nc,nr,i,c,r - character*3 :: month_name(12) - - month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& - "JUL","AUG","SEP","OCT","NOV","DEC"/) + real, allocatable :: precip_climo(:,:,:) + integer :: ios,nid,ncId,nrId,varId + integer :: nc,nr,i,c,r + character*3 :: month_name(12) + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) #if(defined USE_NETCDF3 || defined USE_NETCDF4) inquire(file=trim(filename), exist=file_exists) - if (.not. file_exists) then - write(LDT_logunit,*) '[ERR] (',filename, & - ') does not exist. Please provide a monthly precipitation climatology in CDF format ' - call LDT_endrun() - end if + if (.not. file_exists) then + write(LDT_logunit,*) '[ERR] (',filename, & + ') does not exist. Please provide a monthly precipitation climatology in CDF format ' + call LDT_endrun() + end if + + write(LDT_logunit,*) '[INFO] Reading Precipitation climatology from CDF file ',trim(filename) + call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) - write(LDT_logunit,*) '[INFO] Reading Precipitation climatology from CDF file ',trim(filename) - call LDT_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& - ncid=nid),'failed to open file '//trim(filename)) + ios = nf90_inq_dimid(nid,"east_west",ncId) + call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') - ios = nf90_inq_dimid(nid,"east_west",ncId) - call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + ios = nf90_inq_dimid(nid,"north_south",nrId) + call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') - ios = nf90_inq_dimid(nid,"north_south",nrId) - call LDT_verify(ios,'Error in nf90_inq_dimid in read_precip_climo') + ios = nf90_inquire_dimension(nid,ncId, len=nc) + call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') - ios = nf90_inquire_dimension(nid,ncId, len=nc) - call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + ios = nf90_inquire_dimension(nid,nrId, len=nr) + call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') - ios = nf90_inquire_dimension(nid,nrId, len=nr) - call LDT_verify(ios,'Error in nf90_inquire_dimension in read_precip_climo') + if (ncol .ne. nc .or. nrow .ne.nr) then + write(LDT_logunit,*) & + '[ERR] The number of columns or rows specified in the file '//& + trim(filename) + write(LDT_logunit,*) '[ERR] (', nc, nr, & + ') is different from the number of columns and rows specified' + write(LDT_logunit,*) '[ERR] in the ldt.config file (', ncol, nrow, ')' + call LDT_endrun() + endif - if (ncol .ne. nc .or. nrow .ne.nr) then - write(LDT_logunit,*) & - '[ERR] The number of columns or rows specified in the file '//& - trim(filename) - write(LDT_logunit,*) '[ERR] (', nc, nr, & - ') is different from the number of columns and rows specified' - write(LDT_logunit,*) '[ERR] in the ldt.config file (', ncol, nrow, ')' - call LDT_endrun() - endif + allocate(precip_climo(nc,nr,12)) - allocate(precip_climo(nc,nr,12)) + do i=1,12 + ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) + call LDT_verify(ios,'Precipitation climo field not found in the file') - do i=1,12 - ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) - call LDT_verify(ios,'Precipitation climo field not found in the file') + ios = nf90_get_var(nid,varId,precip_climo(:,:,i)) + call LDT_verify(ios,'Error in nf90_get_var in LDT_procDataForREAL') + enddo - ios = nf90_get_var(nid,varId,precip_climo(:,:,i)) - call LDT_verify(ios,'Error in nf90_get_var in LDT_procDataForREAL') - enddo - - ios = nf90_close(nid) - call LDT_verify(ios,'Error in nf90_close in readldtparam_real_2d') - write(LDT_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) + ios = nf90_close(nid) + call LDT_verify(ios,'Error in nf90_close in readldtparam_real_2d') + write(LDT_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) - precip = precip_climo - deallocate(precip_climo) + precip = precip_climo + deallocate(precip_climo) ! end USE_NETCDF4 #endif diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index bd7777de8..a3d68e13c 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -350,7 +350,6 @@ subroutine computeSingleCDF(n,obs, metrics) enddo do t=1,LDT_rc%ngrid(n) -! if(datamask(t).gt.0) then do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins @@ -359,7 +358,6 @@ subroutine computeSingleCDF(n,obs, metrics) enddo enddo enddo -! endif enddo ! MN: save stratified CDF metrics%strat_cdf = strat_cdf @@ -414,7 +412,6 @@ subroutine computeSingleCDF(n,obs, metrics) enddo do t=1,LDT_rc%ngrid(n) -! if(datamask(t).gt.0) then do j=1,LDT_rc%cdf_ntimes do k=1,obs%vlevels do i=1,LDT_rc%cdf_nbins @@ -425,10 +422,9 @@ subroutine computeSingleCDF(n,obs, metrics) enddo enddo enddo -! endif enddo - ! MN: save stratified CDF + ! MN: save stratified CDF metrics%strat_cdf = strat_cdf deallocate(strat_bincounts) deallocate(strat_cdf) diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index adfdb2420..bce21191e 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -87,7 +87,7 @@ subroutine LDT_DApreprocInit() call LDT_verify(rc,'Name of the preprocessed DA file: not defined') if(LDT_rc%comp_cdf.gt.0) then - + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%cdf_nbins,& label="Number of bins to use in the CDF:",rc=rc) call LDT_verify(rc,'Number of bins to use in the CDF: not defined') @@ -167,17 +167,17 @@ subroutine LDT_DApreprocInit() do r=1,LDT_rc%lnr(n) do c=1,LDT_rc%lnc(n) - if(LDT_domain(n)%gindex(c,r).ne.-1) then - + if(LDT_domain(n)%gindex(c,r).ne.-1) then + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = & nint((cdf_strat_data(c,r) - LDT_rc%group_cdfs_min)/& delta)+1 if (LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) .gt. LDT_rc%group_cdfs_nbins) then - write(LDT_logunit,*) '[INFO] Group bins is larger then Max Group bins',& - LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)), 'vs.', LDT_rc%group_cdfs_nbins ,& - 'Value adjusted the Max Group bins' - LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = LDT_rc%group_cdfs_nbins - endif + write(LDT_logunit,*) '[INFO] Group bins is larger then Max Group bins',& + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)), 'vs.', LDT_rc%group_cdfs_nbins ,& + 'Value adjusted the Max Group bins' + LDT_rc%cdf_strat_data(LDT_domain(n)%gindex(c,r)) = LDT_rc%group_cdfs_nbins + endif endif enddo enddo @@ -217,12 +217,10 @@ subroutine LDT_DApreprocInit() call read_Precip_climo (LDT_rc%lnc(n), LDT_rc%lnr(n), LDT_rc%strat_file, stratification_data) ! do j=1,LDT_rc%cdf_ntimes - LDT_rc%strat_cdfs_min = 0. !minval returns -9999. minval(stratification_data(:,:,j)) ! min value over the entire domain - LDT_rc%strat_cdfs_max = maxval(stratification_data(:,:,j)) ! max value over the entire domain - delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& - LDT_rc%strat_cdfs_nbins - print*, 'month,min,man,delta', j,LDT_rc%strat_cdfs_min, LDT_rc%strat_cdfs_max, delta - + LDT_rc%strat_cdfs_min = 0. !minval returns -9999. minval(stratification_data(:,:,j)) ! min value over the entire domain + LDT_rc%strat_cdfs_max = maxval(stratification_data(:,:,j)) ! max value over the entire domain + delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& + LDT_rc%strat_cdfs_nbins do r=1,LDT_rc%lnr(n) do c=1,LDT_rc%lnc(n) if(LDT_domain(n)%gindex(c,r).ne.-1) then @@ -231,104 +229,65 @@ subroutine LDT_DApreprocInit() nint((stratification_data(c,r,j) - LDT_rc%strat_cdfs_min)/& delta)+1 if (LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) .gt. LDT_rc%strat_cdfs_nbins) then - write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& - 'Value adjusted to the Max Startification bins' - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins + write(LDT_logunit,*) '[INFO] Startification bins is larger then Max Startification bins',& + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) , 'vs.', LDT_rc%strat_cdfs_nbins,& + 'Value adjusted to the Max Startification bins' + LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = LDT_rc%strat_cdfs_nbins endif else write(LDT_logunit,*) '[INFO] Total precip is zero or undefined',& - stratification_data(c,r,j) ,c,r,j,& - 'Value adjusted to the Min Startification bins' + stratification_data(c,r,j) ,c,r,j,& + 'Value adjusted to the Min Startification bins' LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r), j) = 1 endif endif enddo enddo enddo - - -#if 0 - !if(LDT_rc%strat_cdfs.gt.0) then - allocate(LDT_rc%stratification_data(LDT_rc%ngrid(n))) - allocate(stratification_data(LDT_rc%ngrid(n),2)) - - call read_Drange(LDT_rc%ngrid(n), LDT_rc%strat_file, "TotalPrecip", stratification_data) !LDT_rc%strat_cdfs_nbins, LDT_rc%ngrid(n), & - - LDT_rc%strat_cdfs_min = minval(stratification_data(:,1)) ! min value over the entire domain - LDT_rc%strat_cdfs_max = maxval(stratification_data(:,2)) ! max value over the entire domain - delta = (LDT_rc%strat_cdfs_max-LDT_rc%strat_cdfs_min)/& - LDT_rc%strat_cdfs_nbins - print*, 'min,man,delta', LDT_rc%strat_cdfs_min, LDT_rc%strat_cdfs_max, delta - do r=1,LDT_rc%lnr(n) - do c=1,LDT_rc%lnc(n) - if(LDT_domain(n)%gindex(c,r).ne.-1) then - LDT_rc%stratification_data(LDT_domain(n)%gindex(c,r)) = & - nint((stratification_data(LDT_domain(n)%gindex(c,r),2) - LDT_rc%strat_cdfs_min)/& - delta)+1 - endif - enddo - enddo - - !if(LDT_rc%strat_cdfs.gt.0) then - ! call ESMF_ConfigGetAttribute(LDT_config,& - ! LDT_rc%strat_cdfs_attrib_file,& - ! label="CDF Stratification attributes file:",rc=rc) - ! call LDT_verify(rc,'CDF Stratification attributes file: not defined') - - ! ftn = LDT_getNextUnitNumber() - ! open(ftn,file=LDT_rc%strat_cdfs_attrib_file, status='old') - ! read(ftn,*) - ! read(ftn,*) LDT_rc%strat_cdfs_nbins - ! call LDT_releaseUnitNumber(ftn) -#endif endif endif - - - - if(LDT_rc%comp_obsgrid.eq.1) then + if(LDT_rc%comp_obsgrid.eq.1) then LDT_rc%pass = 0 else - - if(LDT_rc%tavgInterval.lt.LDT_rc%ts) then + + if(LDT_rc%tavgInterval.lt.LDT_rc%ts) then write(LDT_logunit,*) '[ERR] Temporal averaging interval must be greater than' write(LDT_logunit,*) '[ERR] or equal to the LIS output timestep. ' write(LDT_logunit,*) '[ERR] Program stopping....' call LDT_endrun() endif - + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%obsCountThreshold,& label="Observation count threshold:",& rc=rc) - call LDT_verify(rc,'Observation count threshold: not defined') - - if(LDT_rc%comp_cdf.eq.1) then + call LDT_verify(rc,'Observation count threshold: not defined') + + if(LDT_rc%comp_cdf.eq.1) then LDT_rc%pass = 2 - elseif(LDT_rc%anomalyObsProc.eq.1) then + elseif(LDT_rc%anomalyObsProc.eq.1) then LDT_rc%pass = 2 endif - + endif call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%applyMask,& label="Apply external mask:",& rc=rc) call LDT_verify(rc,'Apply external mask: not defined') - + call ESMF_ConfigGetAttribute(LDT_config,LDT_rc%maskdir,& label="External mask directory:",& rc=rc) call LDT_verify(rc,'External mask directory: not defined') - + call LDT_DAobs_plugin - + LDT_rc%nobs = 1 - + ! This flag is set to prompt the writing of the domain file - if(LDT_rc%anomalyObsProc.eq.1) then - LDT_rc%comp_obsgrid = 1 + if(LDT_rc%anomalyObsProc.eq.1) then + LDT_rc%comp_obsgrid = 1 endif end subroutine LDT_DApreprocInit diff --git a/lis/core/LIS_dataAssimMod.F90 b/lis/core/LIS_dataAssimMod.F90 index af2693e2c..1b70c12c3 100644 --- a/lis/core/LIS_dataAssimMod.F90 +++ b/lis/core/LIS_dataAssimMod.F90 @@ -1041,7 +1041,6 @@ subroutine LIS_rescale_with_stratified_CDF(& real :: model_cdf(n_strat_bins,ntimes, nbins) real :: obs_cdf(n_strat_bins,ntimes, nbins) real :: obs_value(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k)) - !real :: ref_precip_climo(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k),ntimes) real :: ref_precip_climo_maxval(ntimes) real :: target_precip_climo(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k),ntimes) ! @@ -1078,7 +1077,6 @@ subroutine LIS_rescale_with_stratified_CDF(& integer, dimension (1) :: index_25 , index_75 real :: Lb_xrange, Ub_xrange, iqr_obs, iqr_model - if(ntimes.gt.1) then kk = LIS_rc%mo else @@ -1090,87 +1088,83 @@ subroutine LIS_rescale_with_stratified_CDF(& enddo do t=1,LIS_rc%obs_ngrid(k) - col = LIS_obs_domain(n,k)%col(t) - row = LIS_obs_domain(n,k)%row(t) + col = LIS_obs_domain(n,k)%col(t) + row = LIS_obs_domain(n,k)%row(t) - ! find the reference CDF stratification bin value for each grid cell - if(target_precip_climo(col,row,kk).ne.-9999.0) then - ref_p_min = 0. !minval returns -9999. minval(ref_precip_climo(:,:,j)) ! min value over the entire domain - !ref_p_max = maxval(ref_precip_climo(:,:,kk)) ! max value over the entire domain - ref_p_max = ref_precip_climo_maxval(kk) ! max value over the entire domain - delta_p_ref = (ref_p_max-ref_p_min)/& - n_strat_bins - strat_binval = nint( (target_precip_climo(col,row,kk)-ref_p_min)/& + ! find the reference CDF stratification bin value for each grid cell + if(target_precip_climo(col,row,kk).ne.-9999.0) then + ref_p_min = 0. !minval returns -9999. minval(ref_precip_climo(:,:,j)) ! min value over the entire domain + ref_p_max = ref_precip_climo_maxval(kk) ! max value over the entire domain + delta_p_ref = (ref_p_max-ref_p_min)/& + n_strat_bins + strat_binval = nint( (target_precip_climo(col,row,kk)-ref_p_min)/& delta_p_ref)+1 - if(strat_binval.gt.n_strat_bins) strat_binval = n_strat_bins - if(strat_binval.le.0) strat_binval = 1 - endif + if(strat_binval.gt.n_strat_bins) strat_binval = n_strat_bins + if(strat_binval.le.0) strat_binval = 1 + endif - index_25 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.25)) - index_75 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.75)) - Lb_xrange = obs_xrange(strat_binval,kk,index_25(1)) - Ub_xrange = obs_xrange(strat_binval,kk,index_75(1)) - iqr_obs = Ub_xrange - Lb_xrange + index_25 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.25)) + index_75 = minloc(abs(obs_cdf(strat_binval,kk,:) - 0.75)) + Lb_xrange = obs_xrange(strat_binval,kk,index_25(1)) + Ub_xrange = obs_xrange(strat_binval,kk,index_75(1)) + iqr_obs = Ub_xrange - Lb_xrange - index_25 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.25)) - index_75 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.75)) - Lb_xrange = model_xrange(strat_binval,kk,index_25(1)) - Ub_xrange = model_xrange(strat_binval,kk,index_75(1)) - iqr_model = Ub_xrange - Lb_xrange + index_25 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.25)) + index_75 = minloc(abs(model_cdf(strat_binval,kk,:) - 0.75)) + Lb_xrange = model_xrange(strat_binval,kk,index_25(1)) + Ub_xrange = model_xrange(strat_binval,kk,index_75(1)) + iqr_model = Ub_xrange - Lb_xrange - if( iqr_obs .lt. 0.05 * (obs_xrange(strat_binval,kk,nbins)-obs_xrange(strat_binval,kk,1)) .or. & + if( iqr_obs .lt. 0.05 * (obs_xrange(strat_binval,kk,nbins)-obs_xrange(strat_binval,kk,1)) .or. & iqr_model .lt. 0.05 * (model_xrange(strat_binval,kk,nbins)-model_xrange(strat_binval,kk,1)) ) then - obs_delta(strat_binval) = 0 - endif + obs_delta(strat_binval) = 0 + endif + if(obs_value(col,row).ne.-9999.0) then + obs_in = obs_value(col,row) + if(obs_delta(strat_binval).gt.0) then + binval = nint((obs_value(col,row)-obs_xrange(strat_binval,kk,1))/& + obs_delta(strat_binval))+1 + if(binval.gt.nbins) binval = nbins + if(binval.le.0) binval = 1 + cdf_obsval = obs_cdf(strat_binval,kk,binval) + if(cdf_obsval.gt.1.0) cdf_obsval = 1.0 + if(cdf_obsval .gt.0)then + i=1 + do while((model_cdf(strat_binval,kk,i).lt.cdf_obsval).and.& + (i.le.nbins)) + i = i+1 + if(i.gt.nbins) exit + enddo + if(i.gt.nbins) i = i-1 + obs_tmp = model_xrange(strat_binval,kk,i) - if(obs_value(col,row).ne.-9999.0) then - obs_in = obs_value(col,row) - if(obs_delta(strat_binval).gt.0) then - binval = nint((obs_value(col,row)-obs_xrange(strat_binval,kk,1))/& - obs_delta(strat_binval))+1 - if(binval.gt.nbins) binval = nbins - if(binval.le.0) binval = 1 - cdf_obsval = obs_cdf(strat_binval,kk,binval) - if(cdf_obsval.gt.1.0) cdf_obsval = 1.0 - if(cdf_obsval .gt.0)then - i=1 - do while((model_cdf(strat_binval,kk,i).lt.cdf_obsval).and.& - (i.le.nbins)) - i = i+1 - if(i.gt.nbins) exit - enddo - if(i.gt.nbins) i = i-1 - obs_tmp = model_xrange(strat_binval,kk,i) - - if(obs_tmp.gt.max_obs_value) then -! obs_tmp = max_obs_value - obs_tmp = LIS_rc%udef - endif - - if(obs_tmp.le.min_obs_value) then -! obs_tmp = obs_value(col,row) - obs_tmp = LIS_rc%udef - endif - obs_value(col,row) = obs_tmp - else - obs_value(col,row) = LIS_rc%udef - endif - else - obs_value(col,row) = LIS_rc%udef - endif - if(obs_value(col,row).le.min_obs_value.and.& - obs_value(col,row).ne.-9999.0) then - write(LIS_logunit,*) '[ERR] Problem in CDF scaling of observations in the DA instance ',k - write(LIS_logunit,*) '[ERR] ',col,row,obs_value(col,row), obs_in - call LIS_endrun() - endif - else - obs_value(col,row) = LIS_rc%udef - endif - enddo - !TRACE_EXIT("DA_rescaleCDF") - end subroutine LIS_rescale_with_stratified_CDF + if(obs_tmp.gt.max_obs_value) then + obs_tmp = LIS_rc%udef + endif + + if(obs_tmp.le.min_obs_value) then + obs_tmp = LIS_rc%udef + endif + obs_value(col,row) = obs_tmp + else + obs_value(col,row) = LIS_rc%udef + endif + else + obs_value(col,row) = LIS_rc%udef + endif + if(obs_value(col,row).le.min_obs_value.and.& + obs_value(col,row).ne.-9999.0) then + write(LIS_logunit,*) '[ERR] Problem in CDF scaling of observations in the DA instance ',k + write(LIS_logunit,*) '[ERR] ',col,row,obs_value(col,row), obs_in + call LIS_endrun() + endif + else + obs_value(col,row) = LIS_rc%udef + endif + enddo + !TRACE_EXIT("DA_rescaleCDF") + end subroutine LIS_rescale_with_stratified_CDF !MN 2022.02.24 @@ -1721,7 +1715,7 @@ subroutine read_CDFtransferdata_all(n, k, nbins, ntimes, n_strat_bins, & filename, varname, xrange, cdf) implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer, intent(in) :: n integer, intent(in) :: k integer, intent(in) :: nbins @@ -1758,60 +1752,56 @@ subroutine read_CDFtransferdata_all(n, k, nbins, ntimes, n_strat_bins, & !TRACE_ENTER("DA_readCDF") #if(defined USE_NETCDF3 || defined USE_NETCDF4) write(LIS_logunit,*) '[INFO] Reading stratified geolocation independent reference CDF file ',trim(filename) - !if(ngrid.gt.0) then - call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& - ncid=nid),'failed to open file '//trim(filename)) + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& + ncid=nid),'failed to open file '//trim(filename)) - call LIS_verify(nf90_inq_dimid(nid,"n_strat_bins",nstratbinId), & - 'nf90_inq_dimid failed for n_strat_bins') - call LIS_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & - 'nf90_inq_dimid failed for nbins') - call LIS_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & - 'nf90_inq_dimid failed for '//trim(varname)//"_levels") + call LIS_verify(nf90_inq_dimid(nid,"n_strat_bins",nstratbinId), & + 'nf90_inq_dimid failed for n_strat_bins') + call LIS_verify(nf90_inq_dimid(nid,"nbins",nbinsId), & + 'nf90_inq_dimid failed for nbins') + call LIS_verify(nf90_inq_dimid(nid,trim(varname)//"_levels",nlevsId), & + 'nf90_inq_dimid failed for '//trim(varname)//"_levels") - call LIS_verify(nf90_inquire_dimension(nid,nstratbinId, len=nstratbin_file),& - 'nf90_inquire_dimension failed for n_strat_bins') - call LIS_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& - 'nf90_inquire_dimension failed for nbins') - call LIS_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& - 'nf90_inquire_dimension failed for nlevels') + call LIS_verify(nf90_inquire_dimension(nid,nstratbinId, len=nstratbin_file),& + 'nf90_inquire_dimension failed for n_strat_bins') + call LIS_verify(nf90_inquire_dimension(nid,nbinsId, len=nbins_file),& + 'nf90_inquire_dimension failed for nbins') + call LIS_verify(nf90_inquire_dimension(nid,nlevsId, len=nlevs_file),& + 'nf90_inquire_dimension failed for nlevels') - if(nbins.ne.nbins_file) then - write(LIS_logunit,*) '[ERR] The number of bins specified in the file '//& - trim(filename) - write(LIS_logunit,*) '[ERR] (',nbins_file, & - ') is different from the number of bins specified' - write(LIS_logunit,*) '[ERR] in the lis.config file (',nbins,')' - call LIS_endrun() - endif + if(nbins.ne.nbins_file) then + write(LIS_logunit,*) '[ERR] The number of bins specified in the file '//& + trim(filename) + write(LIS_logunit,*) '[ERR] (',nbins_file, & + ') is different from the number of bins specified' + write(LIS_logunit,*) '[ERR] in the lis.config file (',nbins,')' + call LIS_endrun() + endif - allocate(xrange_file(nstratbin_file,ntimes,nlevs_file,nbins)) - allocate(cdf_file(nstratbin_file,ntimes,nlevs_file,nbins)) + allocate(xrange_file(nstratbin_file,ntimes,nlevs_file,nbins)) + allocate(cdf_file(nstratbin_file,ntimes,nlevs_file,nbins)) - !do j=1,ntimes - call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_xrange_stratified',xid),& - 'nf90_inq_varid failed for for '//trim(varname)//'_xrange_stratified') - call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_CDF_stratified',cdfid),& - 'nf90_inq_varid failed for '//trim(varname)//'_CDF_stratified') + call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_xrange_stratified',xid),& + 'nf90_inq_varid failed for for '//trim(varname)//'_xrange_stratified') + call LIS_verify(nf90_inq_varid(nid,trim(varname)//'_CDF_stratified',cdfid),& + 'nf90_inq_varid failed for '//trim(varname)//'_CDF_stratified') - call LIS_verify(nf90_get_var(nid,xid,xrange_file, & - start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& - 'nf90_get_var failed for '//trim(varname)//'_xrange_stratified') - call LIS_verify(nf90_get_var(nid,cdfid,cdf_file,& - start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& - 'nf90_get_var failed for '//trim(varname)//'_CDF_stratified') + call LIS_verify(nf90_get_var(nid,xid,xrange_file, & + start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& + 'nf90_get_var failed for '//trim(varname)//'_xrange_stratified') + call LIS_verify(nf90_get_var(nid,cdfid,cdf_file,& + start=(/1,1,1,1/), count=(/nstratbin_file,ntimes,nlevs_file,nbins/)),& + 'nf90_get_var failed for '//trim(varname)//'_CDF_stratified') - !enddo - xrange = xrange_file(:,:,1,:) - cdf = cdf_file(:,:,1,:) + xrange = xrange_file(:,:,1,:) + cdf = cdf_file(:,:,1,:) - deallocate(xrange_file) - deallocate(cdf_file) + deallocate(xrange_file) + deallocate(cdf_file) - call LIS_verify(nf90_close(nid),& - 'failed to close file '//trim(filename)) - write(LIS_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) - !endif + call LIS_verify(nf90_close(nid),& + 'failed to close file '//trim(filename)) + write(LIS_logunit,*) '[INFO] Successfully read CDF file ',trim(filename) #endif ! TRACE_EXIT("DA_readCDF") end subroutine read_CDFtransferdata_all @@ -1820,11 +1810,10 @@ end subroutine read_CDFtransferdata_all ! !ROUTINE: read_Precip_climo ! \label{read_Precip_climo} -! !REVISION HISTORY: +! !REVISION HISTORY: ! 28 Feb 2022: Mahdi Navari ; Initial Specification ! -! !INTERFACE: -!subroutine read_Precip_climo(n,k,ncol, nrow, filename, precip) +! !INTERFACE: subroutine read_Precip_climo(n,k, filename, precip) use LIS_coreMod use LIS_logMod @@ -1833,40 +1822,37 @@ subroutine read_Precip_climo(n,k, filename, precip) use netcdf #endif - implicit none -! !ARGUMENTS: - integer, intent(in) :: n - integer, intent(in) :: k - !integer, intent(in) :: ncol, nrow - character(len=*), intent(in) :: filename - real, allocatable, intent(inout) :: precip(:,:,:) - logical :: file_exists -! -! !DESCRIPTION: + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: k + character(len=*), intent(in) :: filename + real, allocatable, intent(inout) :: precip(:,:,:) + logical :: file_exists +! +! !DESCRIPTION: ! This routine reads the input CDF file (generated by LVT in NETCDF format) -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[filename] name of the CDF file ! \item[varname] name of the variable being extracted. ! \end{description} !EOP - !real, allocatable :: precip_climo(:,:,:), gtmp1d(:),gtmp2d(:,:) - integer :: ios,nid,ncId,nrId,varId - integer :: gnc,gnr,gr,gc,nc,nr,i,c,r - character*3 :: month_name(12) - integer :: gindex,gid - integer :: ierr - - month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& - "JUL","AUG","SEP","OCT","NOV","DEC"/) + integer :: ios,nid,ncId,nrId,varId + integer :: gnc,gnr,gr,gc,nc,nr,i,c,r + character*3 :: month_name(12) + integer :: gindex,gid + integer :: ierr + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) #if(defined USE_NETCDF3 || defined USE_NETCDF4) inquire(file=trim(filename), exist=file_exists) if(file_exists) then write(LIS_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) - !if(ngrid.gt.0) then + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& ncid=nid),'failed to open file '//trim(filename)) @@ -1888,7 +1874,6 @@ subroutine read_Precip_climo(n,k, filename, precip) call LIS_endrun() endif - !allocate(precip_climo(gnc,gnr,12)) allocate(precip(gnc,gnr,12)) do i=1,12 ios = nf90_inq_varid(nid,'TotalPrecip_'//trim(month_name(i)),varId) @@ -1903,29 +1888,6 @@ subroutine read_Precip_climo(n,k, filename, precip) write(LIS_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) endif - !precip = precip_climo - !deallocate(precip_climo) - ! subset from the global 2-d space to the local 2-d space -! do i=1,12 -! precip(:,:,i) = precip_climo(& -! LIS_ews_halo_ind(n,LIS_localPet+1):& -! LIS_ewe_halo_ind(n,LIS_localPet+1), & -! LIS_nss_halo_ind(n,LIS_localPet+1): & -! LIS_nse_halo_ind(n,LIS_localPet+1),i) -! enddo -! deallocate(precip_climo) - -#if 0 - if(ngrid.gt.0) then - do kk=1,nbins - call LIS_convertObsVarToLocalSpace(n,k,xrange_file(:,1,kk), & - xrange(:,j,kk)) - call LIS_convertObsVarToLocalSpace(n,k,cdf_file(:,1,kk), & - cdf(:,j,kk)) - enddo - endif -#endif - ! end USE_NETCDF4 #endif @@ -1938,7 +1900,7 @@ end subroutine read_Precip_climo ! !REVISION HISTORY: ! 28 Feb 2022: Mahdi Navari ; Initial Specification ! -! !INTERFACE: +! !INTERFACE: subroutine read_Precip_climo_maxval(n,filename, strat_cdfs_max) use LIS_coreMod @@ -1948,39 +1910,36 @@ subroutine read_Precip_climo_maxval(n,filename, strat_cdfs_max) use netcdf #endif - implicit none -! !ARGUMENTS: - integer, intent(in) :: n -! integer, intent(in) :: k - !integer, intent(in) :: ncol, nrow - character(len=*), intent(in) :: filename - real :: strat_cdfs_max(12) - logical :: file_exists -! -! !DESCRIPTION: + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + character(len=*), intent(in) :: filename + real :: strat_cdfs_max(12) + logical :: file_exists +! +! !DESCRIPTION: ! This routine reads the input CDF file (generated by LVT in NETCDF format) -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item[filename] name of the CDF file ! \item[varname] name of the variable being extracted. ! \end{description} !EOP - real, allocatable :: precip_climo(:,:,:) - integer :: ios,nid,ncId,nrId,varId - integer :: gnc,gnr,gr,gc,nc,nr,i,c,r - character*3 :: month_name(12) - integer :: gindex - - month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& - "JUL","AUG","SEP","OCT","NOV","DEC"/) + real, allocatable :: precip_climo(:,:,:) + integer :: ios,nid,ncId,nrId,varId + integer :: gnc,gnr,gr,gc,nc,nr,i,c,r + character*3 :: month_name(12) + integer :: gindex + month_name = (/"JAN","FEB","MAR","APR","MAY","JUN",& + "JUL","AUG","SEP","OCT","NOV","DEC"/) #if(defined USE_NETCDF3 || defined USE_NETCDF4) inquire(file=trim(filename), exist=file_exists) if(file_exists) then write(LIS_logunit,*) '[INFO] Reading Precipitation climatology form CDF file ',trim(filename) - !if(ngrid.gt.0) then + call LIS_verify(nf90_open(path=trim(filename),mode=NF90_NOWRITE,& ncid=nid),'failed to open file '//trim(filename)) @@ -2011,15 +1970,12 @@ subroutine read_Precip_climo_maxval(n,filename, strat_cdfs_max) write(LIS_logunit,*) '[INFO] Successfully read Precipitation climo file ',trim(filename) endif - !precip = precip_climo - !deallocate(precip_climo) - ! Note: we just need Max and min values for each month (Min is zero) do i=1,12 ! number of month strat_cdfs_max(i) = maxval(precip_climo(:,:,i)) ! max value over the entire domain enddo - deallocate(precip_climo) + deallocate(precip_climo) ! end USE_NETCDF4 #endif diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 index a486edf3f..875dd2207 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 @@ -10,16 +10,16 @@ !BOP ! ! !MODULE: cdfTransfer_NASASMAPsm_Mod -! -! !DESCRIPTION: +! +! !DESCRIPTION: ! This module contains interfaces and subroutines to -! handle -! -! !REVISION HISTORY: +! handle +! +! !REVISION HISTORY: ! 2 Mar 2022 Mahdi Navari; initial specification ! module cdfTransfer_NASASMAPsm_Mod -! !USES: +! !USES: use ESMF use map_utils @@ -37,7 +37,7 @@ module cdfTransfer_NASASMAPsm_Mod public :: cdfT_SMAPsm_struc !EOP type, public:: cdfT_SMAPsm_dec - + integer :: useSsdevScal logical :: startMode integer :: nc @@ -74,24 +74,23 @@ module cdfTransfer_NASASMAPsm_Mod integer :: useCDFtransfer character*100 :: ref_p_climo_file character*100 :: target_p_climo_file - !real, allocatable :: ref_p_climo(:,:,:) real, allocatable :: ref_p_climo_maxval(:) real, allocatable :: target_p_climo(:,:,:) end type cdfT_SMAPsm_dec - + type(cdfT_SMAPsm_dec),allocatable :: cdfT_SMAPsm_struc(:) contains !BOP -! +! ! !ROUTINE: cdfTransfer_NASASMAPsm_setup ! \label{cdfTransfer_NASASMAPsm_setup} -! -! !INTERFACE: +! +! !INTERFACE: subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) -! !USES: +! !USES: use LIS_coreMod use LIS_timeMgrMod use LIS_historyMod @@ -100,22 +99,22 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) use LIS_DAobservationsMod use LIS_logmod - implicit none + implicit none -! !ARGUMENTS: +! !ARGUMENTS: integer :: k type(ESMF_State) :: OBS_State(LIS_rc%nnest) type(ESMF_State) :: OBS_Pert_State(LIS_rc%nnest) -! -! !DESCRIPTION: -! -! This routine completes the runtime initializations and -! creation of data strctures required for handling NASASMAP -! soil moisture data. -! -! The arguments are: +! +! !DESCRIPTION: +! +! This routine completes the runtime initializations and +! creation of data strctures required for handling NASASMAP +! soil moisture data. +! +! The arguments are: ! \begin{description} -! \item[OBS\_State] observation state +! \item[OBS\_State] observation state ! \item[OBS\_Pert\_State] observation perturbations state ! \end{description} !EOP @@ -196,38 +195,14 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%useSsdevScal,& rc=status) call LIS_verify(status, 'SMAP(NASA) soil moisture use scaled standard deviation model: is missing') - - enddo -#if 0 - call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) model CDF file:",& - rc=status) - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%modelcdffile,rc=status) - call LIS_verify(status, 'SMAP(NASA) model CDF file: not defined') - enddo - call ESMF_ConfigFindLabel(LIS_config,"SMAP(NASA) observation CDF file:",& - rc=status) - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%obscdffile,rc=status) - call LIS_verify(status, 'SMAP(NASA) observation CDF file: not defined') enddo -#endif + call ESMF_ConfigFindLabel(LIS_config, "SMAP(NASA) soil moisture number of bins in the CDF:", rc=status) do n=1, LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) call LIS_verify(status, "SMAP(NASA) soil moisture number of bins in the CDF: not defined") enddo -#if 0 - do n=1, LIS_rc%nnest - cdfT_SMAPsm_struc(n)%cdf_read_mon = .false. - - call ESMF_ConfigFindLabel(LIS_config, "SMAP(NASA) CDF read option:", rc=status) ! 0: read CDF for all months/year - ! 1: read CDF for current month - call ESMF_ConfigGetAttribute(LIS_config, cdfT_SMAPsm_struc(n)%cdf_read_opt, rc=status) - call LIS_verify(status, "SMAP(NASA) CDF read option: not defined") - enddo -#endif call ESMF_ConfigFindLabel(LIS_config,"Use CDF transfer for soil moisture data assimilation:",& rc=status) @@ -238,31 +213,23 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call LIS_verify(status, 'Use CDF transfer for soil moisture data assimilation: is missing') enddo - !if(cdfT_SMAPsm_struc(n)%useCDFtransfer.gt.0) then - call ESMF_ConfigFindLabel(LIS_config,"Reference domain model CDF file:",& + call ESMF_ConfigFindLabel(LIS_config,"Reference domain model CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%modelcdffile,& rc=status) - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,& - cdfT_SMAPsm_struc(n)%modelcdffile,& - rc=status) - call LIS_verify(status, 'Reference domain model CDF file: is missing') - enddo + call LIS_verify(status, 'Reference domain model CDF file: is missing') + enddo - call ESMF_ConfigFindLabel(LIS_config,"Reference domain obs CDF file:",& + call ESMF_ConfigFindLabel(LIS_config,"Reference domain obs CDF file:",& + rc=status) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,& + cdfT_SMAPsm_struc(n)%obscdffile,& rc=status) - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,& - cdfT_SMAPsm_struc(n)%obscdffile,& - rc=status) - call LIS_verify(status, 'Reference domain obs CDF file: is missing') - enddo -#if 0 - call ESMF_ConfigFindLabel(LIS_config, "Number of bins in the soil moisture CDF:", rc=status) - do n=1, LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,cdfT_SMAPsm_struc(n)%nbins, rc=status) - call LIS_verify(status, "Number of bins in the soil moisture CDF not defined") - enddo -#endif + call LIS_verify(status, 'Reference domain obs CDF file: is missing') + enddo call ESMF_ConfigFindLabel(LIS_config,"Reference domain precipitation climatology data source:",& rc=status) @@ -282,8 +249,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call LIS_verify(status, 'Target domain precipitation climatology data source: is missing') enddo - - do n=1,LIS_rc%nnest + do n=1,LIS_rc%nnest call ESMF_AttributeSet(OBS_State(n),"Data Update Status",& .false., rc=status) call LIS_verify(status) @@ -295,33 +261,29 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call ESMF_AttributeSet(OBS_State(n),"Data Assimilate Status",& .false., rc=status) call LIS_verify(status) - + call ESMF_AttributeSet(OBS_State(n),"Number Of Observations",& LIS_rc%obs_ngrid(k),rc=status) call LIS_verify(status) - + enddo write(LIS_logunit,*)& '[INFO] read reference and target domains precipitation climatology data' -!-------------------------------------------------------------------------------- +!-------------------------------------------------------------------------------- ! Data must be in the local domain ! The stratified CDF is geolocation independent ! Subset the precipition climotology to local space !------------------------------------------------------------------------------- do n=1,LIS_rc%nnest - !allocate(cdfT_SMAPsm_struc(n)%ref_p_climo(LIS_rc%lnc(n), LIS_rc%lnr(n), cdfT_SMAPsm_struc(n)%ntimes)) allocate(cdfT_SMAPsm_struc(n)%ref_p_climo_maxval(12)) !cdfT_SMAPsm_struc(n)%ntimes)) allocate(cdfT_SMAPsm_struc(n)%target_p_climo(LIS_rc%lnc(n), LIS_rc%lnr(n),12)) !cdfT_SMAPsm_struc(n)%ntimes)) - ! Note: we do not need to know the dimenesions of the reference domain precip climatology + ! Note: we do not need to know the dimenesions of the reference domain precip climatology ! for allocation so we just extract max value for each month call read_Precip_climo_maxval (n,cdfT_SMAPsm_struc(n)%ref_p_climo_file,& cdfT_SMAPsm_struc(n)%ref_p_climo_maxval) - !call read_Precip_climo (n,k,LIS_rc%lnc(n), LIS_rc%lnr(n),& - ! cdfT_SMAPsm_struc(n)%target_p_climo_file,& - ! cdfT_SMAPsm_struc(n)%target_p_climo) call read_Precip_climo (n,k,& cdfT_SMAPsm_struc(n)%target_p_climo_file,& target_precip_climo) @@ -337,18 +299,18 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) enddo write(LIS_logunit,*)& - '[INFO] read SMAP(NASA) soil moisture data specifications' + '[INFO] read SMAP(NASA) soil moisture data specifications' !---------------------------------------------------------------------------- ! Create the array containers that will contain the observations and ! the perturbations. NASASMAP ! observations are in the grid space. Since there is only one layer -! being assimilated, the array size is LIS_rc%obs_ngrid(k). -! +! being assimilated, the array size is LIS_rc%obs_ngrid(k). +! !---------------------------------------------------------------------------- do n=1,LIS_rc%nnest - + write(unit=temp,fmt='(i2.2)') 1 read(unit=temp,fmt='(2a1)') vid @@ -365,21 +327,21 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) read(ftn,*) read(ftn,*) LIS_rc%nobtypes(k) read(ftn,*) - + allocate(vname(LIS_rc%nobtypes(k))) allocate(varmax(LIS_rc%nobtypes(k))) allocate(varmin(LIS_rc%nobtypes(k))) - + do i=1,LIS_rc%nobtypes(k) read(ftn,fmt='(a40)') vname(i) read(ftn,*) varmin(i),varmax(i) write(LIS_logunit,*) '[INFO] ',vname(i),varmin(i),varmax(i) enddo - call LIS_releaseUnitNumber(ftn) - + call LIS_releaseUnitNumber(ftn) + allocate(ssdev(LIS_rc%obs_ngrid(k))) - - if(trim(LIS_rc%perturb_obs(k)).ne."none") then + + if(trim(LIS_rc%perturb_obs(k)).ne."none") then allocate(obs_pert%vname(1)) allocate(obs_pert%perttype(1)) allocate(obs_pert%ssdev(1)) @@ -393,7 +355,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call LIS_readPertAttributes(1,LIS_rc%obspertAttribfile(k),& obs_pert) -! Set obs err to be uniform (will be rescaled later for each grid point). +! Set obs err to be uniform (will be rescaled later for each grid point). ssdev = obs_pert%ssdev(1) cdfT_SMAPsm_struc(n)%ssdev_inp = obs_pert%ssdev(1) @@ -401,37 +363,37 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) grid=LIS_obsensOnGrid(n,k),name="Observation"//vid(1)//vid(2),& rc=status) call LIS_verify(status) - -! initializing the perturbations to be zero + +! initializing the perturbations to be zero call ESMF_FieldGet(pertField(n),localDE=0,farrayPtr=obs_temp,rc=status) call LIS_verify(status) - obs_temp(:,:) = 0 + obs_temp(:,:) = 0 call ESMF_AttributeSet(pertField(n),"Perturbation Type",& obs_pert%perttype(1), rc=status) call LIS_verify(status) - if(LIS_rc%obs_ngrid(k).gt.0) then + if(LIS_rc%obs_ngrid(k).gt.0) then call ESMF_AttributeSet(pertField(n),"Standard Deviation",& ssdev,itemCount=LIS_rc%obs_ngrid(k),rc=status) call LIS_verify(status) endif - + call ESMF_AttributeSet(pertField(n),"Std Normal Max",& obs_pert%stdmax(1), rc=status) call LIS_verify(status) - + call ESMF_AttributeSet(pertField(n),"Ensure Zero Mean",& obs_pert%zeromean(1),rc=status) call LIS_verify(status) - + call ESMF_AttributeSet(pertField(n),"Temporal Correlation Scale",& obs_pert%tcorr(1),rc=status) call LIS_verify(status) - + call ESMF_AttributeSet(pertField(n),"X Correlation Scale",& obs_pert%xcorr(1),rc=status) - + call ESMF_AttributeSet(pertField(n),"Y Correlation Scale",& obs_pert%ycorr(1),rc=status) @@ -439,7 +401,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) obs_pert%ccorr(1,:),itemCount=1,rc=status) endif - + deallocate(vname) deallocate(varmax) deallocate(varmin) @@ -450,13 +412,13 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) write(LIS_logunit,*) & '[INFO] Created the States to hold the SMAP NASA observations data' do n=1,LIS_rc%nnest - if(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP") then + if(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP") then cdfT_SMAPsm_struc(n)%nc = 964 cdfT_SMAPsm_struc(n)%nr = 406 elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP") then cdfT_SMAPsm_struc(n)%nc = 964 cdfT_SMAPsm_struc(n)%nr = 406 - elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E") then + elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E") then cdfT_SMAPsm_struc(n)%nc = 3856 cdfT_SMAPsm_struc(n)%nr = 1624 elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") then @@ -466,16 +428,14 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) allocate(cdfT_SMAPsm_struc(n)%smobs(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k))) allocate(cdfT_SMAPsm_struc(n)%smtime(LIS_rc%obs_lnc(k),LIS_rc%obs_lnr(k))) - + cdfT_SMAPsm_struc(n)%smtime = -1 - - enddo + enddo write(LIS_logunit,*)& '[INFO] read cdf transfer data specifications' - do n=1,LIS_rc%nnest allocate(ssdev(LIS_rc%obs_ngrid(k))) ssdev = obs_pert%ssdev(1) @@ -485,20 +445,20 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) call LIS_getCDFtransferattributes(k,cdfT_SMAPsm_struc(n)%modelcdffile,& cdfT_SMAPsm_struc(n)%n_strat_bins , cdfT_SMAPsm_struc(n)%ntimes) - allocate(cdfT_SMAPsm_struc(n)%model_xrange(& - cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & - cdfT_SMAPsm_struc(n)%nbins)) - allocate(cdfT_SMAPsm_struc(n)%obs_xrange(& - cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & - cdfT_SMAPsm_struc(n)%nbins)) - allocate(cdfT_SMAPsm_struc(n)%model_cdf(& - cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & - cdfT_SMAPsm_struc(n)%nbins)) - allocate(cdfT_SMAPsm_struc(n)%obs_cdf(& - cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & - cdfT_SMAPsm_struc(n)%nbins)) - write(LIS_logunit,*)& - '[INFO] Successfully read cdf transfer data specifications' + allocate(cdfT_SMAPsm_struc(n)%model_xrange(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%obs_xrange(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%model_cdf(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + allocate(cdfT_SMAPsm_struc(n)%obs_cdf(& + cdfT_SMAPsm_struc(n)%n_strat_bins, cdfT_SMAPsm_struc(n)%ntimes, & + cdfT_SMAPsm_struc(n)%nbins)) + write(LIS_logunit,*)& + '[INFO] Successfully read cdf transfer data specifications' endif if(cdfT_SMAPsm_struc(n)%useSsdevScal.eq.1) then @@ -526,7 +486,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) gridDesci(3) = 406 gridDesci(9) = 4 !M36 grid gridDesci(20) = 64 - gridDesci(10) = 0.36 + gridDesci(10) = 0.36 gridDesci(11) = 1 !for the global switch elseif(cdfT_SMAPsm_struc(n)%data_designation.eq."SPL3SMP_E".or.& cdfT_SMAPsm_struc(n)%data_designation.eq."SPL2SMP_E") then @@ -536,7 +496,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) gridDesci(3) = 1624 gridDesci(9) = 5 !M09 grid gridDesci(20) = 64 - gridDesci(10) = 0.09 + gridDesci(10) = 0.09 gridDesci(11) = 1 !for the global switch endif @@ -546,7 +506,7 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k))) allocate(cdfT_SMAPsm_struc(n)%rlon(& LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k))) - + call neighbor_interp_input_withgrid(gridDesci,& LIS_rc%obs_gridDesc(k,:),& LIS_rc%obs_lnc(k)*LIS_rc%obs_lnr(k),& @@ -563,11 +523,11 @@ subroutine cdfTransfer_NASASMAPsm_setup(k, OBS_State, OBS_Pert_State) 3600.0, 3600.0) endif - cdfT_SMAPsm_struc(n)%startMode = .true. + cdfT_SMAPsm_struc(n)%startMode = .true. call ESMF_StateAdd(OBS_State(n),(/obsField(n)/),rc=status) call LIS_verify(status) - + call ESMF_StateAdd(OBS_Pert_State(n),(/pertField(n)/),rc=status) call LIS_verify(status) diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 index 99be20224..d07c4df8c 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 @@ -381,37 +381,6 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) enddo enddo -#if 0 -!------------------------------------------------------------------------- -! From the SMAP documentation: -! The current approach for the SPL3SMP product is to use the nearest -! 6:00 a.m. LST criterion to perform Level-3 compositing for the -! descending passes. According to this criterion, for a given grid cell, -! an L2 data point acquired closest to 6:00 a.m. local solar time will -! make its way to the final Level-3 file; other late-coming L2 data -! points falling into the same grid cell will be ignored. For a given -! file whose time stamp (yyyy-mm-ddThh:mm:ss) is expressed in UTC, only -! the hh:mm:ss part is converted into local solar time. -! (O'Neill et al. 2012) -!------------------------------------------------------------------------- - do r = 1, LIS_rc%obs_lnr(k) - do c = 1, LIS_rc%obs_lnc(k) - grid_index = LIS_obs_domain(n, k)%gindex(c, r) - if (grid_index .ne. -1) then - - if (smobs(c + (r - 1)*LIS_rc%obs_lnc(k)) .ne. -9999.0) then - cdfT_SMAPsm_struc(n)%smobs(c, r) = & - smobs(c + (r - 1)*LIS_rc%obs_lnc(k)) - lon = LIS_obs_domain(n, k)%lon(c + (r - 1)*LIS_rc%obs_lnc(k)) - lhour = 6.0 - call LIS_localtime2gmt(gmt, lon, lhour, zone) - cdfT_SMAPsm_struc(n)%smtime(c, r) = gmt - endif - endif - enddo - enddo -#endif - endif ! sensor endif ! alram @@ -477,30 +446,29 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) !------------------------------------------------------------------------- -! Transform data to the LSM climatology using a geolocation independent +! Transform data to the LSM climatology using a geolocation independent ! CDF-scaling approach !------------------------------------------------------------------------- if (cdfT_SMAPsm_struc(n)%useCDFtransfer .gt. 0) then if (LIS_rc%da .eq. 1 .and. LIS_rc%hr .eq. 0 .and. & LIS_rc%mn .eq. 0 .and. LIS_rc%ss .eq. 0) then - call read_CDFtransferdata_all(n,k,& - cdfT_SMAPsm_struc(n)%nbins,& - cdfT_SMAPsm_struc(n)%ntimes,& - cdfT_SMAPsm_struc(n)%n_strat_bins, & - cdfT_SMAPsm_struc(n)%modelcdffile, & - "SoilMoist",& - cdfT_SMAPsm_struc(n)%model_xrange,& - cdfT_SMAPsm_struc(n)%model_cdf) - - call read_CDFtransferdata_all(n,k,& - cdfT_SMAPsm_struc(n)%nbins,& - cdfT_SMAPsm_struc(n)%ntimes,& - cdfT_SMAPsm_struc(n)%n_strat_bins, & - cdfT_SMAPsm_struc(n)%obscdffile, & - "SoilMoist",& - cdfT_SMAPsm_struc(n)%obs_xrange,& - cdfT_SMAPsm_struc(n)%obs_cdf) - + call read_CDFtransferdata_all(n,k,& + cdfT_SMAPsm_struc(n)%nbins,& + cdfT_SMAPsm_struc(n)%ntimes,& + cdfT_SMAPsm_struc(n)%n_strat_bins, & + cdfT_SMAPsm_struc(n)%modelcdffile, & + "SoilMoist",& + cdfT_SMAPsm_struc(n)%model_xrange,& + cdfT_SMAPsm_struc(n)%model_cdf) + + call read_CDFtransferdata_all(n,k,& + cdfT_SMAPsm_struc(n)%nbins,& + cdfT_SMAPsm_struc(n)%ntimes,& + cdfT_SMAPsm_struc(n)%n_strat_bins, & + cdfT_SMAPsm_struc(n)%obscdffile, & + "SoilMoist",& + cdfT_SMAPsm_struc(n)%obs_xrange,& + cdfT_SMAPsm_struc(n)%obs_cdf) endif if (fnd .ne. 0) then @@ -518,8 +486,8 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) cdfT_SMAPsm_struc(n)%ref_p_climo_maxval, & cdfT_SMAPsm_struc(n)%target_p_climo,& cdfT_SMAPsm_struc(n)%n_strat_bins,& - sm_current) - endif + sm_current) + endif endif obsl = LIS_rc%udef @@ -588,40 +556,6 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) write(LIS_logunit,*) '[ERR] for CDF transfer method' call LIS_endrun() endif -#if 0 - if (LIS_rc%dascaloption(k) .eq. "CDF matching") then - if (cdfT_SMAPsm_struc(n)%useSsdevScal .eq. 1) then - call ESMF_StateGet(OBS_Pert_State, "Observation01", pertfield, & - rc=status) - call LIS_verify(status, 'Error: StateGet Observation01') - - allocate (ssdev(LIS_rc%obs_ngrid(k))) - ssdev = cdfT_SMAPsm_struc(n)%ssdev_inp - - if (cdfT_SMAPsm_struc(n)%ntimes .eq. 1) then - jj = 1 - else - jj = LIS_rc%mo - endif - do t = 1, LIS_rc%obs_ngrid(k) - if (cdfT_SMAPsm_struc(n)%obs_sigma(t, jj) .gt. 0) then - ssdev(t) = ssdev(t)*cdfT_SMAPsm_struc(n)%model_sigma(t, jj)/ & - cdfT_SMAPsm_struc(n)%obs_sigma(t, jj) - if (ssdev(t) .lt. minssdev) then - ssdev(t) = minssdev - endif - endif - enddo - - if (LIS_rc%obs_ngrid(k) .gt. 0) then - call ESMF_AttributeSet(pertField, "Standard Deviation", & - ssdev, itemCount=LIS_rc%obs_ngrid(k), rc=status) - call LIS_verify(status) - endif - deallocate (ssdev) - endif - endif -#endif else call ESMF_AttributeSet(OBS_State, "Data Update Status", & .false., rc=status) @@ -631,28 +565,28 @@ subroutine read_cdfTransfer_NASASMAPsm(n, k, OBS_State, OBS_Pert_State) end subroutine read_cdfTransfer_NASASMAPsm !BOP -! +! ! !ROUTINE: read_SMAPL2sm_data_cdfTransfer ! \label{read_SMAPL2sm_data_cdfTransfer} ! ! !INTERFACE: subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) -! -! !USES: +! +! !USES: use LIS_coreMod use LIS_logMod use LIS_timeMgrMod use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc -#if (defined USE_HDF5) +#if (defined USE_HDF5) use hdf5 #endif implicit none ! -! !INPUT PARAMETERS: -! +! !INPUT PARAMETERS: +! integer :: n integer :: k character (len=*) :: fname @@ -662,7 +596,7 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) ! !OUTPUT PARAMETERS: ! ! -! !DESCRIPTION: +! !DESCRIPTION: ! ! !EOP @@ -718,7 +652,7 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) call h5dopen_f(sm_gr_id, sm_qa_name,sm_qa_id, status) call LIS_verify(status, 'Error opening QA field in SMAP L2 file') -!YK +!YK call h5dopen_f(sm_gr_id, vwc_field_name,vwc_field_id, status) call LIS_verify(status, 'Error opening Veg water content field in SMAP L2 file') @@ -726,7 +660,7 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) call LIS_verify(status, 'Error in h5dget_space_f: reaSMAP L2Obs') ! Size of the arrays -! This routine returns -1 on failure, rank on success. +! This routine returns -1 on failure, rank on success. call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, status) if(status.eq.-1) then call LIS_verify(status, 'Error in h5sget_simple_extent_dims_f: readSMAP L2Obs') @@ -759,7 +693,7 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) call h5dclose_f(sm_qa_id,status) call LIS_verify(status,'Error in H5DCLOSE call') -!YK +!YK call h5dclose_f(vwc_field_id,status) call LIS_verify(status,'Error in H5DCLOSE call') @@ -784,19 +718,6 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) sm_data = LIS_rc%udef sm_data_b = .false. -!-------------------------------------------------------------------original -!!grid the data in EASE projection -! do t=1,maxdims(1) -! if(ease_col(t).gt.0.and.ease_row(t).gt.0) then -! sm_data(ease_col(t) + & -! (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = sm_field(t) -! if(sm_field(t).ne.-9999.0) then -! sm_data_b(ease_col(t) + & -! (ease_row(t)-1)*cdfT_SMAPsm_struc(n)%nc) = .true. -! endif -! endif -! enddo - !--------------------------------------------------------------------YK !grid the data in EASE projection ! The retrieval_quality_field variable's binary representation consists of bits @@ -828,10 +749,9 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) enddo !----------------------------------------------------------------------- - !t = 1 !-------------------------------------------------------------------------- ! Interpolate to the LIS running domain -!-------------------------------------------------------------------------- +!-------------------------------------------------------------------------- call neighbor_interp(LIS_rc%obs_gridDesc(k,:), sm_data_b, sm_data, & smobs_b_ip, smobs_ip, & cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & @@ -841,11 +761,10 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) deallocate(sm_field) -! deallocate(sm_qa) deallocate(ease_row) deallocate(ease_col) -!overwrite the input data +!overwrite the input data do r=1,LIS_rc%obs_lnr(k) do c=1,LIS_rc%obs_lnc(k) if(smobs_ip(c+(r-1)*LIS_rc%obs_lnc(k)).ne.-9999.0) then @@ -862,28 +781,28 @@ subroutine read_SMAPL2sm_data_cdfTransfer(n, k,fname, smobs_inp, time) end subroutine read_SMAPL2sm_data_cdfTransfer !BOP -! +! ! !ROUTINE: read_NASASMAP_E_data_cdfTransfer ! \label{read_NASASMAP_E_data_cdfTransfer} ! ! !INTERFACE: subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) -! -! !USES: +! +! !USES: use LIS_coreMod, only : LIS_rc, LIS_domain use LIS_logMod use LIS_timeMgrMod use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc -#if (defined USE_HDF5) +#if (defined USE_HDF5) use hdf5 #endif implicit none ! -! !INPUT PARAMETERS: -! - integer :: n +! !INPUT PARAMETERS: +! + integer :: n integer :: k character (len=*) :: pass character (len=*) :: fname @@ -893,20 +812,20 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) ! !OUTPUT PARAMETERS: ! ! -! !DESCRIPTION: +! !DESCRIPTION: ! This subroutine reads the SMOS NESDIS binary file and applies the data ! quality flags to filter the data. !\normalsize ! ! tb_time_seconds -! Arithmetic average of the same parameters found in the -! fore- and aft-looking groups in the input SPL1CTB granule. -! The resulting parameter thus describes the average of UTC -! acquisition times of SPL1BTB observations whose boresights -! fall within a 36 km EASE-Grid 2.0 cell. The result is then -! expressed in J2000 seconds (the number of seconds since +! Arithmetic average of the same parameters found in the +! fore- and aft-looking groups in the input SPL1CTB granule. +! The resulting parameter thus describes the average of UTC +! acquisition times of SPL1BTB observations whose boresights +! fall within a 36 km EASE-Grid 2.0 cell. The result is then +! expressed in J2000 seconds (the number of seconds since ! 11:58:55.816 on January 1, 2000 UT). ! -! The arguments are: +! The arguments are: ! \begin{description} ! \item[n] index of the nest ! \item[fname] name of the RTNASASMAP AMSR-E file @@ -924,7 +843,7 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) character*100, parameter :: sm_gr_name_A = "Soil_Moisture_Retrieval_Data_PM" character*100, parameter :: sm_field_name_A = "soil_moisture_pm" character*100, parameter :: sm_qa_name_A = "retrieval_qual_flag_pm" -! MN +! MN character*100, parameter :: vwc_field_name_D = "vegetation_water_content" character*100, parameter :: vwc_field_name_A = "vegetation_water_content_pm" @@ -940,7 +859,7 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) integer(hid_t) :: file_id integer(hid_t) :: sm_gr_id_D,sm_field_id_D,sm_qa_id_D integer(hid_t) :: sm_gr_id_A,sm_field_id_A,sm_qa_id_A - integer(hid_t) :: vwc_field_id_D ! MN + integer(hid_t) :: vwc_field_id_D ! MN integer(hid_t) :: vwc_field_id_A ! MN real, allocatable :: sm_field(:,:) real, allocatable :: vwc_field(:,:)! MN @@ -954,7 +873,7 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) dimsm = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) count_file = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) count_mem = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) - + allocate(sm_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) allocate(sm_qa(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) allocate(vwc_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) @@ -965,31 +884,31 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5open_f(status) call LIS_verify(status, 'Error opening HDF fortran interface') - - call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) + + call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) call LIS_verify(status, 'Error opening NASASMAP file ') - - if(pass.eq.'D') then + + if(pass.eq.'D') then call h5gopen_f(file_id,sm_gr_name_D,sm_gr_id_D, status) call LIS_verify(status, 'Error opening SM group in NASASMAP file') - + call h5dopen_f(sm_gr_id_D,sm_field_name_D,sm_field_id_D, status) call LIS_verify(status, 'Error opening SM field in NASASMAP file') - + call h5dget_space_f(sm_field_id_D, dataspace, status) call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') - + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & start=offset_file, count=count_file, hdferr=status) call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') - + call h5screate_simple_f(memrank,dimsm, memspace, status) call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') - + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & start=offset_mem, count=count_mem, hdferr=status) call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') - + call h5dread_f(sm_field_id_D, H5T_NATIVE_REAL,sm_field,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') @@ -999,15 +918,15 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5dopen_f(sm_gr_id_D,sm_qa_name_D,sm_qa_id_D, status) call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') - + call h5dread_f(sm_qa_id_D, H5T_NATIVE_INTEGER,sm_qa,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') - + call h5dclose_f(sm_qa_id_D,status) call LIS_verify(status,'Error in H5DCLOSE call') -! MN get the vegetation water contnent +! MN get the vegetation water contnent call h5dopen_f(sm_gr_id_D,vwc_field_name_D,vwc_field_id_D, status) call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') @@ -1024,34 +943,34 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) else call h5gopen_f(file_id,sm_gr_name_A,sm_gr_id_A, status) call LIS_verify(status, 'Error opening SM group in NASASMAP file') - + call h5dopen_f(sm_gr_id_A,sm_field_name_A,sm_field_id_A, status) call LIS_verify(status, 'Error opening SM field in NASASMAP file') - + call h5dget_space_f(sm_field_id_A, dataspace, status) call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') - + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & start=offset_file, count=count_file, hdferr=status) call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') - + call h5screate_simple_f(memrank,dimsm, memspace, status) call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') - + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & start=offset_mem, count=count_mem, hdferr=status) call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') - + call h5dread_f(sm_field_id_A, H5T_NATIVE_REAL,sm_field,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') call h5dclose_f(sm_field_id_A,status) call LIS_verify(status,'Error in H5DCLOSE call') - + call h5dopen_f(sm_gr_id_A,sm_qa_name_A,sm_qa_id_A, status) call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') - + call h5dread_f(sm_qa_id_A, H5T_NATIVE_INTEGER,sm_qa,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') @@ -1059,7 +978,7 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5dclose_f(sm_qa_id_A,status) call LIS_verify(status,'Error in H5DCLOSE call') -! MN get the vegetation water contnent +! MN get the vegetation water contnent call h5dopen_f(sm_gr_id_A,vwc_field_name_A,vwc_field_id_A, status) call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') @@ -1072,35 +991,34 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5gclose_f(sm_gr_id_A,status) call LIS_verify(status,'Error in H5GCLOSE call') - + endif - + call h5fclose_f(file_id,status) call LIS_verify(status,'Error in H5FCLOSE call') - + call h5close_f(status) call LIS_verify(status,'Error in H5CLOSE call') - - sm_data_b = .false. + sm_data_b = .false. t = 1 ! The retrieval_quality_field variable's binary representation consists of bits -! that indicate whether retrieval is performed or not at a given grid cell. -! When retrieval is performed, it contains additional bits to further -! indicate the exit status and quality of the retrieval. The first bit +! that indicate whether retrieval is performed or not at a given grid cell. +! When retrieval is performed, it contains additional bits to further +! indicate the exit status and quality of the retrieval. The first bit ! indicates the recommended quality (0-means retrieval has recommended quality). do r=1,cdfT_SMAPsm_struc(n)%nr - do c=1,cdfT_SMAPsm_struc(n)%nc + do c=1,cdfT_SMAPsm_struc(n)%nc sm_data(t) = sm_field(c,r) - if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 + if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 sm_data(t) = LIS_rc%udef - else + else - if(sm_data(t).ne.-9999.0) then - if(ibits(sm_qa(c,r),0,1).eq.0) then + if(sm_data(t).ne.-9999.0) then + if(ibits(sm_qa(c,r),0,1).eq.0) then sm_data_b(t) = .true. else sm_data(t) = -9999.0 @@ -1116,7 +1034,7 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) !-------------------------------------------------------------------------- ! Interpolate to the LIS running domain -!-------------------------------------------------------------------------- +!-------------------------------------------------------------------------- call neighbor_interp(LIS_rc%obs_gridDesc(k,:),& sm_data_b, sm_data, smobs_b_ip, smobs_ip, & cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & @@ -1131,32 +1049,32 @@ subroutine read_NASASMAP_E_data_cdfTransfer(n, k, pass, fname, smobs_ip) end subroutine read_NASASMAP_E_data_cdfTransfer -! MN: the data structure in both 36 km and 9 km products is the same therefore +! MN: the data structure in both 36 km and 9 km products is the same therefore ! read_NASASMAP_E_data_cdfTransfer is similar to read_NASASMAP_data_cdfTransfer !BOP -! +! ! !ROUTINE: read_NASASMAP_data_cdfTransfer ! \label{read_NASASMAP_data_cdfTransfer} ! ! !INTERFACE: subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) -! -! !USES: +! +! !USES: use LIS_coreMod, only : LIS_rc, LIS_domain use LIS_logMod use LIS_timeMgrMod use cdfTransfer_NASASMAPsm_Mod, only : cdfT_SMAPsm_struc -#if (defined USE_HDF5) +#if (defined USE_HDF5) use hdf5 #endif implicit none ! -! !INPUT PARAMETERS: -! - integer :: n +! !INPUT PARAMETERS: +! + integer :: n integer :: k character (len=*) :: pass character (len=*) :: fname @@ -1166,20 +1084,20 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) ! !OUTPUT PARAMETERS: ! ! -! !DESCRIPTION: +! !DESCRIPTION: ! This subroutine reads the SMOS NESDIS binary file and applies the data ! quality flags to filter the data. !\normalsize ! ! tb_time_seconds -! Arithmetic average of the same parameters found in the -! fore- and aft-looking groups in the input SPL1CTB granule. -! The resulting parameter thus describes the average of UTC -! acquisition times of SPL1BTB observations whose boresights -! fall within a 36 km EASE-Grid 2.0 cell. The result is then -! expressed in J2000 seconds (the number of seconds since +! Arithmetic average of the same parameters found in the +! fore- and aft-looking groups in the input SPL1CTB granule. +! The resulting parameter thus describes the average of UTC +! acquisition times of SPL1BTB observations whose boresights +! fall within a 36 km EASE-Grid 2.0 cell. The result is then +! expressed in J2000 seconds (the number of seconds since ! 11:58:55.816 on January 1, 2000 UT). ! -! The arguments are: +! The arguments are: ! \begin{description} ! \item[n] index of the nest ! \item[fname] name of the RTNASASMAP AMSR-E file @@ -1197,7 +1115,7 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) character*100, parameter :: sm_gr_name_A = "Soil_Moisture_Retrieval_Data_PM" character*100, parameter :: sm_field_name_A = "soil_moisture_pm" character*100, parameter :: sm_qa_name_A = "retrieval_qual_flag_pm" -! MN +! MN character*100, parameter :: vwc_field_name_D = "vegetation_water_content" character*100, parameter :: vwc_field_name_A = "vegetation_water_content_pm" @@ -1213,7 +1131,7 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) integer(hid_t) :: file_id integer(hid_t) :: sm_gr_id_D,sm_field_id_D,sm_qa_id_D integer(hid_t) :: sm_gr_id_A,sm_field_id_A,sm_qa_id_A - integer(hid_t) :: vwc_field_id_D ! MN + integer(hid_t) :: vwc_field_id_D ! MN integer(hid_t) :: vwc_field_id_A ! MN real, allocatable :: sm_field(:,:) real, allocatable :: vwc_field(:,:)! MN @@ -1227,7 +1145,7 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) dimsm = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) count_file = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) count_mem = (/cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr/) - + allocate(sm_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) allocate(sm_qa(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) allocate(vwc_field(cdfT_SMAPsm_struc(n)%nc, cdfT_SMAPsm_struc(n)%nr)) @@ -1238,31 +1156,31 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5open_f(status) call LIS_verify(status, 'Error opening HDF fortran interface') - - call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) + + call h5fopen_f(trim(fname),H5F_ACC_RDONLY_F, file_id, status) call LIS_verify(status, 'Error opening NASASMAP file ') - - if(pass.eq.'D') then + + if(pass.eq.'D') then call h5gopen_f(file_id,sm_gr_name_D,sm_gr_id_D, status) call LIS_verify(status, 'Error opening SM group in NASASMAP file') - + call h5dopen_f(sm_gr_id_D,sm_field_name_D,sm_field_id_D, status) call LIS_verify(status, 'Error opening SM field in NASASMAP file') - + call h5dget_space_f(sm_field_id_D, dataspace, status) call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') - + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & start=offset_file, count=count_file, hdferr=status) call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') - + call h5screate_simple_f(memrank,dimsm, memspace, status) call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') - + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & start=offset_mem, count=count_mem, hdferr=status) call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') - + call h5dread_f(sm_field_id_D, H5T_NATIVE_REAL,sm_field,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') @@ -1272,15 +1190,15 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5dopen_f(sm_gr_id_D,sm_qa_name_D,sm_qa_id_D, status) call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') - + call h5dread_f(sm_qa_id_D, H5T_NATIVE_INTEGER,sm_qa,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') - + call h5dclose_f(sm_qa_id_D,status) call LIS_verify(status,'Error in H5DCLOSE call') -! MN get the vegetation water contnent +! MN get the vegetation water contnent call h5dopen_f(sm_gr_id_D,vwc_field_name_D,vwc_field_id_D, status) call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') @@ -1297,34 +1215,34 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) else call h5gopen_f(file_id,sm_gr_name_A,sm_gr_id_A, status) call LIS_verify(status, 'Error opening SM group in NASASMAP file') - + call h5dopen_f(sm_gr_id_A,sm_field_name_A,sm_field_id_A, status) call LIS_verify(status, 'Error opening SM field in NASASMAP file') - + call h5dget_space_f(sm_field_id_A, dataspace, status) call LIS_verify(status, 'Error in h5dget_space_f: readNASASMAPObs') - + call h5sselect_hyperslab_f(dataspace, H5S_SELECT_SET_F, & start=offset_file, count=count_file, hdferr=status) call LIS_verify(status, 'Error setting hyperslab dataspace in readNASASMAPObs') - + call h5screate_simple_f(memrank,dimsm, memspace, status) call LIS_verify(status, 'Error in h5create_simple_f; read_cdfTransfer_NASASMAPsm') - + call h5sselect_hyperslab_f(memspace, H5S_SELECT_SET_F, & start=offset_mem, count=count_mem, hdferr=status) call LIS_verify(status, 'Error in h5sselect_hyperslab_f: read_cdfTransfer_NASASMAPsm') - + call h5dread_f(sm_field_id_A, H5T_NATIVE_REAL,sm_field,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM field from NASASMAPfile') call h5dclose_f(sm_field_id_A,status) call LIS_verify(status,'Error in H5DCLOSE call') - + call h5dopen_f(sm_gr_id_A,sm_qa_name_A,sm_qa_id_A, status) call LIS_verify(status, 'Error opening SM QA field in NASASMAP file') - + call h5dread_f(sm_qa_id_A, H5T_NATIVE_INTEGER,sm_qa,dims,status, & memspace, dataspace) call LIS_verify(status, 'Error extracting SM QA field from NASASMAPfile') @@ -1332,7 +1250,7 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5dclose_f(sm_qa_id_A,status) call LIS_verify(status,'Error in H5DCLOSE call') -! MN get the vegetation water contnent +! MN get the vegetation water contnent call h5dopen_f(sm_gr_id_A,vwc_field_name_A,vwc_field_id_A, status) call LIS_verify(status, 'Error opening Veg water content field in NASASMAP file') @@ -1345,34 +1263,34 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) call h5gclose_f(sm_gr_id_A,status) call LIS_verify(status,'Error in H5GCLOSE call') - + endif - + call h5fclose_f(file_id,status) call LIS_verify(status,'Error in H5FCLOSE call') - + call h5close_f(status) call LIS_verify(status,'Error in H5CLOSE call') - sm_data_b = .false. + sm_data_b = .false. t = 1 ! The retrieval_quality_field variable's binary representation consists of bits -! that indicate whether retrieval is performed or not at a given grid cell. -! When retrieval is performed, it contains additional bits to further -! indicate the exit status and quality of the retrieval. The first bit +! that indicate whether retrieval is performed or not at a given grid cell. +! When retrieval is performed, it contains additional bits to further +! indicate the exit status and quality of the retrieval. The first bit ! indicates the recommended quality (0-means retrieval has recommended quality). do r=1,cdfT_SMAPsm_struc(n)%nr - do c=1,cdfT_SMAPsm_struc(n)%nc + do c=1,cdfT_SMAPsm_struc(n)%nc sm_data(t) = sm_field(c,r) - if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 + if(vwc_field(c,r).gt. 5 ) then !MN Aply QC : if VWC > 5 kg/m2 sm_data(t) = LIS_rc%udef - else + else - if(sm_data(t).ne.-9999.0) then - if(ibits(sm_qa(c,r),0,1).eq.0) then + if(sm_data(t).ne.-9999.0) then + if(ibits(sm_qa(c,r),0,1).eq.0) then sm_data_b(t) = .true. else sm_data(t) = -9999.0 @@ -1388,7 +1306,7 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) !-------------------------------------------------------------------------- ! Interpolate to the LIS running domain -!-------------------------------------------------------------------------- +!-------------------------------------------------------------------------- call neighbor_interp(LIS_rc%obs_gridDesc(k,:),& sm_data_b, sm_data, smobs_b_ip, smobs_ip, & cdfT_SMAPsm_struc(n)%nc*cdfT_SMAPsm_struc(n)%nr, & @@ -1402,77 +1320,6 @@ subroutine read_NASASMAP_data_cdfTransfer(n, k, pass, fname, smobs_ip) #endif - end subroutine read_NASASMAP_data_cdfTransfer -#if 0 -!BOP -! !ROUTINE: create_cdfTransfer_NASASMAPsm_filename -! \label{create_cdfTransfer_NASASMAPsm_filename} -! -! !INTERFACE: -subroutine create_cdfTransfer_NASASMAPsm_filename(ndir, designation, yr, mo,da, filename) -! !USES: - - implicit none -! !ARGUMENTS: - character(len=*) :: filename - character(len=*) :: designation - integer :: yr, mo, da - character (len=*) :: ndir -! -! !DESCRIPTION: -! This subroutine creates the SMAP filename (from NSIDC) -! based on the time and date -! -! The arguments are: -! \begin{description} -! \item[ndir] name of the SMAP soil moisture data directory -! \item[yr] current year -! \item[mo] current month -! \item[da] current day -! \item[filename] Generated SMAP filename -! \end{description} -!EOP - - character (len=4) :: fyr - character (len=2) :: fmo,fda - - write(unit=fyr, fmt='(i4.4)') yr - write(unit=fmo, fmt='(i2.2)') mo - write(unit=fda, fmt='(i2.2)') da - - if(designation.eq."SPL3SMAP") then - filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& - trim(fda)//'/SMAP_L3_SM_AP_'& - //trim(fyr)//trim(fmo)//trim(fda)//& - '_R12170_001.h5' -! MN: -! The SMAP file names contain components that change in a way that -! is difficult to programatically generate. So after downloading -! a SMAP data file, a symbolic link was created to it which make it -! easier to generate file name. -! For example: -! SMAP_L3_SM_P_20170902.h5 -> SMAP_L3_SM_P_20170902_R15152_001.h5 - elseif(designation.eq."SPL3SMP") then - filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& - trim(fda)//'/SMAP_L3_SM_P_'& - //trim(fyr)//trim(fmo)//trim(fda)//& - '.h5' -! For example: -! SMAP_L3_SM_P_E_20180811.h5 -> SMAP_L3_SM_P_E_20180811_R16010_001.h5 -! MN for sake of convenience instead of real name the symbolic link was used - elseif(designation.eq."SPL3SMP_E") then - filename = trim(ndir)//'/'//trim(fyr)//'.'//trim(fmo)//'.'//& - trim(fda)//'/SMAP_L3_SM_P_E_'& - //trim(fyr)//trim(fmo)//trim(fda)//& - '.h5' - - endif - -end subroutine create_cdfTransfer_NASASMAPsm_filename - -#endif - - diff --git a/lis/plugins/LIS_DAobs_pluginMod.F90 b/lis/plugins/LIS_DAobs_pluginMod.F90 index 2fda9e9e8..680b12dc3 100644 --- a/lis/plugins/LIS_DAobs_pluginMod.F90 +++ b/lis/plugins/LIS_DAobs_pluginMod.F90 @@ -249,9 +249,8 @@ subroutine LIS_DAobs_plugin #if ( defined DA_OBS_NASA_SMAPSM ) use NASASMAPsm_Mod, only : NASASMAPsm_setup -! use cdfTransfer_Mod, only : cdfTransfer_setup #endif - + #if ( defined DA_CDF_TRANSFER_NASA_SMAPSM ) use cdfTransfer_NASASMAPsm_Mod, only : cdfTransfer_NASASMAPsm_setup #endif From a2208e91a93ed475505592e1c59b0bbdb7b2824e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 17 Oct 2023 08:23:04 -0400 Subject: [PATCH 187/328] First import of new gage processing code. Needs to be integrated into LIS-AGRMET. --- lis/metforcing/usaf/USAF_GagesMod.F90 | 2481 ++++++++++++++++++ lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 1054 ++++++++ 2 files changed, 3535 insertions(+) create mode 100644 lis/metforcing/usaf/USAF_GagesMod.F90 create mode 100644 lis/metforcing/usaf/USAF_PreobsReaderMod.F90 diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 new file mode 100644 index 000000000..ef8c7496c --- /dev/null +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -0,0 +1,2481 @@ +! +! MODULE: USAF_GagesMod +! +! DESCRIPTION: Contains structure and related routines for storing and +! updating new database of rain gauge reports from USAF. Includes +! routines to reconcile reports by intercomparison. +! +! AUTHOR: Eric Kemp, SSAI/NASA GSFC +! +! REFERENCES: +! Durre, I, M J Menne, B E Gleason, T G Houston, and R S Vose, 2010: +! Comprehensive automated quality assurance of daily surface observations. +! J Appl Meteor Climatol, 49, 1615-1633, +! https://doi.org/10.1175/2010JAMC2375.1 +! Qi, Y, S Martinaitis, J Zhang, and S Cocks, 2016: A real-time automated +! quality control of hourly rain gauge data based on multiple sensors in +! MRMS system. J Hydrometeor, 17, 1675-1691, +! https://doi.org/10.1175/JHM-D-15-0188.1 +! WMO, 2019: Manual on Codes, International Codes, Volume I.1, Part A -- +! Alphanumeric Codes. WMO No. 306, +! https://library.wmo.int/doc_num.php?explnum_id=10235 +! WMO, 2021: Manual on Codes, International Codes, Volume I.2, Part B -- +! Binary Codes. WMO No. 306, +! https://library.wmo.int/doc_num.php?explnum_id=10722 +! WMO, 2018: Manual on Codes, Regional Codes and National Coding Practices, +! Volume II. WMO No. 306, +! https://library.wmo.int/doc_num.php?explnum_id=5730 +! WMO, 2012: Weather Reporting, Volume A -- Observing Stations. WMO No. 9, +! https://library.wmo.int/doc_num.php?explnum_id=9896 +! +! REVISION HISTORY: +! 30 Aug 2021...First developmental version committed to git. +! 03 Aug 2023...Added 1-hr and 2-hr accumulations, date/times of each +! observation, and ob-specific past weather durations. +! 23 Aug 2023...Added both WMO and FIPS country codes. +! 07 Sep 2023...Fixed WMO block check (values in preobs files are typically +! <= 100, so these are multipied by 1000 or 10000 to check for country +! ranges). +!------------------------------------------------------------------------------ + +module USAF_GagesMod + + ! Defaults + implicit none + private + + type, public :: USAF_Gages_t + private + logical :: cdms_flag + character(10) :: date10 + integer :: nobs + character(14), allocatable :: YYYYMMDDhhmmss(:) + character(10), allocatable :: networks(:) + character(32), allocatable :: platforms(:) + character(2), allocatable :: wmocode_id(:) + character(2), allocatable :: fipscode_id(:) + integer, allocatable :: wmonumbers(:) + integer, allocatable :: bsn(:) + ! NOTE: Latitudes and longitudes are in hundreths of degrees + ! (100 = 1.00 deg) + integer, allocatable :: lats(:) + integer, allocatable :: lons(:) + ! NOTE: Accumulations are in tenths of mm (10 = 1 mm) + integer, allocatable :: amts24(:) + integer, allocatable :: amts21(:) ! Non-standard + integer, allocatable :: amts18(:) + integer, allocatable :: amts15(:) + integer, allocatable :: amts12(:) + ! "Original", non-filled or reconciled 12hr amount, needed for + ! some 12Z South America sanity checks. These are not written + ! to the presav2 file. + integer, allocatable :: amts12_orig(:) + integer, allocatable :: amts09(:) + integer, allocatable :: amts06(:) + ! "Original", non-filled or reconciled 06hr amount, needed for + ! some 12Z South America sanity checks. These are not written + ! to the presav2 file. + integer, allocatable :: amts06_orig(:) + integer, allocatable :: amts03(:) + integer, allocatable :: amts02(:) + integer, allocatable :: amts01(:) + integer, allocatable :: amts00(:) ! Non-standard accumulations + integer, allocatable :: durations(:) ! Durations of non-std accums + integer, allocatable :: preswx(:) + integer, allocatable :: pastwx(:) + integer, allocatable :: pastwx_durations(:) + character(10), allocatable :: unique_networks(:) + integer, allocatable :: firsts(:) ! Starting indices for each network + integer, allocatable :: lasts(:) ! Ending indices for each network + integer :: num_unique_networks + contains + procedure :: new => USAF_gages_new + procedure :: read_data => USAF_gages_read_data + procedure :: delete => USAF_gages_delete + procedure :: check_gross_errors => & + USAF_gages_check_gross_errors + procedure :: use_misc_precip => USAF_gages_use_misc_precip + procedure :: reconcile_self => USAF_gages_reconcile_self + procedure :: reconcile_gages01 => USAF_gages_reconcile_gages01 + procedure :: reconcile_gages02 => USAF_gages_reconcile_gages02 + procedure :: reconcile_gages03 => USAF_gages_reconcile_gages03 + procedure :: reconcile_gages06 => USAF_gages_reconcile_gages06 + procedure :: reconcile_gages09 => USAF_gages_reconcile_gages09 + procedure :: reconcile_gages12 => USAF_gages_reconcile_gages12 + procedure :: reconcile_gages15 => USAF_gages_reconcile_gages15 + procedure :: reconcile_gages18 => USAF_gages_reconcile_gages18 + procedure :: reconcile_gages21 => USAF_gages_reconcile_gages21 + procedure :: correct_region3_12Z => USAF_gages_correct_region3_12Z + procedure :: use_preswx_pastwx => USAF_gages_use_preswx_pastwx + procedure :: fill_gaps => USAF_gages_fill_gaps + procedure :: write_data => USAF_gages_write_data + procedure :: set_pastwx_durations => USAF_gages_set_pastwx_durations + end type USAF_Gages_t + + ! Local parameters + integer, parameter :: MAX_UNIQUE_NETWORKS = 25 + integer, parameter :: MISSING = -99999999 + character(4), parameter :: MISSING_NAME = "NULL" + + ! Old CDMS replacements for WMO numbers + ! The following two are guesses + integer, parameter :: CDMS_SWEDEN_LOWLIMIT = 020010 + integer, parameter :: CDMS_SWEDEN_HIGHLIMIT = 026999 + ! The following two are guesses + integer, parameter :: CDMS_DENMARK_LOWLIMIT = 060010 + integer, parameter :: CDMS_DENMARK_HIGHLIMIT = 061999 + integer, parameter :: CDMS_RUSSIA_LOWLIMIT = 200000 + integer, parameter :: CDMS_RUSSIA_HIGHLIMIT = 390009 + integer, parameter :: CDMS_INDIA_LOWLIMIT = 420010 + integer, parameter :: CDMS_INDIA_HIGHLIMIT = 433999 + integer, parameter :: CDMS_SRILANKA_LOWLIMIT = 434000 + integer, parameter :: CDMS_SRILANKA_HIGHLIMIT = 434979 + integer, parameter :: CDMS_S_AMER_LOWLIMIT = 800000 + integer, parameter :: CDMS_S_AMER_HIGHLIMIT = 889999 + + ! JMOBS WMO Numbers. + integer, parameter, public :: JMOBS_SWEDEN_LOWLIMIT = 02001 + integer, parameter, public :: JMOBS_SWEDEN_HIGHLIMIT = 02699 + integer, parameter, public :: JMOBS_DENMARK_LOWLIMIT = 06001 + integer, parameter, public :: JMOBS_DENMARK_HIGHLIMIT = 06199 + integer, parameter, public :: JMOBS_RUSSIA_LOWLIMIT = 20000 + integer, parameter, public :: JMOBS_RUSSIA_HIGHLIMIT = 39000 + integer, parameter, public :: JMOBS_INDIA_LOWLIMIT = 42000 + integer, parameter, public :: JMOBS_INDIA_HIGHLIMIT = 43399 + integer, parameter, public :: JMOBS_SRILANKA_LOWLIMIT = 43400 + integer, parameter, public :: JMOBS_SRILANKA_HIGHLIMIT = 43497 + integer, parameter, public :: JMOBS_S_AMER_LOWLIMIT = 80000 + integer, parameter, public :: JMOBS_S_AMER_HIGHLIMIT = 88999 + + ! Maximum allowed accumulations + ! Values below are in tenths of mm (10 = 1 mm) + ! Qi et al. (2016) use 50.8 mm (2 in) for 1 hour accum, based on + ! subjective evaluation in CONUS regions with poor radar coverage; + ! they judged approximately 97% of observations above this amount were + ! erroneous. + integer, parameter :: MAX_PCP_1HR = 508 ! 2 inches + integer, parameter :: MAX_PCP_2HR = 1016 ! 4 inches + integer, parameter :: MAX_PCP_3HR = 1524 ! 6 inches + integer, parameter :: MAX_PCP_6HR = 3048 ! 12 inches + integer, parameter :: MAX_PCP_9HR = 4572 ! 18 inches + integer, parameter :: MAX_PCP_12HR = 6096 ! 24 inches + integer, parameter :: MAX_PCP_15HR = 7620 ! 30 inches + integer, parameter :: MAX_PCP_18HR = 9144 ! 36 inches + integer, parameter :: MAX_PCP_21HR = 10668 ! 42 inches + integer, parameter :: MAX_PCP_24HR = 12192 ! 48 inches + + ! Durre et al (2010) use 1828.8 mm (72 in) for 24-hr limit, based on WMO + ! world record for 24-hr accumulation. + ! integer, parameter :: MAX_PCP_3HR = 2286 ! 9 inches + ! integer, parameter :: MAX_PCP_6HR = 4572 ! 18 inches + ! integer, parameter :: MAX_PCP_9HR = 6858 ! 27 inches + ! integer, parameter :: MAX_PCP_12HR = 9144 ! 36 inches + ! integer, parameter :: MAX_PCP_15HR = 11430 ! 45 inches + ! integer, parameter :: MAX_PCP_18HR = 13716 ! 54 inches + ! integer, parameter :: MAX_PCP_21HR = 16002 ! 63 inches + ! integer, parameter :: MAX_PCP_24HR = 18288 ! 72 inches + + ! Note: WMO world records. See https://wmo.asu.edu + ! 1-hr rainfall: 305 mm (12 inch), Holt MO, USA, June 1947 + ! 12-hr rainfall: 1144 mm (45 inch), Foc-Foc, La Reunion, Jan 1966 + ! 24-hr rainfall: 1825 mm (71.8 inch), Foc-Foc, La Reunion, Jan 1966 + +contains + + ! Constructor for USAF_gages_t type + subroutine USAF_gages_new(this, date10, & + nobs, YYYYMMDDhhmmss, networks, platforms, & + wmocode_id, fipscode_id, & + wmonumbers, bsn, lats, lons, & + amts24, amts21, amts18, amts15, amts12, amts09, amts06, amts03, & + amts02, amts01, & + amts00, durations, preswx, pastwx) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(out) :: this + character(10), intent(in) :: date10 + integer, intent(in) :: nobs + character(14), intent(in) :: YYYYMMDDhhmmss(nobs) + character(10), intent(in) :: networks(nobs) + character(32), intent(in) :: platforms(nobs) + character(2), intent(in) :: wmocode_id(nobs) + character(2), intent(in) :: fipscode_id(nobs) + integer, intent(in) :: wmonumbers(nobs) + integer, intent(in) :: bsn(nobs) + integer, intent(in) :: lats(nobs) + integer, intent(in) :: lons(nobs) + integer, intent(in) :: amts24(nobs) + integer, intent(in) :: amts21(nobs) + integer, intent(in) :: amts18(nobs) + integer, intent(in) :: amts15(nobs) + integer, intent(in) :: amts12(nobs) + integer, intent(in) :: amts09(nobs) + integer, intent(in) :: amts06(nobs) + integer, intent(in) :: amts03(nobs) + integer, intent(in) :: amts02(nobs) + integer, intent(in) :: amts01(nobs) + integer, intent(in) :: amts00(nobs) + integer, intent(in) :: durations(nobs) + integer, intent(in) :: preswx(nobs) + integer, intent(in) :: pastwx(nobs) + + this%date10 = date10 + + this%nobs = nobs + + allocate(this%YYYYMMDDhhmmss(nobs)) + this%YYYYMMDDhhmmss = YYYYMMDDhhmmss + + allocate(this%networks(nobs)) + this%networks = networks + + allocate(this%platforms(nobs)) + this%platforms = platforms + + allocate(this%wmocode_id(nobs)) + this%wmocode_id = wmocode_id + + allocate(this%fipscode_id(nobs)) + this%fipscode_id = fipscode_id + + allocate(this%wmonumbers(nobs)) + this%wmonumbers = wmonumbers + + allocate(this%bsn(nobs)) + this%bsn = bsn + + allocate(this%lats(nobs)) + this%lats = lats + + allocate(this%lons(nobs)) + this%lons = lons + + allocate(this%amts24(nobs)) + this%amts24 = amts24 + + allocate(this%amts21(nobs)) + this%amts21 = amts21 + + allocate(this%amts18(nobs)) + this%amts18 = amts18 + + allocate(this%amts15(nobs)) + this%amts15 = amts15 + + allocate(this%amts12(nobs)) + this%amts12 = amts12 + + allocate(this%amts12_orig(nobs)) + this%amts12_orig = amts12 + + allocate(this%amts09(nobs)) + this%amts09 = amts09 + + allocate(this%amts06(nobs)) + this%amts06 = amts06 + + allocate(this%amts06_orig(nobs)) + this%amts06_orig = amts06 + + allocate(this%amts03(nobs)) + this%amts03 = amts03 + + allocate(this%amts02(nobs)) + this%amts02 = amts02 + + allocate(this%amts01(nobs)) + this%amts01 = amts01 + + allocate(this%amts00(nobs)) + this%amts00 = amts00 + + allocate(this%durations(nobs)) + this%durations = durations + + allocate(this%preswx(nobs)) + this%preswx = preswx + + allocate(this%pastwx(nobs)) + this%pastwx = pastwx + + !this%pastwx_duration = set_pastwx_duration(date10) + allocate(this%pastwx_durations(nobs)) + call this%set_pastwx_durations() + + ! Make sure lats/lons are valid. + call check_latlons(this) + + ! Handle arrays for unique networks in private method. Also set & + ! cdms_flag. + call set_unique_networks(this) + + end subroutine USAF_gages_new + + ! Destructor + subroutine USAF_gages_delete(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + this%date10 = "NULL" + + this%nobs = 0 + if (allocated(this%YYYYMMDDhhmmss)) deallocate(this%YYYYMMDDhhmmss) + if (allocated(this%networks)) deallocate(this%networks) + if (allocated(this%platforms)) deallocate(this%platforms) + if (allocated(this%wmocode_id)) deallocate(this%wmocode_id) + if (allocated(this%fipscode_id)) deallocate(this%fipscode_id) + if (allocated(this%wmonumbers)) deallocate(this%wmonumbers) + if (allocated(this%bsn)) deallocate(this%bsn) + if (allocated(this%lats)) deallocate(this%lats) + if (allocated(this%lons)) deallocate(this%lons) + if (allocated(this%amts24)) deallocate(this%amts24) + if (allocated(this%amts21)) deallocate(this%amts21) + if (allocated(this%amts18)) deallocate(this%amts18) + if (allocated(this%amts15)) deallocate(this%amts15) + if (allocated(this%amts12)) deallocate(this%amts12) + if (allocated(this%amts12_orig)) deallocate(this%amts12_orig) + if (allocated(this%amts09)) deallocate(this%amts09) + if (allocated(this%amts06)) deallocate(this%amts06) + if (allocated(this%amts06_orig)) deallocate(this%amts06_orig) + if (allocated(this%amts03)) deallocate(this%amts03) + if (allocated(this%amts02)) deallocate(this%amts02) + if (allocated(this%amts01)) deallocate(this%amts01) + if (allocated(this%amts00)) deallocate(this%amts00) + if (allocated(this%durations)) deallocate(this%durations) + if (allocated(this%preswx)) deallocate(this%preswx) + if (allocated(this%pastwx)) deallocate(this%pastwx) + if (allocated(this%unique_networks)) deallocate(this%unique_networks) + if (allocated(this%firsts)) deallocate(this%firsts) + if (allocated(this%lasts)) deallocate(this%lasts) + if (allocated(this%pastwx_durations)) & + deallocate(this%pastwx_durations) + this%num_unique_networks = 0 + end subroutine USAF_gages_delete + + ! Use the miscellaneous precip amount. + subroutine USAF_gages_use_misc_precip(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + integer :: russia_lowlimit + integer :: russia_highlimit + integer :: india_lowlimit + integer :: india_highlimit + integer :: srilanka_lowlimit + integer :: srilanka_highlimit + integer :: wmo_block + character(10) :: date10 + integer :: nobs + integer :: i + + if (this%cdms_flag) then + india_lowlimit = CDMS_INDIA_LOWLIMIT + india_highlimit = CDMS_INDIA_HIGHLIMIT + russia_lowlimit = CDMS_RUSSIA_LOWLIMIT + russia_highlimit = CDMS_RUSSIA_HIGHLIMIT + srilanka_lowlimit = CDMS_SRILANKA_LOWLIMIT + srilanka_highlimit = CDMS_SRILANKA_HIGHLIMIT + else + india_lowlimit = JMOBS_INDIA_LOWLIMIT + india_highlimit = JMOBS_INDIA_HIGHLIMIT + russia_lowlimit = JMOBS_RUSSIA_LOWLIMIT + russia_highlimit = JMOBS_RUSSIA_HIGHLIMIT + srilanka_lowlimit = JMOBS_SRILANKA_LOWLIMIT + srilanka_highlimit = JMOBS_SRILANKA_HIGHLIMIT + end if + + date10 = this%date10 + + nobs = this%nobs + do i = 1, nobs + + ! WMO block number in preobs files usually range from 1 to 100. + ! Multiply so they are directly comparable to the + ! appropriate WMO block ID ranges. + wmo_block = this%wmonumbers(i) + if (wmo_block < 1000) then + if (this%cdms_flag) then + wmo_block = wmo_block*10000 + else + wmo_block = wmo_block*1000 + end if + end if + + ! India rule...Obs are usually relative to 03Z with an invalid + ! duration flag. So we may need to copy values from miscellaneous + ! (amts00) to a more standard duration. + if (this%durations(i) .eq. 0 .or. & + this%durations(i) .eq. MISSING) then + + if ((wmo_block .ge. india_lowlimit .and. & + wmo_block .le. india_highlimit) .or. & + (this%bsn(i) .ge. india_lowlimit .and. & + this%bsn(i) .le. india_highlimit)) then + + if (this%amts00(i) .ne. MISSING) then + + if (date10(9:10) == "03" .and. & + this%amts24(i) .eq. MISSING) then + this%amts24(i) = this%amts00(i) + else if (date10(9:10) == "06" .and. & + this%amts03(i) .eq. MISSING) then + this%amts03(i) = this%amts00(i) + else if (date10(9:10) == "09" .and. & + this%amts06(i) .eq. MISSING) then + this%amts06(i) = this%amts00(i) + else if (date10(9:10) == "12" .and. & + this%amts09(i) .eq. MISSING) then + this%amts09(i) = this%amts00(i) + else if (date10(9:10) == "15" .and. & + this%amts12(i) .eq. MISSING) then + this%amts12(i) = this%amts00(i) + else if (date10(9:10) == "18" .and. & + this%amts15(i) .eq. MISSING) then + this%amts15(i) = this%amts00(i) + else if (date10(9:10) == "21" .and. & + this%amts18(i) .eq. MISSING) then + this%amts18(i) = this%amts00(i) + else if (date10(9:10) == "00" .and. & + this%amts21(i) .eq. MISSING) then + this%amts21(i) = this%amts00(i) + end if + end if + end if + end if + + ! Sri Lanka rule. + if ((wmo_block .ge. srilanka_lowlimit .and. & + wmo_block .le. srilanka_highlimit) .or. & + (this%bsn(i) .ge. srilanka_lowlimit .and. & + this%bsn(i) .le. srilanka_highlimit) ) then + + ! At present, it doesn't appear a special Sri Lanka rule is + ! required. We can process 3, 9, and 15 hour reports. + continue + end if + + ! Russia rule (actually, post-Soviet rule). In the past, USAF + ! personnel noted many "Russian" obs were only reported at 00Z and + ! 12Z, and did not use a valid duration flag. These are decoded in + ! the miscellaneous accumulation (amts00), and the duration is set + ! to 0. In AGRMET they were treated as 12-hr accumulations. More + ! recently, a spot check in July 2021 showed similar invalid + ! durations in Kazakhstan, Kyrgyzstan, Georgia, Tajiskistan, and + ! Turkenistan at 06Z and 18Z. Since WMO Region VI (Europe) expects + ! 12-hr accumulations at 06Z and 18Z, we assume these rogue + ! reports are 12-hr accumulations. + if (this%durations(i) .eq. 0 .or. & + this%durations(i) .eq. MISSING) then + + if ((wmo_block .ge. russia_lowlimit .and. & + wmo_block .le. russia_highlimit) .or. & + (this%bsn(i) .ge. russia_lowlimit .and. & + this%bsn(i) .le. russia_highlimit) ) then + + if (date10(9:10) .eq. "00" .or. date10(9:10) .eq. "06" .or. & + date10(9:10) .eq. "12" .or. date10(9:10) .eq. "18") then + + if (this%amts00(i) .ne. MISSING) then + if (this%amts12(i) .eq. MISSING) then + this%amts12(i) = this%amts00(i) + end if + end if + end if + end if + end if ! Russia rule + + ! Copy from miscellaneous (amts00) to a more standard duration, + ! according to the reported duration. + if (this%amts00(i) .ne. MISSING) then + if (this%amts24(i) .eq. MISSING .and. & + this%durations(i) .eq. 24) then + this%amts24(i) = this%amts00(i) + else if (this%amts21(i) .eq. MISSING .and. & + this%durations(i) .eq. 21) then + this%amts21(i) = this%amts00(i) + else if (this%amts18(i) .eq. MISSING .and. & + this%durations(i) .eq. 18) then + this%amts18(i) = this%amts00(i) + else if (this%amts15(i) .eq. MISSING .and. & + this%durations(i) .eq. 15) then + this%amts15(i) = this%amts00(i) + else if (this%amts12(i) .eq. MISSING .and. & + this%durations(i) .eq. 12) then + this%amts12(i) = this%amts00(i) + else if (this%amts09(i) .eq. MISSING .and. & + this%durations(i) .eq. 9) then + this%amts09(i) = this%amts00(i) + else if (this%amts06(i) .eq. MISSING .and. & + this%durations(i) .eq. 6) then + this%amts06(i) = this%amts00(i) + else if (this%amts03(i) .eq. MISSING .and. & + this%durations(i) .eq. 3) then + this%amts03(i) = this%amts00(i) + ! EMK...Disabled saving 2-hr and 1-hr amounts from misc. + ! Old preobs files have a mix of different hours, so we + ! can't expect this to work. We will revisit with the + ! new preobs files, likely requiring a new argument to + ! this subroutine to activate. + ! else if (this%amts02(i) .eq. MISSING .and. & + ! this%durations(i) .eq. 2) then + ! this%amts02(i) = this%amts00(i) + ! else if (this%amts01(i) .eq. MISSING .and. & + ! this%durations(i) .eq. 1) then + ! this%amts01(i) = this%amts00(i) + end if + end if + + end do ! i + + ! Make sure shorter durations don't exceed larger durations. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_use_misc_precip + + ! Reconciles different accumulations from the same report. + subroutine USAF_gages_reconcile_self(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + integer :: nobs + integer :: i + integer :: amts_tmp(10) ! 1, 2, 3, 6, 9, 12, 15, 18, 21, 24 + integer :: j, jj + + nobs = this%nobs + do i = 1, nobs + + ! Zero out smaller-duration accumulation if larger one is zero. + if (this%amts24(i) .eq. 0) then + this%amts21(i) = 0 + end if + if (this%amts21(i) .eq. 0) then + this%amts18(i) = 0 + end if + if (this%amts18(i) .eq. 0) then + this%amts15(i) = 0 + end if + if (this%amts15(i) .eq. 0) then + this%amts12(i) = 0 + end if + if (this%amts12(i) .eq. 0) then + this%amts09(i) = 0 + end if + if (this%amts09(i) .eq. 0) then + this%amts06(i) = 0 + end if + if (this%amts06(i) .eq. 0) then + this%amts03(i) = 0 + end if + if (this%amts03(i) .eq. 0) then + this%amts02(i) = 0 + end if + if (this%amts02(i) .eq. 0) then + this%amts01(i) = 0 + end if + + ! Sometimes smaller-duration accumulations exceed larger-durations, + ! due to precision differences in WMO reporting standard. We + ! correct that here. + amts_tmp(1) = this%amts01(i) + amts_tmp(2) = this%amts02(i) + amts_tmp(3) = this%amts03(i) + amts_tmp(4) = this%amts06(i) + amts_tmp(5) = this%amts09(i) + amts_tmp(6) = this%amts12(i) + amts_tmp(7) = this%amts15(i) + amts_tmp(8) = this%amts18(i) + amts_tmp(9) = this%amts21(i) + amts_tmp(10) = this%amts24(i) + + do j = 10, 2, -1 ! Longer duration limit, 24-hr to 02-hr + if (amts_tmp(j) .ne. MISSING) then + do jj = j-1, 1, -1 ! Shorter duration limit, 21-hr to 01-hr + if (amts_tmp(jj) .ne. MISSING) then + amts_tmp(jj) = min(amts_tmp(jj), amts_tmp(j)) + end if + end do ! jj + end if + end do ! j + + this%amts01(i) = amts_tmp(1) + this%amts02(i) = amts_tmp(2) + this%amts03(i) = amts_tmp(3) + this%amts06(i) = amts_tmp(4) + this%amts09(i) = amts_tmp(5) + this%amts12(i) = amts_tmp(6) + this%amts15(i) = amts_tmp(7) + this%amts18(i) = amts_tmp(8) + this%amts21(i) = amts_tmp(9) + this%amts24(i) = amts_tmp(10) + + end do ! i + + end subroutine USAF_gages_reconcile_self + + ! Fill gaps in precip record if bookend accumulations are identical. + subroutine USAF_gages_fill_gaps(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + integer :: nobs + integer :: i + integer :: amts_tmp(10) ! 1, 2, 3, 6, 9, 12, 15, 18, 21, 24 + integer :: j, jj, jjj + logical :: is_data_gap + + nobs = this%nobs + do i = 1, nobs + + amts_tmp(1) = this%amts01(i) + amts_tmp(2) = this%amts02(i) + amts_tmp(3) = this%amts03(i) + amts_tmp(4) = this%amts06(i) + amts_tmp(5) = this%amts09(i) + amts_tmp(6) = this%amts12(i) + amts_tmp(7) = this%amts15(i) + amts_tmp(8) = this%amts18(i) + amts_tmp(9) = this%amts21(i) + amts_tmp(10) = this%amts24(i) + + ! Fill in gaps if shorter and longer accumulations are identical. + do j = 1, 8 ! Shorter duration limit, from 01-hr to 18-hr + do jj = j+2, 10 ! Longer duration limit, from 03-hr to 24-hr + if (amts_tmp(j) .ne. MISSING .and. & + amts_tmp(jj) .ne. MISSING .and. & + amts_tmp(j) == amts_tmp(jj)) then + ! We have two bookends with identical values. See + ! if all the durations in-between are missing. + is_data_gap = .true. + do jjj = j+1, jj-1 + if (amts_tmp(jjj) .ne. MISSING) then + is_data_gap = .false. + exit + end if + end do ! jjj + ! If all the durations in between are missing, just + ! copy the value (we can assume no additional precip + ! occurred during these periods, at least from this + ! particular report). + if (is_data_gap) then + do jjj = j+1, jj-1 + amts_tmp(jjj) = amts_tmp(j) + end do ! jjj + end if + end if + end do ! jj + end do ! j + + this%amts01(i) = amts_tmp(1) + this%amts02(i) = amts_tmp(2) + this%amts03(i) = amts_tmp(3) + this%amts06(i) = amts_tmp(4) + this%amts09(i) = amts_tmp(5) + this%amts12(i) = amts_tmp(6) + this%amts15(i) = amts_tmp(7) + this%amts18(i) = amts_tmp(8) + this%amts21(i) = amts_tmp(9) + this%amts24(i) = amts_tmp(10) + + end do ! i + + end subroutine USAF_gages_fill_gaps + + ! Reconcile current obs with obs from 1 hour ago + subroutine USAF_gages_reconcile_gages01(this, gages01) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages01 + + ! Locals + integer :: nobs + integer tmp + integer :: i, i1 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i1 = search_pcpobs(gages01, this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i)) + + if (i1 .eq. MISSING) cycle + + ! Use current 1-hr accumulation, if available. + if (this%amts01(i) .ne. MISSING) then + + ! Update 3-hr accumulation if missing + if (this%amts03(i) .eq. MISSING .and. & + gages01%amts02(i1) .ne. MISSING ) then + tmp = this%amts01(i) + gages01%amts02(i1) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) this%amts03(i) = tmp + end if + + ! Update 2-hr accumulation if missing + if (this%amts02(i) .eq. MISSING .and. & + gages01%amts01(i1) .ne. MISSING ) then + tmp = this%amts01(i) + gages01%amts01(i1) + if (tmp >= 0 .and. tmp <= MAX_PCP_2HR) this%amts02(i) = tmp + end if + + end if + + ! Update the 01-hr accumulation + if (this%amts01(i) .eq. MISSING) then + if (this%amts02(i) .ne. MISSING .and. & + gages01%amts01(i1) .ne. MISSING) then + tmp = this%amts02(i) - gages01%amts01(i1) + if (tmp >= 0 .and. tmp <= MAX_PCP_1HR) then + this%amts01(i) = tmp + cycle + end if + end if + if (this%amts03(i) .ne. MISSING .and. & + gages01%amts02(i1) .ne. MISSING) then + tmp = this%amts03(i) - gages01%amts02(i1) + if (tmp >= 0 .and. tmp <= MAX_PCP_1HR) then + this%amts01(i) = tmp + cycle + end if + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration accumulations + ! don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages01 + + ! Reconcile current obs with obs from 2 hours ago + subroutine USAF_gages_reconcile_gages02(this, gages02) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages02 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i2 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i2 = search_pcpobs(gages02, this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i)) + + if (i2 .eq. MISSING) cycle + + ! Use current 2-hr accumulation, if available. + if (this%amts02(i) .ne. MISSING) then + + ! Update 3-hr accumulation if missing + if (this%amts03(i) .eq. MISSING .and. & + gages02%amts01(i2) .ne. MISSING ) then + tmp = this%amts02(i) + gages02%amts01(i2) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) this%amts03(i) = tmp + end if + end if + + ! Update the 2-hr accumulation + if (this%amts02(i) .eq. MISSING) then + if (this%amts03(i) .ne. MISSING .and. & + gages02%amts01(i2) .ne. MISSING) then + tmp = this%amts03(i) - gages02%amts01(i2) + if (tmp >= 0 .and. tmp <= MAX_PCP_2HR) this%amts02(i) = tmp + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration accumulations + ! don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages02 + + ! Reconcile current obs with obs from 3 hours ago + subroutine USAF_gages_reconcile_gages03(this, gages03) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages03 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i3 + + nobs = this%nobs + do i = 1, nobs + + ! Find current station in prior report list + i3 = search_pcpobs(gages03, this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i)) + + if (i3 .eq. MISSING) cycle + + ! Use current 3-hr accumulation, if available. + if (this%amts03(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages03%amts21(i3) .ne. MISSING ) then + tmp = this%amts03(i) + gages03%amts21(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages03%amts18(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts18(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + ! Update 18-hr accumulation if missing + if (this%amts18(i) .eq. MISSING .and. & + gages03%amts15(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts15(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) this%amts18(i) = tmp + end if + + ! Update 15-hr accumulation if missing + if (this%amts15(i) .eq. MISSING .and. & + gages03%amts12(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts12(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) this%amts15(i) = tmp + end if + + ! Update 12-hr accumulation if missing + if (this%amts12(i) .eq. MISSING .and. & + gages03%amts09(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts09(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) this%amts12(i) = tmp + end if + + ! Update 09-hr accumulation if missing + if (this%amts09(i) .eq. MISSING .and. & + gages03%amts06(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts06(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) this%amts09(i) = tmp + end if + + ! Update 06-hr accumulation if missing + if (this%amts06(i) .eq. MISSING .and. & + gages03%amts03(i3) .ne. MISSING) then + tmp = this%amts03(i) + gages03%amts03(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) this%amts06(i) = tmp + end if + end if + + ! Multiple attempts to update 03-hr accumulation. + if (this%amts03(i) .eq. MISSING) then + if (this%amts06(i) .ne. MISSING .and. & + gages03%amts03(i3) .ne. MISSING) then + tmp = this%amts06(i) - gages03%amts03(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts09(i) .ne. MISSING .and. & + gages03%amts06(i3) .ne. MISSING) then + tmp = this%amts09(i) - gages03%amts06(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts12(i) .ne. MISSING .and. & + gages03%amts09(i3) .ne. MISSING) then + tmp = this%amts12(i) - gages03%amts09(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts15(i) .ne. MISSING .and. & + gages03%amts12(i3) .ne. MISSING) then + tmp = this%amts15(i) - gages03%amts12(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts18(i) .ne. MISSING .and. & + gages03%amts15(i3) .ne. MISSING) then + tmp = this%amts18(i) - gages03%amts15(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts21(i) .ne. MISSING .and. & + gages03%amts18(i3) .ne. MISSING) then + tmp = this%amts21(i) - gages03%amts18(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + + if (this%amts24(i) .ne. MISSING .and. & + gages03%amts21(i3) .ne. MISSING ) then + tmp = this%amts24(i) - gages03%amts21(i3) + if (tmp >= 0 .and. tmp <= MAX_PCP_3HR) then + this%amts03(i) = tmp + cycle + end if + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration accumulations + ! don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages03 + + ! Reconcile current obs with obs from 6 hours ago. + subroutine USAF_gages_reconcile_gages06(this, gages06) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages06 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i6 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i6 = search_pcpobs(gages06, this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i)) + + if (i6 .eq. MISSING) cycle + + ! Use current 6-hr accumulation, if available. + if (this%amts06(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages06%amts18(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts18(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages06%amts15(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts15(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + ! Update 18-hr accumulation if missing + if (this%amts18(i) .eq. MISSING .and. & + gages06%amts12(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts12(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) this%amts18(i) = tmp + end if + + ! Update 15-hr accumulation if missing + if (this%amts15(i) .eq. MISSING .and. & + gages06%amts09(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts09(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) this%amts15(i) = tmp + end if + + ! Update 12-hr accumulation if missing + if (this%amts12(i) .eq. MISSING .and. & + gages06%amts06(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts06(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) this%amts12(i) = tmp + end if + + ! Update 09-hr accumulation if missing + if (this%amts09(i) .eq. MISSING .and. & + gages06%amts03(i6) .ne. MISSING) then + tmp = this%amts06(i) + gages06%amts03(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) this%amts09(i) = tmp + end if + + end if + + ! Multiple attempts to update 06-hr accumulation. + if (this%amts06(i) .eq. MISSING) then + if ( (this%amts12(i) .ne. MISSING) .and. & + (gages06%amts06(i6) .ne. MISSING) ) then + tmp = this%amts12(i) - gages06%amts06(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) then + this%amts06(i) = tmp + cycle + end if + end if + + if ( (this%amts15(i) .ne. MISSING) .and. & + (gages06%amts09(i6) .ne. MISSING) ) then + tmp = this%amts15(i) - gages06%amts09(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) then + this%amts06(i) = tmp + cycle + end if + end if + + if ( (this%amts18(i) .ne. MISSING) .and. & + (gages06%amts12(i6) .ne. MISSING) ) then + tmp = this%amts18(i) - gages06%amts12(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) then + this%amts06(i) = tmp + cycle + end if + end if + + if ( (this%amts21(i) .ne. MISSING) .and. & + (gages06%amts15(i6) .ne. MISSING) ) then + tmp = this%amts21(i) - gages06%amts15(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) then + this%amts06(i) = tmp + cycle + end if + end if + + if ( (this%amts24(i) .ne. MISSING) .and. & + (gages06%amts18(i6) .ne. MISSING) ) then + tmp = this%amts24(i) - gages06%amts18(i6) + if (tmp >= 0 .and. tmp <= MAX_PCP_6HR) then + this%amts06(i) = tmp + cycle + end if + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages06 + + ! Reconcile current obs with obs from 9 hours ago. + subroutine USAF_gages_reconcile_gages09(this, gages09) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages09 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i9 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i9 = search_pcpobs(gages09, this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i)) + + if (i9 .eq. MISSING) cycle + + ! Use current 9-hr accumulation, if available. + if (this%amts09(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages09%amts15(i9) .ne. MISSING ) then + tmp = this%amts09(i) + gages09%amts15(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages09%amts12(i9) .ne. MISSING ) then + tmp = this%amts09(i) + gages09%amts12(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + ! Update 18-hr accumulation if missing + if (this%amts18(i) .eq. MISSING .and. & + gages09%amts09(i9) .ne. MISSING) then + tmp = this%amts09(i) + gages09%amts09(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) this%amts18(i) = tmp + end if + + ! Update 15-hr accumulation if missing + if (this%amts15(i) .eq. MISSING .and. & + gages09%amts06(i9) .ne. MISSING) then + tmp = this%amts09(i) + gages09%amts06(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) this%amts15(i) = tmp + end if + + ! Update 12-hr accumulation if missing + if (this%amts12(i) .eq. MISSING .and. & + gages09%amts03(i9) .ne. MISSING) then + tmp = this%amts09(i) + gages09%amts03(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) this%amts12(i) = tmp + end if + + end if + + ! Multiple attempts to update 09-hr accumulation. + if (this%amts09(i) .eq. MISSING) then + if ( (this%amts12(i) .ne. MISSING) .and. & + (gages09%amts03(i9) .ne. MISSING) ) then + tmp = this%amts12(i) - gages09%amts03(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) then + this%amts09(i) = tmp + cycle + end if + end if + + if ( (this%amts15(i) .ne. MISSING) .and. & + (gages09%amts06(i9) .ne. MISSING) ) then + this%amts09(i) = this%amts15(i) - gages09%amts06(i9) + this%amts09(i) = max(this%amts09(i), 0) + tmp = this%amts15(i) - gages09%amts06(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) then + this%amts09(i) = tmp + cycle + end if + end if + + if ( (this%amts18(i) .ne. MISSING) .and. & + (gages09%amts09(i9) .ne. MISSING) ) then + tmp = this%amts18(i) - gages09%amts09(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) then + this%amts09(i) = tmp + cycle + end if + end if + + if ( (this%amts21(i) .ne. MISSING) .and. & + (gages09%amts12(i9) .ne. MISSING) ) then + tmp = this%amts21(i) - gages09%amts12(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) then + this%amts09(i) = tmp + cycle + end if + end if + + if ( (this%amts24(i) .ne. MISSING) .and. & + (gages09%amts15(i9) .ne. MISSING) ) then + tmp = this%amts24(i) - gages09%amts15(i9) + if (tmp >= 0 .and. tmp <= MAX_PCP_9HR) then + this%amts09(i) = tmp + cycle + end if + end if + end if + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages09 + + ! Reconcile current obs with obs from 12 hours ago. + subroutine USAF_gages_reconcile_gages12(this, gages12) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages12 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i12 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i12 = search_pcpobs(gages12, this%networks(i), & + this%platforms(i), this%wmocode_id(i), this%fipscode_id(i)) + + if (i12 .eq. MISSING) cycle + + ! Use current 12-hr accumulation, if available + if (this%amts12(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages12%amts12(i12) .ne. MISSING) then + tmp = this%amts12(i) + gages12%amts12(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages12%amts09(i12) .ne. MISSING) then + tmp = this%amts12(i) + gages12%amts09(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + ! Update 18-hr accumulation if missing + if (this%amts18(i) .eq. MISSING .and. & + gages12%amts06(i12) .ne. MISSING) then + tmp = this%amts12(i) + gages12%amts06(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) this%amts18(i) = tmp + end if + + ! Update 15-hr accumulation if missing + if (this%amts15(i) .eq. MISSING .and. & + gages12%amts03(i12) .ne. MISSING) then + tmp = this%amts12(i) + gages12%amts03(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) this%amts15(i) = tmp + end if + end if + + ! Multiple attempts to update 12-hr accumulation. + if (this%amts12(i) .eq. MISSING) then + if ( (this%amts15(i) .ne. MISSING) .and. & + (gages12%amts03(i12) .ne. MISSING) ) then + tmp = this%amts15(i) - gages12%amts03(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) then + this%amts12(i) = tmp + cycle + end if + end if + + if( (this%amts18(i) .ne. MISSING) .and. & + (gages12%amts06(i12) .ne. MISSING) ) then + tmp = this%amts18(i) - gages12%amts06(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) then + this%amts12(i) = tmp + cycle + end if + end if + + if( (this%amts21(i) .ne. MISSING) .and. & + (gages12%amts09(i12) .ne. MISSING) ) then + tmp = this%amts21(i) - gages12%amts09(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) then + this%amts12(i) = tmp + cycle + end if + end if + + if ( (this%amts24(i) .ne. MISSING) .and. & + (gages12%amts12(i12) .ne. MISSING) ) then + tmp = this%amts24(i) - gages12%amts12(i12) + if (tmp >= 0 .and. tmp <= MAX_PCP_12HR) then + this%amts12(i) = tmp + cycle + end if + end if + + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages12 + + ! Reconcile current obs with obs from 15 hours ago. + subroutine USAF_gages_reconcile_gages15(this, gages15) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages15 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i15 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i15 = search_pcpobs(gages15, this%networks(i), & + this%platforms(i), this%wmocode_id(i), this%fipscode_id(i)) + + if (i15 .eq. MISSING) cycle + + ! Use current 15-hr accumulation, if available + if (this%amts15(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages15%amts09(i15) .ne. MISSING) then + tmp = this%amts15(i) + gages15%amts09(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages15%amts06(i15) .ne. MISSING) then + tmp = this%amts15(i) + gages15%amts06(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + ! Update 18-hr accumulation if missing + if (this%amts18(i) .eq. MISSING .and. & + gages15%amts03(i15) .ne. MISSING) then + tmp = this%amts15(i) + gages15%amts03(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) this%amts18(i) = tmp + end if + + end if + + ! Multiple attempts to update 15-hr accumulation. + if (this%amts15(i) .eq. MISSING) then + if ( (this%amts18(i) .ne. MISSING) .and. & + (gages15%amts03(i15) .ne. MISSING) ) then + tmp = this%amts18(i) - gages15%amts03(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) then + this%amts15(i) = tmp + cycle + end if + end if + + if ( (this%amts21(i) .ne. MISSING) .and. & + (gages15%amts06(i15) .ne. MISSING) ) then + tmp = this%amts21(i) - gages15%amts06(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) then + this%amts15(i) = tmp + cycle + end if + end if + + if ( (this%amts24(i) .ne. MISSING) .and. & + (gages15%amts09(i15) .ne. MISSING) ) then + tmp = this%amts24(i) - gages15%amts09(i15) + if (tmp >= 0 .and. tmp <= MAX_PCP_15HR) then + this%amts15(i) = tmp + cycle + end if + end if + + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration & + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages15 + + ! Reconcile current obs with obs from 18 hours ago. + subroutine USAF_gages_reconcile_gages18(this, gages18) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages18 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i18 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i18 = search_pcpobs(gages18, this%networks(i), & + this%platforms(i), this%wmocode_id(i), this%fipscode_id(i)) + + if (i18 .eq. MISSING) cycle + + ! Use current 18-hr accumulation, if available + if (this%amts18(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages18%amts06(i18) .ne. MISSING) then + tmp = this%amts18(i) + gages18%amts06(i18) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + ! Update 21-hr accumulation if missing + if (this%amts21(i) .eq. MISSING .and. & + gages18%amts03(i18) .ne. MISSING) then + tmp = this%amts18(i) + gages18%amts03(i18) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + + end if + + ! Multiple attempts to update 18-hr accumulation. + if (this%amts18(i) .eq. MISSING) then + if (this%amts21(i) .ne. MISSING .and. & + gages18%amts03(i18) .ne. MISSING) then + tmp = this%amts21(i) - gages18%amts03(i18) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) then + this%amts18(i) = tmp + cycle + end if + end if + + if (this%amts24(i) .ne. MISSING .and. & + gages18%amts06(i18) .ne. MISSING) then + tmp = this%amts24(i) - gages18%amts06(i18) + if (tmp >= 0 .and. tmp <= MAX_PCP_18HR) then + this%amts18(i) = tmp + cycle + end if + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages18 + + ! Reconcile current obs with obs from 21 hours ago. + subroutine USAF_gages_reconcile_gages21(this, gages21) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + class(USAF_gages_t), intent(in) :: gages21 + + ! Locals + integer :: nobs + integer :: tmp + integer :: i, i21 + + nobs = this%nobs + + do i = 1, nobs + + ! Find current station in prior report list + i21 = search_pcpobs(gages21, this%networks(i), & + this%platforms(i), this%wmocode_id(i), this%fipscode_id(i)) + + if (i21 .eq. MISSING) cycle + + ! Use current 21-hr accumulation, if available + if (this%amts21(i) .ne. MISSING) then + + ! Update 24-hr accumulation if missing + if (this%amts24(i) .eq. MISSING .and. & + gages21%amts03(i21) .ne. MISSING) then + tmp = this%amts21(i) + gages21%amts03(i21) + if (tmp >= 0 .and. tmp <= MAX_PCP_24HR) this%amts24(i) = tmp + end if + + end if + + ! Update 21-hr accumulation + if (this%amts21(i) .eq. MISSING) then + if (this%amts24(i) .ne. MISSING .and. & + gages21%amts03(i21) .ne. MISSING) then + tmp = this%amts24(i) - gages21%amts03(i21) + if (tmp >= 0 .and. tmp <= MAX_PCP_21HR) this%amts21(i) = tmp + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_reconcile_gages21 + + ! Correct for missing "zero-precip" 12-hr reports at 12Z for Region III + ! (South America). Based on logic in AGRMET_processobs. + subroutine USAF_gages_correct_region3_12Z(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + integer :: s_amer_lowlimit + integer :: s_amer_highlimit + integer :: wmo_block + character(10) :: date10 + integer :: nobs + integer :: i + + ! Only work with 12Z observations. + date10 = this%date10 + if (date10(9:10) .ne. "12") return + + if (this%cdms_flag) then + s_amer_lowlimit = CDMS_S_AMER_LOWLIMIT + s_amer_highlimit = CDMS_S_AMER_HIGHLIMIT + else + s_amer_lowlimit = JMOBS_S_AMER_LOWLIMIT + s_amer_highlimit = JMOBS_S_AMER_HIGHLIMIT + end if + + nobs = this%nobs + + do i = 1, nobs + + ! WMO block number in preobs files usually range from 1 to 100. + ! Multiply so they are directly comparable to the + ! appropriate WMO block ID ranges. + wmo_block = this%wmonumbers(i) + if (wmo_block < 1000) then + if (this%cdms_flag) then + wmo_block = wmo_block*10000 + else + wmo_block = wmo_block*1000 + end if + end if + + ! In the past, USAF personnel noticed a lack of "zero-precip" + ! 12-hr accumulations at 12Z over South America, which they + ! attributed to two causes: + ! (1) Many stations fail to report at 06Z; and + ! (2) Many 12Z reports indicate zero precip without indicating + ! duration. (Speculation: SYNOP reports excluded a 6RRRt_r + ! precip group in the ob, and instead mark the "I_R" + ! indicator in Section 0 as "3" (meaning precipitation amount + ! is zero) without indicating the duration.) + ! Apparently this is decoded by default as "no precip over last + ! six hours". + ! To reconcile, South American obs at 12Z with missing 12-hr + ! accumulations but with "zero" 6-hr accumulations will also + ! be treated as "zero" 12-hr accumulations. + ! EXCEPTION: If a rare 9-hour non-zero report exists, don't + ! change the 12-hr. + if (this%amts12(i) .ne. MISSING) cycle + if (this%amts12_orig(i) .ne. MISSING) cycle + if (this%amts09(i) .gt. 0) cycle + + if ((wmo_block .ge. s_amer_lowlimit .and. & + wmo_block .le. s_amer_highlimit) .or. & + (this%bsn(i) .ge. s_amer_lowlimit .and. & + this%bsn(i) .le. s_amer_highlimit)) then + + ! We want to make sure the 6-hr report is "original", and + ! not just filled in or derived from comparing other gage + ! reports or present/past weather. That is, the station + ! really made a "zero precip" ob at 12Z, and nothing is + ! available from 06Z. + if (this%amts06(i) .eq. 0 .and. & + this%amts06_orig(i) .eq. 0) then + this%amts12(i) = 0 + this%amts09(i) = 0 + this%amts06(i) = 0 + this%amts03(i) = 0 + this%amts02(i) = 0 + this%amts01(i) = 0 + end if + end if + + end do + + ! Reconcile current obs again to ensure smaller-duration + ! accumulations don't exceed longer-duration. + call this%reconcile_self() + call this%fill_gaps() + + end subroutine USAF_gages_correct_region3_12Z + + ! Write gage data to output file. + subroutine USAF_gages_write_data(this, filename) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(in) :: this + character(*), intent(in) :: filename + + ! Locals + integer :: istat + integer :: nobs, nobs_good + integer :: i + + nobs = this%nobs + + ! First, count number of good obs in the structure, after quality + ! control. + nobs_good = 0 + do i = 1, nobs + if (this%amts24(i) .eq. MISSING .and. & + this%amts21(i) .eq. MISSING .and. & + this%amts18(i) .eq. MISSING .and. & + this%amts15(i) .eq. MISSING .and. & + this%amts12(i) .eq. MISSING .and. & + this%amts09(i) .eq. MISSING .and. & + this%amts06(i) .eq. MISSING .and. & + this%amts03(i) .eq. MISSING .and. & + this%amts02(i) .eq. MISSING .and. & + this%amts01(i) .eq. MISSING) cycle + nobs_good = nobs_good + 1 + end do + + open(11, file=trim(filename), iostat=istat, err=300) + write(11, *, iostat=istat, err=300) nobs_good + do i = 1, nobs + if (this%amts24(i) .eq. MISSING .and. & + this%amts21(i) .eq. MISSING .and. & + this%amts18(i) .eq. MISSING .and. & + this%amts15(i) .eq. MISSING .and. & + this%amts12(i) .eq. MISSING .and. & + this%amts09(i) .eq. MISSING .and. & + this%amts06(i) .eq. MISSING .and. & + this%amts03(i) .eq. MISSING .and. & + this%amts02(i) .eq. MISSING .and. & + this%amts01(i) .eq. MISSING) cycle + write(11, 6000, iostat=istat, err=300) & + this%YYYYMMDDhhmmss(i), & + this%networks(i), this%platforms(i), & + this%wmocode_id(i), this%fipscode_id(i), & + this%wmonumbers(i), this%bsn(i), & + this%lats(i), this%lons(i), & + this%amts24(i), this%amts21(i), this%amts18(i), & + this%amts15(i), this%amts12(i), this%amts09(i), & + this%amts06(i), this%amts03(i), & + this%amts02(i), this%amts01(i), & + this%amts00(i), this%durations(i), & + this%preswx(i), this%pastwx(i) +6000 format (a14, 1x, & + a10, 1x, a32, 1x, & + a2, 1x, a2, 1x, & + i6, 1x, i6, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x & + i9, 1x, i9) + end do + + 300 continue + close(11) + + end subroutine USAF_gages_write_data + + ! Read gage data from file. Acts as an alternative constructor. + subroutine USAF_gages_read_data(this, filename, date10) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(out) :: this + character(*), intent(in) :: filename + character(10), intent(in) :: date10 + + ! Locals + integer :: nobs + character(14), allocatable :: YYYYMMDDhhmmss(:) + character(10), allocatable :: networks(:) + character(32), allocatable :: platforms(:) + character(2), allocatable :: wmocode_id(:) + character(2), allocatable :: fipscode_id(:) + integer, allocatable :: wmonumbers(:) + integer, allocatable :: bsn(:) + integer, allocatable :: lats(:) + integer, allocatable :: lons(:) + integer, allocatable :: amts24(:) + integer, allocatable :: amts21(:) + integer, allocatable :: amts18(:) + integer, allocatable :: amts15(:) + integer, allocatable :: amts12(:) + integer, allocatable :: amts09(:) + integer, allocatable :: amts06(:) + integer, allocatable :: amts03(:) + integer, allocatable :: amts02(:) + integer, allocatable :: amts01(:) + integer, allocatable :: amts00(:) + integer, allocatable :: durations(:) + integer, allocatable :: preswx(:) + integer, allocatable :: pastwx(:) + integer :: istat + logical :: found + integer :: i + + call this%delete() ! Make sure structure is empty + + inquire(file=trim(filename), exist=found) + if (.not. found) return + + open(11, file=trim(filename), iostat=istat, err=300) + read(11, *, iostat=istat, err=300, end=300) nobs + + if (nobs .le. 0) then + close(11) + return + end if + + allocate(YYYYMMDDhhmmss(nobs)) + allocate(networks(nobs)) + allocate(platforms(nobs)) + allocate(wmocode_id(nobs)) + allocate(fipscode_id(nobs)) + allocate(wmonumbers(nobs)) + allocate(bsn(nobs)) + allocate(lats(nobs)) + allocate(lons(nobs)) + allocate(amts24(nobs)) + allocate(amts21(nobs)) + allocate(amts18(nobs)) + allocate(amts15(nobs)) + allocate(amts12(nobs)) + allocate(amts09(nobs)) + allocate(amts06(nobs)) + allocate(amts03(nobs)) + allocate(amts02(nobs)) + allocate(amts01(nobs)) + allocate(amts00(nobs)) + allocate(durations(nobs)) + allocate(preswx(nobs)) + allocate(pastwx(nobs)) + + do i = 1, nobs + read(11, 6000, iostat=istat, err=300, end=300) & + YYYYMMDDhhmmss(i), & + networks(i), platforms(i), & + wmocode_id(i), fipscode_id(i), & + wmonumbers(i), bsn(i), & + lats(i), lons(i), & + amts24(i), amts21(i), amts18(i), & + amts15(i), amts12(i), amts09(i), & + amts06(i), amts03(i), & + amts02(i), amts01(i), & + amts00(i), durations(i), & + preswx(i), pastwx(i) +6000 format (a14, 1x, & + a10, 1x, a32, 1x, & + a2, 1x, a2, 1x, & + i6, 1x, i6, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, & + i9, 1x, i9) + end do + + close(11) + 300 continue + + ! If read was successful, copy to USAF_gages_t structure. + if (istat .eq. 0) then + call this%new(date10, nobs, YYYYMMDDhhmmss, & + networks, platforms, & + wmocode_id, fipscode_id, & + wmonumbers, bsn, lats, lons, & + amts24, amts21, amts18, amts15, amts12, amts09, amts06, & + amts03, amts02, amts01, & + amts00, durations, preswx, pastwx) + end if + + ! Clean up + deallocate(YYYYMMDDhhmmss) + deallocate(networks) + deallocate(platforms) + deallocate(wmocode_id) + deallocate(fipscode_id) + deallocate(wmonumbers) + deallocate(bsn) + deallocate(lats) + deallocate(lons) + deallocate(amts24) + deallocate(amts21) + deallocate(amts18) + deallocate(amts15) + deallocate(amts12) + deallocate(amts09) + deallocate(amts06) + deallocate(amts03) + deallocate(amts02) + deallocate(amts01) + deallocate(amts00) + deallocate(durations) + deallocate(preswx) + deallocate(pastwx) + + ! Handle arrays for unique networks in private method. Also set + ! cdms_flag. + if (istat .eq. 0) then + call set_unique_networks(this) + end if + end subroutine USAF_gages_read_data + + ! Search USAF_gages_t type for presumed erroneous accumulations. + subroutine USAF_gages_check_gross_errors(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + character(10) :: date10 + integer :: india_lowlimit + integer :: india_highlimit + integer :: russia_lowlimit + integer :: russia_highlimit + integer :: threshold + integer :: threshold_india + integer :: nobs + integer :: i + + if (this%cdms_flag) then + india_lowlimit = CDMS_INDIA_LOWLIMIT + india_highlimit = CDMS_INDIA_HIGHLIMIT + russia_lowlimit = CDMS_RUSSIA_LOWLIMIT + russia_highlimit = CDMS_RUSSIA_HIGHLIMIT + else + india_lowlimit = JMOBS_INDIA_LOWLIMIT + india_highlimit = JMOBS_INDIA_HIGHLIMIT + russia_lowlimit = JMOBS_RUSSIA_LOWLIMIT + russia_highlimit = JMOBS_RUSSIA_HIGHLIMIT + end if + date10 = this%date10 + + nobs = this%nobs + do i = 1, nobs + + ! Check for negatives + if (this%amts24(i) < 0) this%amts24(i) = MISSING + if (this%amts21(i) < 0) this%amts21(i) = MISSING + if (this%amts18(i) < 0) this%amts18(i) = MISSING + if (this%amts15(i) < 0) this%amts15(i) = MISSING + if (this%amts12(i) < 0) this%amts12(i) = MISSING + if (this%amts09(i) < 0) this%amts09(i) = MISSING + if (this%amts06(i) < 0) this%amts06(i) = MISSING + if (this%amts03(i) < 0) this%amts03(i) = MISSING + if (this%amts02(i) < 0) this%amts02(i) = MISSING + if (this%amts01(i) < 0) this%amts01(i) = MISSING + if (this%amts00(i) < 0) this%amts00(i) = MISSING + + ! Check for large errors + if (this%amts24(i) > MAX_PCP_24HR) this%amts24(i) = MISSING + if (this%amts21(i) > MAX_PCP_21HR) this%amts21(i) = MISSING + if (this%amts18(i) > MAX_PCP_18HR) this%amts18(i) = MISSING + if (this%amts15(i) > MAX_PCP_15HR) this%amts15(i) = MISSING + if (this%amts12(i) > MAX_PCP_12HR) this%amts12(i) = MISSING + if (this%amts09(i) > MAX_PCP_9HR) this%amts09(i) = MISSING + if (this%amts06(i) > MAX_PCP_6HR) this%amts06(i) = MISSING + if (this%amts03(i) > MAX_PCP_3HR) this%amts03(i) = MISSING + if (this%amts02(i) > MAX_PCP_2HR) this%amts02(i) = MISSING + if (this%amts01(i) > MAX_PCP_1HR) this%amts01(i) = MISSING + + ! Checking miscellaneous accumulations is more complicated. + ! First, see if we have a WMO established duration. + threshold = set_precip_duration_threshold(this%durations(i)) + if (threshold .ne. MISSING) then + if (this%amts00(i) > threshold) then + this%amts00(i) = MISSING + this%durations(i) = MISSING + end if + cycle + end if + + ! Try the "Russia" rule. Three sets of tests before invoking. + if (this%durations(i) .eq. 0 .or. & + this%durations(i) .eq. MISSING) then + + if ((this%wmonumbers(i) .ge. russia_lowlimit .and. & + this%wmonumbers(i) .le. russia_highlimit) .or. & + (this%bsn(i) .ge. russia_lowlimit .and. & + this%bsn(i) .le. russia_highlimit) ) then + + if (date10(9:10) .eq. "00" .or. & + date10(9:10) .eq. "06" .or. & + date10(9:10) .eq. "12" .or. & + date10(9:10) .eq. "18") then + + ! Russia rule (actually, post-Soviet rule). In the + ! past, USAF personnel noted many "Russian" obs were + ! only reported at 00Z and 12Z, and did not use a valid + ! duration flag. These are decoded in the miscellaneous + ! accumulation (amts00). In AGRMET they were treated as + ! 12-hr accumulations. More recently, a spot check in + ! July 2021 showed similar invalid durations in + ! Kazakhstan, Kyrgyzstan, Georgia, Tajiskistan, and + ! Turkenistan at 06Z and 18Z. Since WMO Region VI + ! (Europe) expects 12-hr accumulations at 06Z and 18Z, we + ! assume these rogue reports are also 12-hr + ! accumulations. + + if (this%amts00(i) > MAX_PCP_12HR) then + this%amts00(i) = MISSING + this%durations(i) = MISSING + end if + cycle + end if + end if + end if ! Russia rule + + ! Try the India rule. Two sets of tests. + if (this%durations(i) .eq. 0 .or. & + this%durations(i) .eq. MISSING) then + + if ((this%wmonumbers(i) .ge. india_lowlimit .and. & + this%wmonumbers(i) .le. india_highlimit) .or. & + (this%bsn(i) .ge. india_lowlimit .or. & + this%bsn(i) .le. india_highlimit)) then + + ! If these are from India, we assume duration is from 03Z. + ! But, we will only accept reports at three-hour intervals. + threshold_india = set_india_precip_threshold(date10(9:10)) + if (threshold_india .ne. MISSING) then + if (this%amts00(i) > threshold_india) then + this%amts00(i) = MISSING + this%durations(i) = MISSING + end if + cycle + end if + end if + end if ! India rule + + ! If all else fails, assume 24-hr accumulation + if (this%amts00(i) > MAX_PCP_24HR) then + this%amts00(i) = MISSING + this%durations(i) = MISSING + end if + + end do + end subroutine USAF_gages_check_gross_errors + + ! Check the observations for bad lat/lon values. If found, reset the + ! data to missing. + subroutine check_latlons(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + logical :: bad_latlon + integer :: nobs + integer :: i + + nobs = this%nobs + do i = 1, nobs + bad_latlon = .false. + + ! Sometimes a station report is listed with a lat/lon of 0, + ! putting it in the Atlantic Ocean. We check and flag. + if (this%lats(i) == 0 .and. this%lons(i) == 0) bad_latlon = .true. + + ! If we don't have a good lat/lon, the information from the + ! station is useless. So remove it. + if (bad_latlon) then + this%amts24(i) = MISSING + this%amts21(i) = MISSING + this%amts18(i) = MISSING + this%amts15(i) = MISSING + this%amts12(i) = MISSING + this%amts09(i) = MISSING + this%amts06(i) = MISSING + this%amts03(i) = MISSING + this%amts02(i) = MISSING + this%amts01(i) = MISSING + this%amts00(i) = MISSING + this%durations(i) = MISSING + this%preswx(i) = MISSING + this%pastwx(i) = MISSING + end if + end do + end subroutine check_latlons + + ! Search USAF_gages_t type for unique networks, and establish index + ! bounds for each network. Assumes data are sorted. Borrows logic + ! from AGRMET_processobs. + subroutine set_unique_networks(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + character(10) :: prior_net + integer :: net_count + integer :: nobs + integer :: i + + if (.not. allocated(this%unique_networks)) then + allocate(this%unique_networks(MAX_UNIQUE_NETWORKS)) + end if + this%unique_networks = MISSING_NAME + if (.not. allocated(this%firsts)) then + allocate(this%firsts(MAX_UNIQUE_NETWORKS)) + end if + this%firsts = MISSING + if (.not. allocated(this%lasts)) then + allocate(this%lasts(MAX_UNIQUE_NETWORKS)) + end if + this%lasts = MISSING + + prior_net = MISSING_NAME + + nobs = this%nobs + do i = 1, nobs + if (prior_net .eq. MISSING_NAME) then + this%firsts(1) = i + this%unique_networks(i) = this%networks(i) + net_count = 1 + prior_net = this%networks(i) + else if (this%networks(i) .ne. prior_net) then + this%lasts(net_count) = i - 1 + net_count = net_count + 1 + ! FIXME...Update for LIS_logunit and LIS_endrun + if (net_count .gt. MAX_UNIQUE_NETWORKS) then + print*,'[ERR] Too many unique networks!' + stop + end if + this%firsts(net_count) = i + this%unique_networks(net_count) = this%networks(i) + prior_net = this%networks(i) + end if + end do + this%lasts(net_count) = this%nobs + + this%num_unique_networks = net_count + + ! Mark if these obs are all legacy CDMS output + this%cdms_flag = .false. + if (net_count .eq. 1) then + if (this%unique_networks(net_count) .eq. "CDMS") then + this%cdms_flag = .true. + end if + end if + end subroutine set_unique_networks + + ! Search USAF_gages_t type for given network and platform, and + ! return index. Based on AGRMET_pcpobs_search + function search_pcpobs(this, network, plat_id, & + wmocode_id, fipscode_id) result(index) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(in) :: this + character(10), intent(in) :: network + character(32), intent(in) :: plat_id + character(2), intent(in) :: wmocode_id + character(2), intent(in) :: fipscode_id + + ! Result + integer :: index + + ! Locals + integer :: first + integer :: middle + integer :: last + integer :: net_index + logical :: found + + index = MISSING + first = 1 + last = this%nobs + found = .false. + + net_index = 1 + + ! Select the appropriate 'first' and 'last' search indices based on + ! requested network + do while ((net_index .le. this%num_unique_networks) .and. & + (.not. found)) + if (network .eq. this%unique_networks(net_index)) then + first = this%firsts(net_index) + last = this%lasts(net_index) + found = .true. + end if + net_index = net_index + 1 + end do + if (.not. found) return + + found = .false. ! Reuse for finding station ID below + do + if ((first .gt. last) .or. found) return + ! Use binary search + middle = (first + last) / 2 + if (plat_id .lt. this%platforms(middle)) then + last = middle - 1 + elseif (plat_id .gt. this%platforms(middle)) then + first = middle + 1 + else + ! Make sure country code matches + if (this%wmocode_id(middle) .eq. wmocode_id .and. & + this%fipscode_id(middle) .eq. fipscode_id) then + found = .true. + index = middle + end if + exit + end if + end do + + end function search_pcpobs + + ! Infer zero precip for certain durations if the accumulations are + ! missing and if present and past weather codes support no precip. + subroutine USAF_gages_use_preswx_pastwx(this) + + ! Defaults + implicit none + + ! Arguments + class(USAF_gages_t), intent(inout) :: this + + ! Locals + integer :: sweden_lowlimit + integer :: sweden_highlimit + integer :: denmark_lowlimit + integer :: denmark_highlimit + integer :: pastwx_duration + integer :: nobs + integer :: i + + if (this%cdms_flag) then + sweden_lowlimit = CDMS_SWEDEN_LOWLIMIT + sweden_highlimit = CDMS_SWEDEN_HIGHLIMIT + denmark_lowlimit = CDMS_DENMARK_LOWLIMIT + denmark_highlimit = CDMS_DENMARK_HIGHLIMIT + else + sweden_lowlimit = JMOBS_SWEDEN_LOWLIMIT + sweden_highlimit = JMOBS_SWEDEN_HIGHLIMIT + denmark_lowlimit = JMOBS_DENMARK_LOWLIMIT + denmark_highlimit = JMOBS_DENMARK_HIGHLIMIT + end if + + nobs = this%nobs + do i = 1, nobs + + ! If we don't have a valid past weather duration, we can't know + ! which precip accumulation to adjust. + pastwx_duration = this%pastwx_durations(i) + if (pastwx_duration .eq. MISSING) cycle + + if (this%preswx(i) .eq. MISSING) cycle + if (this%pastwx(i) .eq. MISSING) cycle + + ! We will only use past and present weather if the appropriate + ! accumulations are missing. + if (pastwx_duration .eq. 6) then + if (this%amts06(i) .ne. MISSING) cycle + if (this%amts03(i) .ne. MISSING) cycle + if (this%amts02(i) .ne. MISSING) cycle + if (this%amts01(i) .ne. MISSING) cycle + end if + + if (pastwx_duration .eq. 3) then + if (this%amts03(i) .ne. MISSING) cycle + if (this%amts02(i) .ne. MISSING) cycle + if (this%amts01(i) .ne. MISSING) cycle + end if + + ! Exclude Danish stations, since reports at non-standard + ! international hours have past weather of only 1 hour. + if ((this%wmonumbers(i) .ge. denmark_lowlimit .and. & + this%wmonumbers(i) .le. denmark_highlimit) .or. & + (this%bsn(i) .ge. denmark_lowlimit .and. & + this%bsn(i) .le. denmark_highlimit)) then + cycle + end if + + ! Exclude Swedish stations, since durations for past weather + ! vary from one to six hours depending on when the report was + ! made. + if ((this%wmonumbers(i) .ge. sweden_lowlimit .and. & + this%wmonumbers(i) .le. sweden_highlimit) .or. & + (this%bsn(i) .ge. sweden_lowlimit .and. & + this%bsn(i) .le. sweden_highlimit)) then + cycle + end if + + ! Exclude Antarctic stations. This is because (1) Australian + ! Antarctic stations are known to have varying past weather + ! durations due to staffing; (2) isolating the Australian + ! stations is difficult due to WMO station ID assignments; and + ! (3) Antarctic stations will probably be subfreezing and have + ! their precip accumulations rejected anyway. For simplicity, we + ! skip any report south of 60S. + if (this%lons(i) .le. -6000) cycle + + ! WMO SYNOP reports use different code tables depending on if the + ! station is manned or automatic. Unfortunately, the indicator + ! for manned vs automatic is not included in the USAF decoded + ! files, so we must be conservative and check for precipitation + ! codes from either scenario. The decision criteria are kept + ! separate in case the USAF file format is changed in the future + ! to include this information. In addition, BUFR has it's own + ! tables, and it is not clear from the USAF decoded files if BUFR + ! or SYNOP was decoded. + + ! First, check present weather for manned station (WMO Code Table + ! 4677; also WMO BUFR Code Table 0 20 003). + select case (this%preswx(i)) + case (50:99) ! Precipitation at station at time of observation + cycle + case (20:27, 29) ! Precip at station in last hour, but not at + cycle ! time of observation + end select + + ! Next, check present weather for automatic station (WMO Code + ! Table 4680; see also WMO BUFR Code Table 0 20 003) + select case (this%preswx(i)) + case (40:48, 50:58, 60:68, 70:78, 89, 90:96) + cycle ! Precipitation at station at time of observation + case (21:26) + cycle ! Precip at station in last hour, but not at time of + ! observation + case (140:148, 150:158, 160:168, 170:178, 180:188, 190:196) + cycle ! BUFR codes for precip at automated station at time of + ! observation + case (121:126) + cycle ! BUFR codes for precip at station in last hour, but + ! not at time of observation + case (250:257, 259, 260:267, 270:279, 280:291) + cycle ! More descriptive BUFR codes for precip at station. + case (510:511) + cycle ! BUFR codes for missing data + end select + + ! Next, check past weather for manned station (WMO Code Table + ! 4561) + select case (this%pastwx(i)) + case (5:9) + cycle + end select + + ! Next, check past weather for automatic station (WMO Code Table + ! 4531, and WMO BUFR Code Table 0 20 004 / 0 20 005) + select case (this%pastwx(i)) + case (4:9) ! WMO Code Table 4531 + cycle + case (14:19) ! BUFR Code Tables + cycle + case (31) ! BUFR code for missing + cycle + end select + + ! At this point, we can infer zero precipitation for the + ! appropriate duration + if (pastwx_duration .eq. 6) then + this%amts06(i) = 0 + this%amts03(i) = 0 + this%amts02(i) = 0 + this%amts01(i) = 0 + else if (pastwx_duration .eq. 3) then + this%amts03(i) = 0 + this%amts02(i) = 0 + this%amts01(i) = 0 + end if + end do + + call this%reconcile_self() + call this%fill_gaps() + end subroutine USAF_gages_use_preswx_pastwx + + ! Method for setting pastwx duration for each report. + subroutine USAF_gages_set_pastwx_durations(this) + implicit none + class(USAF_gages_t), intent(inout) :: this + integer :: nobs + character(10) :: date10 + integer :: i + nobs = this%nobs + do i = 1, nobs + if (this%YYYYMMDDhhmmss(i) .eq. "NULL") then + date10 = this%date10 + else + date10 = this%YYYYMMDDhhmmss(i)(1:10) + end if + this%pastwx_durations(i) = set_pastwx_duration(date10) + end do + end subroutine USAF_gages_set_pastwx_durations + + ! Function for setting duration of past weather report. This is based + ! on WMO SYNOP definition. (Two and one hour durations are also + ! allowed by the WMO, but these require SYNOP reports every two or one + ! hours; and it is not clear from the USAF decoded files when that + ! occurs.) + function set_pastwx_duration(date10) result (duration) + implicit none + character(10), intent(in) :: date10 + integer :: duration + select case (date10(9:10)) + case ('00', '06', '12', '18') + duration = 6 + case ('03', '09', '15', '21') + duration = 3 + case default + duration = MISSING + end select + end function set_pastwx_duration + + ! Return appropriate precipitation threshold based on duration. + ! NOTE: We currently skip 1 hour and 2-hour accumulations. + function set_precip_duration_threshold(duration) result (threshold) + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: duration + + ! Return variable + integer :: threshold + + ! Select appropriate threshold + select case (duration) + case (1) + threshold = MAX_PCP_1HR + case (2) + threshold = MAX_PCP_2HR + case (3) + threshold = MAX_PCP_3HR + case (6) + threshold = MAX_PCP_6HR + case (9) + threshold = MAX_PCP_9HR + case (12) + threshold = MAX_PCP_12HR + case (15) + threshold = MAX_PCP_15HR + case (18) + threshold = MAX_PCP_18HR + case (21) ! Not a WMO established duration, but we'll check anyway. + threshold = MAX_PCP_21HR + case (24) + threshold = MAX_PCP_24HR + case default + threshold = MISSING + end select + + end function set_precip_duration_threshold + + ! Return appropriate precipitation threshold based on report time in + ! India + function set_india_precip_threshold(utc_hour) result (threshold) + + ! Defaults + implicit none + + ! Arguments + character(2), intent(in) :: utc_hour + + ! Return variable + integer :: threshold + + ! Select appropriate threshold. India obs are assumed to accumulate + ! from 03Z + select case (utc_hour) + case ("04") + threshold = MAX_PCP_1HR + case ("05") + threshold = MAX_PCP_2HR + case ("06") + threshold = MAX_PCP_3HR + case ("09") + threshold = MAX_PCP_6HR + case ("12") + threshold = MAX_PCP_9HR + case ("15") + threshold = MAX_PCP_12HR + case ("18") + threshold = MAX_PCP_15HR + case ("21") + threshold = MAX_PCP_18HR + case ("00") + threshold = MAX_PCP_21HR + case ("03") + threshold = MAX_PCP_24HR + case default + threshold = MISSING + end select + + end function set_india_precip_threshold + +end module USAF_GagesMod diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 new file mode 100644 index 000000000..dcc901e8b --- /dev/null +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -0,0 +1,1054 @@ +! +! MODULE: USAF_PreobsReaderMod +! +! DESCRIPTION: Contains code for reading USAF preobs files, performing simple +! preprocessing, and adding to gages database. +! +! AUTHOR: Eric Kemp, SSAI/NASA GSFC +! +!------------------------------------------------------------------------------ + +module USAF_PreobsReaderMod + + ! Defaults + implicit none + private + + ! Public routines + public :: USAF_read_preobs + + ! FIXME: Replace this with LIS_logMod.F90 + integer, parameter :: LIS_logunit = 6 + + integer, parameter :: MISSING = -99999999 + +contains + + ! Read preobs files, perform simple preprocessing, and store + ! in database. + subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & + use_timestamp, & + year, month, day, hour, use_expanded_station_ids) + + ! Imports + use ESMF + use USAF_GagesMod, only : USAF_Gages_t + + ! Defaults + implicit none + + ! Arguments + character(*), intent(in) :: rootdir + character(*), intent(in) :: preobsdir + character(*), intent(in) :: presavdir + integer, intent(in) :: use_timestamp + integer, intent(in) :: year + integer, intent(in) :: month + integer, intent(in) :: day + integer, intent(in) :: hour + integer, intent(in) :: use_expanded_station_ids + + ! Locals + character(255) :: filename + integer, allocatable :: twfprc(:) + integer, allocatable :: duration(:) + integer, allocatable :: sixprc(:) + integer, allocatable :: mscprc(:) + integer, allocatable :: ilat(:) + integer, allocatable :: ilon(:) + integer, allocatable :: bsn(:) + character(10), allocatable :: network(:) + character(32), allocatable :: plat_id(:) + character(2), allocatable :: wmocode_id(:) + character(2), allocatable :: fipscode_id(:) + integer, allocatable :: pastwx(:) + integer, allocatable :: preswx(:) + integer, allocatable :: wmoblk(:) + integer :: twfprc_tmp + integer :: duration_tmp + integer :: sixprc_tmp + integer :: mscprc_tmp + integer :: ilat_tmp + integer :: ilon_tmp + character(14) :: YYYYMMDDhhmmss_tmp + character(10) :: network_tmp + character(32) :: plat_id_tmp + character(2) :: wmocode_id_tmp, fipscode_id_tmp + integer :: pastwx_tmp + integer :: preswx_tmp + integer :: wmoblk_tmp + integer :: bsn_tmp + integer :: nsize + integer :: nsize_total + integer :: ihemi + logical :: found_file + integer :: ierr + integer :: stncnt + integer :: i + character(10) :: date10 + character(14), allocatable :: YYYYMMDDhhmmss(:) + integer, allocatable :: amts24(:) + integer, allocatable :: amts21(:) + integer, allocatable :: amts18(:) + integer, allocatable :: amts15(:) + integer, allocatable :: amts12(:) + integer, allocatable :: amts09(:) + integer, allocatable :: amts06(:) + integer, allocatable :: amts03(:) + integer, allocatable :: amts02(:) + integer, allocatable :: amts01(:) + integer, allocatable :: amts00(:) + type(USAF_Gages_t) :: obscur, obsprev + integer :: rc + character(255) :: presav_filename + integer :: ipass, j + logical :: exchanges + type(ESMF_Time) :: curtime, prevtime, reporttime + type(ESMF_TimeInterval) :: deltatime, maxdeltatime + integer :: prevyear, prevmonth, prevday, prevhour + logical :: file_exists + integer :: deltahr + character(10) :: prevdate10 + integer :: yyyy, mm, dd, h, m, s + character(255) :: timestring + + write(LIS_logunit,*)'---------------------------------------------' + + ! Set time limit allowed for report + call esmf_timeintervalset(maxdeltatime, m=5, rc=rc) ! 5 min after + + ! Find the total number of entries in the two hemispheric preobs + ! files for this date/time. This will be the upper-limit for how + ! much memory we allocate for temporary storage. If the newer + ! global preobs file is read, logic in the loop will break out + ! of the loop before the second pass. + nsize_total = 0 + do ihemi = 1, 2 + + call get_preobs_filename(filename, rootdir, preobsdir, & + use_timestamp, & + ihemi, year, month, day, hour, use_expanded_station_ids) + + inquire(file=trim(filename), exist=found_file) + if (.not. found_file) then + write(LIS_logunit,*) '[WARN] Cannot find ', trim(filename) + cycle + end if + + open(22, file=trim(filename), status='old', iostat=ierr) + if (ierr .ne. 0) then + write(LIS_logunit,*) '[WARN] Problem opening ', trim(filename) + cycle + end if + + nsize = 0 + read(22, *, iostat=ierr) nsize + if (ierr .ne. 0) then + write(LIS_logunit,*) '[WARN] Problem reading ', trim(filename) + close(22) + cycle + end if + + write(LIS_logunit,*) '[INFO] Will process ', trim(filename) + + nsize_total = nsize_total + nsize + close(22) + + if (use_expanded_station_ids == 1) cycle ! These files are global + end do + + if (nsize_total == 0) then + write(LIS_logunit,*) '[WARN] No precip obs available!' + return + end if + + ! We now have an upper limit of how many gage reports to save. + allocate(twfprc(nsize_total)) + twfprc = MISSING + allocate(duration(nsize_total)) + duration = MISSING + allocate(sixprc(nsize_total)) + sixprc = MISSING + allocate(mscprc(nsize_total)) + mscprc = MISSING + allocate(ilat(nsize_total)) + ilat = MISSING + allocate(ilon(nsize_total)) + ilon = MISSING + allocate(bsn(nsize_total)) + bsn = MISSING + allocate(network(nsize_total)) + network = "NULL" + allocate(plat_id(nsize_total)) + plat_id = "NULL" + allocate(wmocode_id(nsize_total)) + wmocode_id = "??" + allocate(fipscode_id(nsize_total)) + fipscode_id = "??" + allocate(pastwx(nsize_total)) + pastwx = MISSING + allocate(preswx(nsize_total)) + preswx = MISSING + allocate(wmoblk(nsize_total)) + wmoblk = MISSING + allocate(YYYYMMDDhhmmss(nsize_total)) + YYYYMMDDhhmmss = "NULL" + + write(date10, "(i4.4,i2.2,i2.2,i2.2)") year, month, day, hour + + ! Need to set current time in ESMF for calculations + call esmf_timeset(curtime, yy=year, mm=month, dd=day, h=hour, & + m=0, s=0, rc=rc) + + ! Now begin reading the data in the files, performing simple checks + ! along the way. + stncnt = 0 + do ihemi = 1, 2 + call get_preobs_filename(filename, rootdir, preobsdir, & + use_timestamp, & + ihemi, year, month, day, hour, use_expanded_station_ids) + + inquire(file=trim(filename), exist=found_file) + if (.not. found_file) then + if (use_expanded_station_ids == 1) exit + cycle + end if + + open(22, file=trim(filename), status='old', iostat=ierr) + if (ierr .ne. 0) cycle + + nsize = 0 + read(22, *, iostat=ierr) nsize + if (ierr .ne. 0) then + close(22) + if (use_expanded_station_ids == 1) exit + cycle + end if + + ! Start reading the actual obs + do i = 1, nsize + if (use_expanded_station_ids == 1) then + twfprc_tmp = MISSING + sixprc_tmp = MISSING + read(22, 6001, iostat=ierr) YYYYMMDDhhmmss_tmp, & + network_tmp, plat_id_tmp, ilat_tmp, ilon_tmp, & + wmocode_id_tmp, fipscode_id_tmp, wmoblk_tmp, & + mscprc_tmp, duration_tmp, pastwx_tmp, preswx_tmp +6001 format(1x, a14, 1x, a10, 1x, a32, 1x, i9, 1x, i9, 1x, & + a2, 1x, a2, 1x, i9, 1x, i9, 1x, i9, 1x, i9, 1x, i9) + if (wmocode_id_tmp == " ") wmocode_id_tmp = "??" + if (fipscode_id_tmp == " ") fipscode_id_tmp = "??" + else + read(22, 6000, iostat=ierr) twfprc_tmp, duration_tmp, & + sixprc_tmp, & + mscprc_tmp, ilat_tmp, ilon_tmp, network_tmp, & + plat_id_tmp, & + pastwx_tmp, preswx_tmp, wmoblk_tmp +6000 format(i10, i10, i10, i10, i10, i10, 1x, a10, 2x, a10 & + ,i10, i10, i10) + wmocode_id_tmp = "??" + fipscode_id_tmp = "??" + YYYYMMDDhhmmss_tmp = date10 // "0000" + end if + + if (ierr .ne. 0) then + write(LIS_logunit,*) & + '[WARN] Problem reading report, skipping line...' + cycle + end if + + ! Skip if lat/lon is 0 (this is interpreted as missing). + if (ilat_tmp == 0 .and. ilon_tmp == 0) cycle + + ! Skip reports that are too much after the analysis time + ! (but allow earlier reports). This is a crude way of + ! allowing for Australian reports that are sometimes one or + ! two hours behind the sub-synoptic times. + if (use_expanded_station_ids == 1) then + read(YYYYMMDDhhmmss_tmp, & + '(I4.4, I2.2, I2.2, I2.2, I2.2, I2.2)') yyyy, mm, dd, & + h, m, s + call esmf_timeset(reporttime, yy=yyyy, mm=mm, dd=dd, & + h=h, m=m, s=s, rc=rc) + deltatime = reporttime - curtime + + call esmf_timeintervalget(deltatime, timestring=timestring, & + rc=rc) + + ! if (deltatime < mindeltatime) cycle + if (deltatime > maxdeltatime) cycle + end if + + ! Don't save 1-hr precip. + ! FIXME...Add special handling in new preobs files to + ! estimate 3-hr accums if enough 1-hr reports are available. + if (duration_tmp .eq. 1) then + mscprc_tmp = MISSING + duration_tmp = MISSING + end if + + ! Skip if no useable data in report. + if (twfprc_tmp == MISSING .and. & + sixprc_tmp == MISSING .and. & + mscprc_tmp == MISSING .and. & + (pastwx_tmp == MISSING .or. & + preswx_tmp == MISSING)) then + cycle + end if + + ! If we don't have FIPS or WMO codes available, try guessing + ! the FIPS code for countries with special rules based on + ! the WIGOS issuer number. + if (fipscode_id_tmp == "??" .and. & + wmocode_id_tmp == "??") then + fipscode_id_tmp = get_fips_from_wigos_issuer(plat_id_tmp) + end if + + ! Set the numeric bsn field. + if (network_tmp .eq. "WMO") then + bsn_tmp = set_bsn_wmo(use_expanded_station_ids, & + plat_id_tmp, fipscode_id_tmp, wmocode_id_tmp) + else if (network_tmp .eq. "CDMS") then + read (plat_id_tmp, '(i32)') bsn_tmp + else + bsn_tmp = 0 + end if + + ! Set the country codes if possible. + if (network_tmp .eq. "CANA") then + wmocode_id_tmp = "CA" + fipscode_id_tmp = "CA" + else if (network_tmp .eq. "FAA") then + wmocode_id_tmp = "US" + fipscode_id_tmp = "US" + end if + + ! Sometimes 6 and 24-hr data are stored in misc. Copy + ! over if necessary, then erase. + if (duration_tmp == 24) then + if (twfprc_tmp == MISSING) then + twfprc_tmp = mscprc_tmp + end if + mscprc_tmp = MISSING + duration_tmp = MISSING + else if (duration_tmp == 6) then + if (sixprc_tmp == MISSING) then + sixprc_tmp = mscprc_tmp + end if + mscprc_tmp = MISSING + duration_tmp = MISSING + end if + + ! If this is the first report, save it. + if (stncnt == 0) then + stncnt = stncnt + 1 + twfprc(stncnt) = twfprc_tmp + duration(stncnt) = duration_tmp + sixprc(stncnt) = sixprc_tmp + mscprc(stncnt) = mscprc_tmp + ilat(stncnt) = ilat_tmp + ilon(stncnt) = ilon_tmp + bsn(stncnt) = bsn_tmp + network(stncnt) = network_tmp + plat_id(stncnt) = plat_id_tmp + wmocode_id(stncnt) = wmocode_id_tmp + fipscode_id(stncnt) = fipscode_id_tmp + pastwx(stncnt) = pastwx_tmp + preswx(stncnt) = preswx_tmp + wmoblk(stncnt) = wmoblk_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + cycle + else + ! Look at the most recent saved gage report, and see if this + ! new entry is from the same station. + if (network(stncnt) .eq. network_tmp .and. & + trim(plat_id(stncnt)) .eq. trim(plat_id_tmp)) then + + ! For newer file format with date/time with each report, + ! pick the more recent date/time for duration other + ! than 1 hour. + if (YYYYMMDDhhmmss(stncnt) < YYYYMMDDhhmmss_tmp .and. & + (twfprc_tmp .ne. MISSING .or. & + sixprc_tmp .ne. MISSING .or. & + mscprc_tmp .ne. MISSING .or. & + (preswx_tmp .ne. MISSING .and. & + pastwx_tmp .ne. MISSING))) then + twfprc(stncnt) = twfprc_tmp + duration(stncnt) = duration_tmp + sixprc(stncnt) = sixprc_tmp + mscprc(stncnt) = mscprc_tmp + ilat(stncnt) = ilat_tmp + ilon(stncnt) = ilon_tmp + bsn(stncnt) = bsn_tmp + network(stncnt) = network_tmp + plat_id(stncnt) = plat_id_tmp + wmocode_id(stncnt) = wmocode_id_tmp + fipscode_id(stncnt) = fipscode_id_tmp + pastwx(stncnt) = pastwx_tmp + preswx(stncnt) = preswx_tmp + wmoblk(stncnt) = wmoblk_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + cycle + end if + + ! Logic for older file format. Code above assigns + ! the file date/time as the report date/time. + ! See if there is any additional information worth + ! saving. The AGRMET logic overwrites the older data + ! with the newer if the newer data is a higher amount. + ! An exception is that "zero" six-hour precip is ignored + ! if 24-hr or 12-hr precip is positive, apparently + ! because "zero" six-hour precip reports in this case are + ! typically from an asynoptic ob. We follow that logic + ! here. + if (YYYYMMDDhhmmss(stncnt) == YYYYMMDDhhmmss_tmp) then + if (twfprc(stncnt) < twfprc_tmp) then + twfprc(stncnt) = twfprc_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + end if + + if (mscprc(stncnt) .eq. MISSING .and. & + mscprc_tmp .ne. MISSING) then + ! We don't have a misc precip stored yet, so do it + ! here. + mscprc(stncnt) = mscprc_tmp + duration(stncnt) = duration_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + else if (duration_tmp > duration(stncnt) .and. & + duration_tmp > 1 .and. & + mscprc_tmp .ne. MISSING) then + ! Try to capture 3-hr or other longer duration + ! precip. + mscprc(stncnt) = mscprc_tmp + duration(stncnt) = duration_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + else if (mscprc_tmp > mscprc(stncnt) .and. & + duration_tmp == duration(stncnt)) then + ! Somewhat mimics AGRMET. Save larger accum for + ! current duration. + mscprc(stncnt) = mscprc_tmp + duration(stncnt) = duration_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + else if ((mscprc_tmp > mscprc(stncnt)) .and. & + (duration_tmp == MISSING .or. & + duration_tmp == 0) .and. & + (duration(stncnt) == MISSING .or. & + duration(stncnt) == 0)) then + ! Somewhat mimics AGRMET. Save larger accum for + ! undefined duration, for use in certain regions + ! (e.g., Russia) + mscprc(stncnt) = mscprc_tmp + duration(stncnt) = duration_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + end if + if ( (twfprc(stncnt) > 0) .or. & + (duration(stncnt) == 12 .and. & + mscprc(stncnt) > 0) ) then + if (sixprc(stncnt) == MISSING .and. & + sixprc_tmp == 0) then + sixprc(stncnt) = MISSING + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + else if (sixprc(stncnt) == 0 .and. & + sixprc_tmp == MISSING) then + sixprc(stncnt) = MISSING + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + else + if (sixprc(stncnt) < sixprc_tmp) then + sixprc(stncnt) = sixprc_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + end if + end if + else + if (sixprc(stncnt) < sixprc_tmp) then + sixprc(stncnt) = sixprc_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + end if + end if + end if + else + ! This isn't the same station, so save it. + stncnt = stncnt + 1 + twfprc(stncnt) = twfprc_tmp + duration(stncnt) = duration_tmp + sixprc(stncnt) = sixprc_tmp + mscprc(stncnt) = mscprc_tmp + ilat(stncnt) = ilat_tmp + ilon(stncnt) = ilon_tmp + bsn(stncnt) = bsn_tmp + network(stncnt) = network_tmp + plat_id(stncnt) = plat_id_tmp + wmocode_id(stncnt) = wmocode_id_tmp + fipscode_id(stncnt) = fipscode_id_tmp + pastwx(stncnt) = pastwx_tmp + preswx(stncnt) = preswx_tmp + wmoblk(stncnt) = wmoblk_tmp + YYYYMMDDhhmmss(stncnt) = YYYYMMDDhhmmss_tmp + cycle + end if + end if + end do + + if (use_expanded_station_ids == 1) cycle ! These files are global + end do ! ihemi + + ! Since we combined both the NH and SH files, the resulting list + ! is unsorted. + ! Bubble sort the reports by network. + if (use_expanded_station_ids == 0) then + ipass = 1 + exchanges = .true. + do while ((ipass < stncnt) .and. exchanges) + exchanges = .false. + do j = 1, stncnt - ipass + if (network(j) > network(j+1)) then + call swap_int(twfprc(j), twfprc(j+1)) + call swap_int(duration(j), duration(j+1)) + call swap_int(sixprc(j), sixprc(j+1)) + call swap_int(mscprc(j), mscprc(j+1)) + call swap_int(ilat(j), ilat(j+1)) + call swap_int(ilon(j), ilon(j+1)) + call swap_int(bsn(j), bsn(j+1)) + call swap_char10(network(j), network(j+1)) + call swap_char32(plat_id(j), plat_id(j+1)) + call swap_char2(wmocode_id(j), wmocode_id(j+1)) + call swap_char2(fipscode_id(j), fipscode_id(j+1)) + call swap_int(pastwx(j), pastwx(j+1)) + call swap_int(preswx(j), preswx(j+1)) + call swap_int(wmoblk(j), wmoblk(j+1)) + call swap_char14(YYYYMMDDhhmmss(j), YYYYMMDDhhmmss(j+1)) + exchanges = .true. + end if + end do + ipass = ipass + 1 + end do + + ! Now bubble sort by station ID within the same network + ipass = 1 + exchanges = .true. + do while ((ipass < stncnt) .and. exchanges) + exchanges = .false. + do j = 1, stncnt - ipass + if ((network(j) == network(j+1)) .and. & + (plat_id(j) > plat_id(j+1))) then + call swap_int(twfprc(j), twfprc(j+1)) + call swap_int(duration(j), duration(j+1)) + call swap_int(sixprc(j), sixprc(j+1)) + call swap_int(mscprc(j), mscprc(j+1)) + call swap_int(ilat(j), ilat(j+1)) + call swap_int(ilon(j), ilon(j+1)) + call swap_int(bsn(j), bsn(j+1)) + call swap_char10(network(j), network(j+1)) + call swap_char32(plat_id(j), plat_id(j+1)) + call swap_char2(wmocode_id(j), wmocode_id(j+1)) + call swap_char2(fipscode_id(j), fipscode_id(j+1)) + call swap_int(pastwx(j), pastwx(j+1)) + call swap_int(preswx(j), preswx(j+1)) + call swap_int(wmoblk(j), wmoblk(j+1)) + call swap_char14(YYYYMMDDhhmmss(j), YYYYMMDDhhmmss(j+1)) + exchanges = .true. + end if + end do + ipass = ipass + 1 + end do + end if + + ! Report if any WMO obs are not legacy 5-digit SYNOP + do j = 1, stncnt + if (network(j) .ne. "WMO") cycle + if (.not. len_trim(plat_id(j)) == 5) then + write(LIS_logunit,*) '[INFO] Found non SYNOP WMO station ', & + trim(plat_id(j)) + else if (verify(trim(plat_id(j)), "0123456789") .ne. 0) then + write(LIS_logunit,*) '[INFO] Found non SYNOP WMO station ', & + trim(plat_id(j)) + end if + end do + + ! Copy into Gage_type object + allocate(amts24(nsize_total)) ; amts24 = twfprc + allocate(amts21(nsize_total)) ; amts21 = MISSING + allocate(amts18(nsize_total)) ; amts18 = MISSING + allocate(amts15(nsize_total)) ; amts15 = MISSING + allocate(amts12(nsize_total)) ; amts12 = MISSING + allocate(amts09(nsize_total)) ; amts09 = MISSING + allocate(amts06(nsize_total)) ; amts06 = sixprc + allocate(amts03(nsize_total)) ; amts03 = MISSING + allocate(amts02(nsize_total)) ; amts02 = MISSING + allocate(amts01(nsize_total)) ; amts01 = MISSING + allocate(amts00(nsize_total)) ; amts00 = mscprc + + call obscur%new(date10, stncnt, YYYYMMDDhhmmss, network, plat_id, & + wmocode_id, fipscode_id, wmoblk, bsn, ilat, ilon, & + amts24, amts21, amts18, amts15, amts12, amts09, amts06, & + amts03, amts02, amts01, amts00, duration, preswx, pastwx) + + ! Clean up the temporary arrays + deallocate(twfprc) + deallocate(duration) + deallocate(sixprc) + deallocate(mscprc) + deallocate(ilat) + deallocate(ilon) + deallocate(bsn) + deallocate(network) + deallocate(plat_id) + deallocate(wmocode_id) + deallocate(fipscode_id) + deallocate(pastwx) + deallocate(preswx) + deallocate(wmoblk) + deallocate(YYYYMMDDhhmmss) + deallocate(amts24) + deallocate(amts21) + deallocate(amts18) + deallocate(amts15) + deallocate(amts12) + deallocate(amts09) + deallocate(amts06) + deallocate(amts03) + deallocate(amts02) + deallocate(amts01) + deallocate(amts00) + + ! Check for unphysical values. + call obscur%check_gross_errors() + + ! Reconcile values in same report (shorter durations should not be + ! larger than longer durations) + call obscur%reconcile_self() + + ! Fill gaps if possible + call obscur%fill_gaps() + + ! Use the miscellaneous precip, with special rules for some + ! countries. + call obscur%use_misc_precip() + + ! Leverage present and past weather information to identify + ! zero precip durations. + !EMK...Disable until more accurate inspection of time in new + !preobs files is implemented. + !call obscur%use_preswx_pastwx() + + ! Try fetching presav files from earlier hours and reconcile. + write(LIS_logunit,*)'[INFO] Will compare with earlier gage reports.' + do deltahr = 3, 21, 3 + call esmf_timeintervalset(deltatime, yy=0, mm=0, d=0, & + h=deltahr, m=0, s=0, rc=rc) + prevtime = curtime - deltatime + call esmf_timeget(prevtime, yy=prevyear, mm=prevmonth, & + dd=prevday, h=prevhour, rc=rc) + write(presav_filename,'(A,A,A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(rootdir), '/', trim(presavdir), '/presav2.03hr.', & + prevyear, prevmonth, prevday, prevhour + inquire(file=presav_filename, exist=file_exists) + if (file_exists) then + write(LIS_logunit,*)'[INFO] Comparing against data in ', & + trim(presav_filename) + write(prevdate10,'(i4.4,i2.2,i2.2,i2.2)') & + prevyear, prevmonth, prevday, prevhour + call obsprev%read_data(presav_filename, prevdate10) + if (deltahr == 3) then + call obscur%reconcile_gages03(obsprev) + else if (deltahr == 6) then + call obscur%reconcile_gages06(obsprev) + else if (deltahr == 9) then + call obscur%reconcile_gages09(obsprev) + else if (deltahr == 12) then + call obscur%reconcile_gages12(obsprev) + else if (deltahr == 15) then + call obscur%reconcile_gages15(obsprev) + else if (deltahr == 18) then + call obscur%reconcile_gages18(obsprev) + else if (deltahr == 21) then + call obscur%reconcile_gages21(obsprev) + end if + call obsprev%delete() + else + write(LIS_logunit,*)'[WARN] Cannot find ', trim(presav_filename) + write(LIS_logunit,*) & + '[WARN] Will skip reconciling with obs from ', & + abs(deltahr),' hours ago' + end if + end do + + ! Correct for overnight reporting issues in South America + write(LIS_logunit,*) & + '[INFO] Correcting overnight reporting in South America' + call obscur%correct_region3_12z() + + ! Write the final presave file + write(presav_filename,'(A,A,A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(rootdir), '/', trim(presavdir), '/presav2.03hr.', & + year, month, day, hour + write(LIS_logunit,*)'[INFO] Writing to ', trim(presav_filename) + call obscur%write_data(presav_filename) + call obscur%delete() + + end subroutine USAF_read_preobs + + ! Generate name of preobs file. Based on code in AGRMET_getpcpobs.F90 + subroutine get_preobs_filename(filename, rootdir, preobsdir, & + use_timestamp, & + ihemi, year, month, day, hour, use_expanded_station_ids) + + ! Defaults + implicit none + + ! Arguments + character(*), intent(out) :: filename + character(*), intent(in) :: rootdir + character(*), intent(in) :: preobsdir + integer, intent(in) :: use_timestamp + integer, intent(in) :: ihemi + integer, intent(in) :: year + integer, intent(in) :: month + integer, intent(in) :: day + integer, intent(in) :: hour + integer, intent(in) :: use_expanded_station_ids + + ! Locals + character(10) :: ftime1, ftime2 + character(2), parameter :: FHEMI(2) = (/'nh', 'sh'/) + + write(ftime2, '(i4.4, i2.2, i2.2, i2.2)') year, month, day, hour + + if (use_expanded_station_ids == 0) then + if (use_timestamp == 1) then + write(ftime1, '(a1, i4.4, i2.2, i2.2, a1)') '/', & + year, month, day, '/' + filename = trim(rootdir) // ftime1 // trim(preobsdir) // & + '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 + else + filename = trim(rootdir) // '/' // trim(preobsdir) // & + '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 + endif + else if (use_expanded_station_ids == 1) then + if (use_timestamp == 1) then + write(ftime1, '(a1, i4.4, i2.2, i2.2, a1)') '/', & + year, month, day, '/' + filename = trim(rootdir) // ftime1 // trim(preobsdir) // & + '/preobs_03hr_' // ftime2 // ".txt" + else + filename = trim(rootdir) // '/' // trim(preobsdir) // & + '/preobs_03hr_' // ftime2 // ".txt" + endif + end if + end subroutine get_preobs_filename + + ! Set block number for a WMO station + function set_bsn_wmo(use_expanded_station_id, plat_id, fipscode_id, & + wmocode_id) result(bsn) + + ! Imports + use USAF_GagesMod, only: JMOBS_SWEDEN_LOWLIMIT, & + JMOBS_DENMARK_LOWLIMIT, JMOBS_RUSSIA_LOWLIMIT, & + JMOBS_INDIA_LOWLIMIT, JMOBS_SRILANKA_LOWLIMIT, & + JMOBS_S_AMER_LOWLIMIT + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: use_expanded_station_id + character(32), intent(in) :: plat_id + character(2), intent(in) :: fipscode_id + character(2), intent(in) :: wmocode_id + + ! Return variable + integer :: bsn + + bsn = 0 + + ! Old preobs files don't have any country codes. Just copy the + ! 5-digit ID and use as is. + if (use_expanded_station_id == 0) then + read(plat_id, '(i5.5)') bsn + return + end if + + ! If this is a legacy 5-digit WMO ID, just copy it. + if (verify(trim(plat_id), "0123456789") == 0 & + .and. len_trim(plat_id) == 5) then + read(plat_id, '(i5.5)') bsn + return + end if + + ! WIGOS supports legacy 5-digit WMO IDs with a special prefix + if (len_trim(plat_id) == 15) then + if (plat_id(1:10) == "0-20000-0-" .and. & + verify(trim(plat_id(11:15)), "0123456789") == 0) then + read(plat_id(11:15), '(i5.5)') bsn + return + end if + end if + + ! Try using the FIPS country code. This code seems to be more + ! accurate than the WMO code. + select case(fipscode_id) + case('SW') + bsn = JMOBS_SWEDEN_LOWLIMIT + return + case('DA') + bsn = JMOBS_DENMARK_LOWLIMIT + return + case('AM', 'AJ', 'BO', 'EN', 'GG', 'LG', 'LH', 'KZ', & + 'KG', 'MD', 'RS', 'TI', 'TX', 'UP', 'UZ') + ! AM is Armenia + ! AJ is Azerbaijan + ! BO is Belarus + ! EN is Estonia + ! GG is Georgia + ! LG is Latvia + ! LH is Lituania + ! KZ is Kazakhstan + ! KG is Kyrgyzstan + ! MD is Moldova + ! RS is Russia + ! TI is Tajikistan + ! TX is Turkmenistan + ! UP is Ukraine + ! UZ is Uzbekistan + bsn = JMOBS_RUSSIA_LOWLIMIT + return + case ("IN") + bsn = JMOBS_INDIA_LOWLIMIT + return + case ("CE") + bsn = JMOBS_SRILANKA_LOWLIMIT + return + case ('AR', 'BL', 'BR', 'CI', 'CO', 'EC', 'FK', 'FG', 'GY', & + 'PA', 'PE', 'SX', 'NS', 'UY', 'VE') + ! AR is Argentina + ! BL is Bolivia + ! BR is Brazil + ! CI is Chile + ! CO is Colombia + ! EC is Ecuador + ! FK is Falkland Islands + ! FG is French Guiana + ! GY is Guyana + ! PA is Paraguay + ! PE is Peru + ! SX is South Georgia and the South Sandwich Islands + ! NS is Suriname + ! UY is Uruguay + ! VE is Venezuela + bsn = JMOBS_S_AMER_LOWLIMIT + return + case default + bsn = 0 + end select + + ! Try using the WMO country code + select case(wmocode_id) + case('SE') + bsn = JMOBS_SWEDEN_LOWLIMIT + return + case('DK') + bsn = JMOBS_DENMARK_LOWLIMIT + return + case('AM', 'AZ', 'BY', 'EE', 'GE', 'LV', 'LT', 'KZ', 'KG', & + 'MD', 'RU', 'TJ', 'TM', 'UA', 'UZ') + ! AM is Armenia + ! AZ is Azerbaijan + ! BY is Belarus + ! EE is Estonia + ! GE is Georgia + ! LV is Latvia + ! LT is Lithuania + ! KZ is Kazakhstan + ! KG is Kyrgyzstan + ! MD is Moldova + ! RU is Russia + ! TJ is Tajikistan + ! TM is Turkmenistan + ! UA is Ukraine + ! UZ is Uzbekistan + bsn = JMOBS_RUSSIA_LOWLIMIT + return + case ("IN") + bsn = JMOBS_INDIA_LOWLIMIT + return + case ("LK") + bsn = JMOBS_SRILANKA_LOWLIMIT + return + case ('AR', 'BO', 'BR', 'CL', 'CO', 'EC', 'FK', 'GF', 'GY', & + 'PY', 'PE', 'GS', 'SR', 'UG', 'VE') + ! AR is Argentina + ! BO is Bolivia + ! BR is Brazil + ! CL is Chile + ! CO is Colombia + ! EC is Ecuador + ! FK is Falkland Islands + ! GF is French Guiana + ! GY is Guyana + ! PY is Paraguay + ! PE is Peru + ! GS is South Georgia and the South Sandwich Islands + ! SR is Suriname + ! UG is Uruguay + ! VE is Venezuela + bsn = JMOBS_S_AMER_LOWLIMIT + return + case default + bsn = 0 + end select + + end function set_bsn_wmo + + subroutine swap_int(var1, var2) + implicit none + integer, intent(inout) :: var1 + integer, intent(inout) :: var2 + integer :: tmp + tmp = var1 + var1 = var2 + var2 = tmp + end subroutine swap_int + + subroutine swap_char2(var1, var2) + implicit none + character(2), intent(inout) :: var1 + character(2), intent(inout) :: var2 + character(2) :: tmp + tmp = var1 + var1 = var2 + var2 = tmp + end subroutine swap_char2 + + subroutine swap_char10(var1, var2) + implicit none + character(10), intent(inout) :: var1 + character(10), intent(inout) :: var2 + character(10) :: tmp + tmp = var1 + var1 = var2 + var2 = tmp + end subroutine swap_char10 + + subroutine swap_char14(var1, var2) + implicit none + character(14), intent(inout) :: var1 + character(14), intent(inout) :: var2 + character(14) :: tmp + tmp = var1 + var1 = var2 + var2 = tmp + end subroutine swap_char14 + + subroutine swap_char32(var1, var2) + implicit none + character(32), intent(inout) :: var1 + character(32), intent(inout) :: var2 + character(32) :: tmp + tmp = var1 + var1 = var2 + var2 = tmp + end subroutine swap_char32 + + ! Try to set FIPS country code based on WIGOS issuer number. Only + ! certain specific countries are checked for (for special accumulation + ! rules). + function get_fips_from_wigos_issuer(stn) result (fips) + + ! Defaults + implicit none + + ! Arguments + character(*),intent(in) :: stn + + ! Return variable + character(2) :: fips + + ! Locals + integer :: idx1, idx2 + integer :: id + + fips = '??' ! First guess + + ! See if this is a WIGOS station ID; if so, the issuer code is the + ! integer string between the first two dashes. If this is not + ! WIGOS, just return. + idx1 = scan(stn,'-') + if (idx1 == 0) return + idx2 = scan(stn(idx1+1:len(stn)),'-') + if (idx2 == 0) return + if (verify(trim(stn(idx1+1:idx2+1)), "0123456789") .ne. 0) return + read(stn(idx1+1:idx2+1), '(i5.5)') id + + ! Select FIPS code for specific countries where we have special rules. + select case(id) + case(752) + fips = 'SW' ! Sweden + case(208) + fips = 'DA' ! Denmark + case(051) ! Post-Soviet countries start here + fips = 'AM' ! Armenia + case(031) + fips = 'AJ' ! Azerbaijan + case(112) + fips = 'BO' ! Belarus + case(233) + fips = 'EN' ! Estonia + case(268) + fips = 'GG' ! Georgia + case(428) + fips = 'LG' ! Latvia + case(440) + fips = 'LH' ! Lithuania + case(398) + fips = 'KZ' ! Kazakhstan + case(417) + fips = 'KG' ! Kyrgyzstan + case(498) + fips = 'MD' ! Moldova + case(643) + fips = 'RS' ! Russia + case(762) + fips = 'TI' ! Tajikistan + case(795) + fips = 'TX' ! Turkmenistan + case(804) + fips = 'UP' ! Ukraine + case(860) + fips = 'UZ' ! Uzbekistan + case(356) ! Post-Soviet countries end here + fips = 'IN' ! India + case(144) + fips = 'CE' ! Sri Lanka + case(032) ! South American countries start here + fips = 'AR' ! Argentina + case(068) + fips = 'BL' ! Bolivia + case(076) + fips = 'BR' ! Brazil + case(152) + fips = 'CI' ! Chile + case(170) + fips = 'CO' ! Columbia + case(218) + fips = 'EC' ! Ecuador + case(238) + fips = 'FK' ! Falkland Islands + case(254) + fips = 'FG' ! French Guiana + case(328) + fips = 'GY' ! Guyana + case(600) + fips = 'PA' ! Paraguay + case(604) + fips = 'PE' ! Peru + case(239) + fips = 'SX' ! South Georgia and the South Sandwich Islands + case(740) + fips = 'NS' ! Suriname + case(858) + fips = 'UY' ! Uruguay + case(862) + fips = 'VE' ! Venezuela + end select + end function get_fips_from_wigos_issuer + +end module USAF_PreobsReaderMod From 06a39ebe294479d5a6dd20ce444b86c205503d8f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 17 Oct 2023 09:01:26 -0400 Subject: [PATCH 188/328] Added imports to LIS_logMod.F90. --- lis/metforcing/usaf/USAF_GagesMod.F90 | 8 +++++--- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 6 ++---- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index ef8c7496c..4dc340f98 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -2071,6 +2071,9 @@ end subroutine check_latlons ! from AGRMET_processobs. subroutine set_unique_networks(this) + ! Imports + use LIS_logMod, only: LIS_logunit, LIS_endrun + ! Defaults implicit none @@ -2108,10 +2111,9 @@ subroutine set_unique_networks(this) else if (this%networks(i) .ne. prior_net) then this%lasts(net_count) = i - 1 net_count = net_count + 1 - ! FIXME...Update for LIS_logunit and LIS_endrun if (net_count .gt. MAX_UNIQUE_NETWORKS) then - print*,'[ERR] Too many unique networks!' - stop + write(LIS_logunit,*) '[ERR] Too many unique networks!' + call LIS_endrun end if this%firsts(net_count) = i this%unique_networks(net_count) = this%networks(i) diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index dcc901e8b..d30ac2ebc 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -17,9 +17,6 @@ module USAF_PreobsReaderMod ! Public routines public :: USAF_read_preobs - ! FIXME: Replace this with LIS_logMod.F90 - integer, parameter :: LIS_logunit = 6 - integer, parameter :: MISSING = -99999999 contains @@ -32,7 +29,8 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & ! Imports use ESMF - use USAF_GagesMod, only : USAF_Gages_t + use LIS_logMod, only: LIS_logunit + use USAF_GagesMod, only: USAF_Gages_t ! Defaults implicit none From 2ee11bc203749ada6a181ad5cb515dabf6f68eb2 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 17 Oct 2023 14:38:50 -0400 Subject: [PATCH 189/328] Removed rootdir argument. --- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 32 +++++++++----------- 1 file changed, 15 insertions(+), 17 deletions(-) diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index d30ac2ebc..8e2a04cc9 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -23,7 +23,7 @@ module USAF_PreobsReaderMod ! Read preobs files, perform simple preprocessing, and store ! in database. - subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & + subroutine USAF_read_preobs(preobsdir, presavdir, & use_timestamp, & year, month, day, hour, use_expanded_station_ids) @@ -36,7 +36,6 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & implicit none ! Arguments - character(*), intent(in) :: rootdir character(*), intent(in) :: preobsdir character(*), intent(in) :: presavdir integer, intent(in) :: use_timestamp @@ -123,7 +122,7 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & nsize_total = 0 do ihemi = 1, 2 - call get_preobs_filename(filename, rootdir, preobsdir, & + call get_preobs_filename(filename, preobsdir, & use_timestamp, & ihemi, year, month, day, hour, use_expanded_station_ids) @@ -202,7 +201,7 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & ! along the way. stncnt = 0 do ihemi = 1, 2 - call get_preobs_filename(filename, rootdir, preobsdir, & + call get_preobs_filename(filename, preobsdir, & use_timestamp, & ihemi, year, month, day, hour, use_expanded_station_ids) @@ -636,8 +635,8 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & prevtime = curtime - deltatime call esmf_timeget(prevtime, yy=prevyear, mm=prevmonth, & dd=prevday, h=prevhour, rc=rc) - write(presav_filename,'(A,A,A,A,i4.4,i2.2,i2.2,i2.2)') & - trim(rootdir), '/', trim(presavdir), '/presav2.03hr.', & + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(presavdir), '/presav2.03hr.', & prevyear, prevmonth, prevday, prevhour inquire(file=presav_filename, exist=file_exists) if (file_exists) then @@ -676,8 +675,8 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & call obscur%correct_region3_12z() ! Write the final presave file - write(presav_filename,'(A,A,A,A,i4.4,i2.2,i2.2,i2.2)') & - trim(rootdir), '/', trim(presavdir), '/presav2.03hr.', & + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(presavdir), '/presav2.03hr.', & year, month, day, hour write(LIS_logunit,*)'[INFO] Writing to ', trim(presav_filename) call obscur%write_data(presav_filename) @@ -686,7 +685,7 @@ subroutine USAF_read_preobs(rootdir, preobsdir, presavdir, & end subroutine USAF_read_preobs ! Generate name of preobs file. Based on code in AGRMET_getpcpobs.F90 - subroutine get_preobs_filename(filename, rootdir, preobsdir, & + subroutine get_preobs_filename(filename, preobsdir, & use_timestamp, & ihemi, year, month, day, hour, use_expanded_station_ids) @@ -695,7 +694,6 @@ subroutine get_preobs_filename(filename, rootdir, preobsdir, & ! Arguments character(*), intent(out) :: filename - character(*), intent(in) :: rootdir character(*), intent(in) :: preobsdir integer, intent(in) :: use_timestamp integer, intent(in) :: ihemi @@ -713,22 +711,22 @@ subroutine get_preobs_filename(filename, rootdir, preobsdir, & if (use_expanded_station_ids == 0) then if (use_timestamp == 1) then - write(ftime1, '(a1, i4.4, i2.2, i2.2, a1)') '/', & + write(ftime1, '(i4.4, i2.2, i2.2)') & year, month, day, '/' - filename = trim(rootdir) // ftime1 // trim(preobsdir) // & + filename = ftime1 // '/' // trim(preobsdir) // & '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 else - filename = trim(rootdir) // '/' // trim(preobsdir) // & + filename = trim(preobsdir) // & '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 endif else if (use_expanded_station_ids == 1) then if (use_timestamp == 1) then - write(ftime1, '(a1, i4.4, i2.2, i2.2, a1)') '/', & - year, month, day, '/' - filename = trim(rootdir) // ftime1 // trim(preobsdir) // & + write(ftime1, '(i4.4, i2.2, i2.2)') & + year, month, day + filename = ftime1 // '/' // trim(preobsdir) // & '/preobs_03hr_' // ftime2 // ".txt" else - filename = trim(rootdir) // '/' // trim(preobsdir) // & + filename = trim(preobsdir) // & '/preobs_03hr_' // ftime2 // ".txt" endif end if From 6a289dde18ec1f365ab4b1eb8dc966cf623deadf Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 19 Oct 2023 15:30:08 -0400 Subject: [PATCH 190/328] Added testcase configure files. --- .../DAobs_LSM_pclimo_transfer/README | 15 + .../DAobs_LSM_pclimo_transfer/ldt.config | 308 +++++++++++++++++ .../DAobs_SMAP_pclimo_transfer/README | 15 + .../DAobs_SMAP_pclimo_transfer/README~ | 15 + .../DAobs_SMAP_pclimo_transfer/ldt.config | 316 ++++++++++++++++++ .../NOAHMP36_OUTPUT_LIST.TBL.dyn.full | 218 ++++++++++++ .../dataassim/SMAP_sm_pclimo_transfer/README | 25 ++ .../SMAP_sm_pclimo_transfer/lis.config | 260 ++++++++++++++ 8 files changed, 1172 insertions(+) create mode 100644 ldt/testcases/DAobs_LSM_pclimo_transfer/README create mode 100755 ldt/testcases/DAobs_LSM_pclimo_transfer/ldt.config create mode 100644 ldt/testcases/DAobs_SMAP_pclimo_transfer/README create mode 100644 ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ create mode 100755 ldt/testcases/DAobs_SMAP_pclimo_transfer/ldt.config create mode 100755 lis/testcases/dataassim/SMAP_sm_pclimo_transfer/NOAHMP36_OUTPUT_LIST.TBL.dyn.full create mode 100644 lis/testcases/dataassim/SMAP_sm_pclimo_transfer/README create mode 100755 lis/testcases/dataassim/SMAP_sm_pclimo_transfer/lis.config diff --git a/ldt/testcases/DAobs_LSM_pclimo_transfer/README b/ldt/testcases/DAobs_LSM_pclimo_transfer/README new file mode 100644 index 000000000..8a261ad3b --- /dev/null +++ b/ldt/testcases/DAobs_LSM_pclimo_transfer/README @@ -0,0 +1,15 @@ +LSM Soil Moisture Test Case for Precip Climo and Relocating CDFs + +This testcase processes LIS LSM data (Noah.4.0.1) to generate a CDF. + +This directory contains: + +* This README file. +* The ldt.config file used for this test case. (This file should be + edited to make sure that the locations of the parameter and forcing + files are specified correctly.) + +To run this test case: +* Generate the LDT executable. +* Run the LDT executable using the ldt.config file and the sample input + data. diff --git a/ldt/testcases/DAobs_LSM_pclimo_transfer/ldt.config b/ldt/testcases/DAobs_LSM_pclimo_transfer/ldt.config new file mode 100755 index 000000000..0ed463e6e --- /dev/null +++ b/ldt/testcases/DAobs_LSM_pclimo_transfer/ldt.config @@ -0,0 +1,308 @@ +# == LDT Main Entry Options == + +LDT running mode: "DA preprocessing" # LDT type of run-mode (top-level option) +Processed LSM parameter filename: ../procLSM/lis_input.d01.nc # Final output file read by LIS-7 + +LIS number of nests: 1 # Total number of nests run by LIS +Number of surface model types: 1 # Total number of desired surface model types +Surface model types: "LSM" # Surface models: LSM | Openwater +Land surface model: "Noah-MP.4.0.1" # Enter LSM(s) of choice +Routing model: "none" # "HYMAP" # "none" +Lake model: "none" # Enter Lake model(s) of choice +Water fraction cutoff value: 0.5 # Fraction at which gridcell is designated as 'water' +#Glacier fraction cutoff value: 0.2 + +Number of met forcing sources: 0 # Enter number of forcing types +Met forcing sources: "NLDAS2" # Enter 'none' if no forcing selected +Met spatial transform methods: neighbor # bilinear | budget-bilinear | neighbor | average +Topographic correction method (met forcing): "none" # none | lapse-rate + +LDT diagnostic file: ldtlog.strat.p.climo.15bins # Log-based diagnostic output file +Undefined value: -9999.0 # Universal undefined value +LDT output directory: LDTOUT.strat.p.climo.15bins # If metrics or stats are written out +Number of ensembles per tile: 1 # The number of ensemble members per tile + +#LIS domain: +Map projection of the LIS domain: latlon +Run domain lower left lat: 25.0625 +Run domain lower left lon: -124.9375 +Run domain upper right lat: 52.9375 +Run domain upper right lon: -67.0625 +Run domain resolution (dx): 0.125 +Run domain resolution (dy): 0.125 + +# == Landcover, Landmask and Soil Texture Parameters == + +#Landcover/Mask Parameter Inputs # +Landcover data source: "AVHRR" #"MODIS_Native" # +Landcover classification: "UMD" # "IGBPNCEP" # # Enter land cover classification type +Landcover file: ../input/LS_PARAMETERS/NLDAS_0.125/umdveg_dom_nldas.1gd4r # ./input/LS_PARAMETERS/noah_2dparms/igbp.bin # # Landcover map path +Landcover spatial transform: none +Landcover fill option: neighbor +Landcover fill radius: 5 +Landcover fill value: 4 +Landcover map projection: latlon +Landcover lower left lat: 25.0625 +Landcover lower left lon: -124.9375 +Landcover upper right lat: 52.9375 +Landcover upper right lon: -67.0625 +Landcover resolution (dx): 0.125 +Landcover resolution (dy): 0.125 + +Create or readin landmask: "readin" +Landmask data source: "AVHRR" # If 'created', recommended to put Landcover source name here +Landmask file: ../input/LS_PARAMETERS/irrigation/conus_modis/IRR_N125_mask.1gd4r +Landmask spatial transform: none +Landmask map projection: latlon +Landmask lower left lat: 25.0625 +Landmask lower left lon: -124.9375 +Landmask upper right lat: 52.9375 +Landmask upper right lon: -67.0625 +Landmask resolution (dx): 0.125 +Landmask resolution (dy): 0.125 + + +#Soil texture map: +Soil texture data source: ISRIC # STATSGOFAO_LIS +Soil texture map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/TEXMHT_M_sl1_250m.tif # ./input/LS_PARAMETERS/NLDAS_0.125/soil_texture_statsgo_nldas.1gd4r # Enter soil texture map +Soil texture spatial transform: mode # none # none | mode | neighbor | tile +Soil texture fill option: neighbor # none | neighbor +Soil texture fill radius: 5 # Number of pixels to search for neighbor +Soil texture fill value: 6 # Static value to fill where missing +Soil texture map projection: latlon +Soil texture lower left lat: 25.0625 +Soil texture lower left lon: -124.9375 +Soil texture upper right lat: 52.9375 +Soil texture upper right lon: -67.0625 +Soil texture resolution (dx): 0.125 +Soil texture resolution (dy): 0.125 + + +# Soil fraction +#Porosity map: # ../LS_PARAMETERS/UMD/25KM/porosity_FAO +Porosity data source: CONSTANT +Porosity fill value: 0.32 # Porosity fill is currently locked with Soils fill options + +Soil fraction data source: none # ISRIC # none +Soil fraction number of bands: 1 +Sand fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/SNDPPT_M_sl1_250m_ll.tif +Clay fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/CLYPPT_M_sl1_250m_ll.tif +Silt fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/SLTPPT_M_sl1_250m_ll.tif +Soils spatial transform: average +Soils fill option: neighbor # none +Soils fill radius: 1 +Soils fill value: 0.333 +Sand fraction fill value: 0.30 +Clay fraction fill value: 0.35 +Silt fraction fill value: 0.35 + +Soils map projection: latlon +Soils lower left lat: -56.008104 +Soils lower left lon: -180.00 +Soils upper right lat: 83.9991672 +Soils upper right lon: 179.9999424 +Soils resolution (dx): 0.0020833 +Soils resolution (dy): 0.0020833 + + +#Topography maps +#Elevation data source: GTOPO30_Native +#Elevation number of bands: 1 +#Elevation map: ./input/LS_PARAMETERS/topo_parms/GTOPO30/raw_updated +#Elevation fill option: neighbor +#Elevation fill radius: 3 +#Elevation fill value: 287 +# SRTM Elevation data entries: +Elevation data source: "SRTM_LIS" +Elevation map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_elev1km.1gd4r +Elevation number of bands: 1 +Slope data source: "SRTM_LIS" +Slope map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_slope1km.1gd4r +Slope number of bands: 1 +Aspect data source: "SRTM_LIS" +Aspect map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_aspect1km.1gd4r +Aspect number of bands: 1 + + +Topography spatial transform: average +Elevation fill option: average +Elevation fill radius: 5 +Elevation fill value: 0 +Slope fill option: average +Slope fill radius: 5 +Slope fill value: 0.1 +Aspect fill option: average +Aspect fill radius: 5 +Aspect fill value: 0 +Topography map projection: latlon +Topography lower left lat: -59.995 +Topography lower left lon: -179.995 +Topography upper right lat: 89.995 +Topography upper right lon: 179.995 +Topography resolution (dx): 0.01 +Topography resolution (dy): 0.01 + + +# Albedo maps: +Albedo data source: NCEP_Native # NCEP_LIS +Albedo map: ../input/LS_PARAMETERS/noah_2dparms/albedo # ./input/LS_PARAMETERS/NLDAS_0.125/albedo_nldas # Albedo files +Albedo climatology interval: monthly # monthly | quarterly +Albedo spatial transform: bilinear # average | neighbor | bilinear | budget-bilinear +Albedo fill option: neighbor # none | neighbor | average +Albedo fill radius: 1 # Number of pixels to search for neighbor +Albedo fill value: 0.14 # Static value to fill where missing +Albedo map projection: latlon +Albedo lower left lat: 25.0625 +Albedo lower left lon: -124.9375 +Albedo upper right lat: 52.9375 +Albedo upper right lon: -67.0625 +Albedo resolution (dx): 0.125 +Albedo resolution (dy): 0.12.5 + +Max snow albedo data source: NCEP_Native # NCEP_LIS +Max snow albedo map: ../input/LS_PARAMETERS/noah_2dparms/maxsnoalb.asc #./input/LS_PARAMETERS/NLDAS_0.125/maxsnalb_nldas.1gd4r # Max. snow albedo map +Max snow albedo spatial transform: budget-bilinear # none # average | neighbor | bilinear | budget-bilinear +Max snow albedo fill option: neighbor # none | neighbor | average +Max snow albedo fill radius: 3 # Number of pixels to search for neighbor +Max snow albedo fill value: 0.65 # Static value to fill where missing +Max snow albedo map projection: latlon +Max snow albedo lower left lat: 25.0625 +Max snow albedo lower left lon: -124.9375 +Max snow albedo upper right lat: 52.9375 +Max snow albedo upper right lon: -67.0625 +Max snow albedo resolution (dx): 0.125 +Max snow albedo resolution (dy): 0.125 + +# Greenness fraction maps: +Greenness data source: NCEP_Native #NCEP_LIS +Greenness fraction map: ../input/LS_PARAMETERS/noah_2dparms/gfrac # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas # Greenness fraction map +Greenness climatology interval: monthly # monthly +Calculate min-max greenness fraction: .false. +Greenness maximum map: ../input/LS_PARAMETERS/noah_2dparms/gfrac_max.asc # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas.MAX.1gd4r # Maximum greenness fraction map +Greenness minimum map: ../input/LS_PARAMETERS/noah_2dparms/gfrac_min.asc # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas.MIN.1gd4r # Minimum greenness fraction map +Greenness spatial transform: bilinear #none # average | neighbor | bilinear | budget-bilinear +Greenness fill option: neighbor # none | neighbor | average +Greenness fill radius: 1 # Number of pixels to search for neighbor +Greenness fill value: 0.30 # Static value to fill where missing +Greenness maximum fill value: 0.40 # Static value to fill where missing +Greenness minimum fill value: 0.20 # Static value to fill where missing +Greenness map projection: latlon +Greenness lower left lat: 25.0625 +Greenness lower left lon: -124.9375 +Greenness upper right lat: 52.9375 +Greenness upper right lon: -67.0625 +Greenness resolution (dx): 0.125 +Greenness resolution (dy): 0.125 + +# Slope type map: +Slope type data source: NCEP_Native # NCEP_LIS +Slope type map: ../input/LS_PARAMETERS/noah_2dparms/islope #./input/LS_PARAMETERS/NLDAS_0.125/noah_slope_nldas.1gd4r # Slope type map +Slope type spatial transform: neighbor # none # none | neighbor | mode +Slope type fill option: neighbor # none | neighbor +Slope type fill radius: 1 # Number of pixels to search for neighbor +Slope type fill value: 3. # Static value to fill where missing +Slope type map projection: latlon +Slope type lower left lat: 25.0625 +Slope type lower left lon: -124.9375 +Slope type upper right lat: 52.9375 +Slope type upper right lon: -67.0625 +Slope type resolution (dx): 0.125 +Slope type resolution (dy): 0.125 + +# Bottom temperature map (lapse-rate correction option): +Bottom temperature data source: NCEP_LIS +Bottom temperature map: ../input/LS_PARAMETERS/NLDAS_0.125/tbot_nldas.1gd4r +Bottom temperature spatial transform: none # none | average | neighbor | bilinear | budget-bilinear +Bottom temperature fill option: none # none | average | neighbor +Bottom temperature fill radius: 1 # Number of pixels to search for neighbor +Bottom temperature fill value: 287. # Static value to fill where missing +Bottom temperature topographic downscaling: "none" # none | lapse-rate +Bottom temperature map projection: latlon # Projection type +Bottom temperature lower left lat: 25.0625 +Bottom temperature lower left lon: -124.9375 +Bottom temperature upper right lat: 52.9375 +Bottom temperature upper right lon: -67.0625 +Bottom temperature resolution (dx): 0.125 +Bottom temperature resolution (dy): 0.125 + +# ======================================================= +#Forcing elevation +NLDAS2 forcing directory: /discover/nobackup/projects/lis/MET_FORCING/NLDAS2.FORCING +NLDAS2 data center source: "GES-DISC" +NLDAS2 use model level data: 0 +NLDAS2 use model based swdown: 0 +NLDAS2 use model based precip: 0 +NLDAS2 use model based pressure: 0 +Forcing variables list file: ./ldt_forcing_vars.txt + +NLDAS2 elevation difference map: ../input/LS_PARAMETERS/NLDAS_0.125/NARR_elev-diff.1gd4r +NARR terrain height map: ../input/LS_PARAMETERS/NLDAS_0.125/NARR_elevation.1gd4r + +#Noah-MP LSM inputs +Noah-MP PBL Height Value: 900. + +# ----------------------------------------------------------------------------- +# Model-based CDF file generation: +#------------------------------------------------------------------------------ +DA preprocessing method: "CDF generation" +DA observation source: "LIS LSM soil moisture" # "LSM soil moisture" +Name of the preprocessed DA file: "cdf_noahmp401" +Apply anomaly correction to obs: 0 +Temporal resolution of CDFs: "monthly" # yearly | monthly +Number of bins to use in the CDF: 100 +Observation count threshold: 30 +Temporal averaging interval: "1da" +Apply external mask: 0 +External mask directory: none + +LIS soil moisture output model name: "Noah.4.0.1" +LIS soil moisture output directory: ../sim/output.ol/ +LIS soil moisture output format: "netcdf" +LIS soil moisture output methodology: "2d gridspace" +LIS soil moisture output naming style: "3 level hierarchy" +LIS soil moisture output nest index: 1 +LIS soil moisture output map projection: "latlon" +LIS soil moisture domain lower left lat: 25.0625 +LIS soil moisture domain upper right lat: 52.9375 +LIS soil moisture domain lower left lon: -124.9375 +LIS soil moisture domain upper right lon: -67.0625 +LIS soil moisture domain resolution (dx): 0.125 +LIS soil moisture domain resolution (dy): 0.125 + + +Starting year: 2015 +Starting month: 03 +Starting day: 01 +Starting hour: 0 +Starting minute: 0 +Starting second: 0 +Ending year: 2022 +Ending month: 01 +Ending day: 01 +Ending hour: 0 +Ending minute: 0 +Ending second: 0 +LIS output timestep: "6hr" + + +Maximum number of surface type tiles per grid: 1 +Minimum cutoff percentage (surface type tiles): 0.05 +Maximum number of soil texture tiles per grid: 1 +Minimum cutoff percentage (soil texture tiles): 0.05 +Maximum number of soil fraction tiles per grid: 1 +Minimum cutoff percentage (soil fraction tiles): 0.05 +Maximum number of elevation bands per grid: 1 +Minimum cutoff percentage (elevation bands): 0.05 +Maximum number of slope bands per grid: 1 +Minimum cutoff percentage (slope bands): 0.05 +Maximum number of aspect bands per grid: 1 +Minimum cutoff percentage (aspect bands): 0.05 + +# ----------------------------------------------------------------------------- +# Stratification based on precipitation: +#------------------------------------------------------------------------------ +Stratify CDFs by external data: 1 +Number of bins to use for stratification: 15 +Stratification data source: "LIS LSM total precipitation" +External stratification file: "LVT_MEAN_FINAL.202201010000.d01.nc" # "../Precip_climatology/Precip.climo.us.nldas2/LVT_MEAN_FINAL.202109010000.d01.nc" +Write stratified geolocation independent CDFs: 1 diff --git a/ldt/testcases/DAobs_SMAP_pclimo_transfer/README b/ldt/testcases/DAobs_SMAP_pclimo_transfer/README new file mode 100644 index 000000000..aca2520d4 --- /dev/null +++ b/ldt/testcases/DAobs_SMAP_pclimo_transfer/README @@ -0,0 +1,15 @@ +SMAP Soil Moisture Test Case for Precip Climo and Relocating CDFs + +This testcase processes SMAP data to generate a CDF. + +This directory contains: + +* This README file. +* The ldt.config file used for this test case. (This file should be + edited to make sure that the locations of the parameter and forcing + files are specified correctly.) + +To run this test case: +* Generate the LDT executable. +* Run the LDT executable using the ldt.config file and the sample input + data. diff --git a/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ b/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ new file mode 100644 index 000000000..8a261ad3b --- /dev/null +++ b/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ @@ -0,0 +1,15 @@ +LSM Soil Moisture Test Case for Precip Climo and Relocating CDFs + +This testcase processes LIS LSM data (Noah.4.0.1) to generate a CDF. + +This directory contains: + +* This README file. +* The ldt.config file used for this test case. (This file should be + edited to make sure that the locations of the parameter and forcing + files are specified correctly.) + +To run this test case: +* Generate the LDT executable. +* Run the LDT executable using the ldt.config file and the sample input + data. diff --git a/ldt/testcases/DAobs_SMAP_pclimo_transfer/ldt.config b/ldt/testcases/DAobs_SMAP_pclimo_transfer/ldt.config new file mode 100755 index 000000000..456ea0382 --- /dev/null +++ b/ldt/testcases/DAobs_SMAP_pclimo_transfer/ldt.config @@ -0,0 +1,316 @@ +# == LDT Main Entry Options == + +LDT running mode: "DA preprocessing" # LDT type of run-mode (top-level option) +Processed LSM parameter filename: ../procLSM/lis_input.d01.nc # Final output file read by LIS-7 + +LIS number of nests: 1 # Total number of nests run by LIS +Number of surface model types: 1 # Total number of desired surface model types +Surface model types: "LSM" # Surface models: LSM | Openwater +Land surface model: "Noah-MP.4.0.1" # Enter LSM(s) of choice +Routing model: "none" # "HYMAP" # "none" +Lake model: "none" # Enter Lake model(s) of choice +Water fraction cutoff value: 0.5 # Fraction at which gridcell is designated as 'water' +#Glacier fraction cutoff value: 0.2 + +Number of met forcing sources: 0 # Enter number of forcing types +Met forcing sources: "NLDAS2" # Enter 'none' if no forcing selected +Met spatial transform methods: neighbor # bilinear | budget-bilinear | neighbor | average +Topographic correction method (met forcing): "none" # none | lapse-rate + +LDT diagnostic file: ldtlog.strat.p.climo.15bins # Log-based diagnostic output file +Undefined value: -9999.0 # Universal undefined value +LDT output directory: LDTOUT.strat.p.climo.15bins # If metrics or stats are written out +Number of ensembles per tile: 1 # The number of ensemble members per tile + +#LIS domain: +Map projection of the LIS domain: latlon +Run domain lower left lat: 25.0625 +Run domain lower left lon: -124.9375 +Run domain upper right lat: 52.9375 +Run domain upper right lon: -67.0625 +Run domain resolution (dx): 0.125 +Run domain resolution (dy): 0.125 + +# == Landcover, Landmask and Soil Texture Parameters == + +#Landcover/Mask Parameter Inputs # +Landcover data source: "AVHRR" #"MODIS_Native" # +Landcover classification: "UMD" # "IGBPNCEP" # # Enter land cover classification type +Landcover file: ../input/LS_PARAMETERS/NLDAS_0.125/umdveg_dom_nldas.1gd4r # ./input/LS_PARAMETERS/noah_2dparms/igbp.bin # # Landcover map path +Landcover spatial transform: none +Landcover fill option: neighbor +Landcover fill radius: 5 +Landcover fill value: 4 +Landcover map projection: latlon +Landcover lower left lat: 25.0625 +Landcover lower left lon: -124.9375 +Landcover upper right lat: 52.9375 +Landcover upper right lon: -67.0625 +Landcover resolution (dx): 0.125 +Landcover resolution (dy): 0.125 + +Create or readin landmask: "readin" +Landmask data source: "AVHRR" # If 'created', recommended to put Landcover source name here +Landmask file: ../input/LS_PARAMETERS/irrigation/conus_modis/IRR_N125_mask.1gd4r +Landmask spatial transform: none +Landmask map projection: latlon +Landmask lower left lat: 25.0625 +Landmask lower left lon: -124.9375 +Landmask upper right lat: 52.9375 +Landmask upper right lon: -67.0625 +Landmask resolution (dx): 0.125 +Landmask resolution (dy): 0.125 + + +#Soil texture map: +Soil texture data source: ISRIC # STATSGOFAO_LIS +Soil texture map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/TEXMHT_M_sl1_250m.tif # ./input/LS_PARAMETERS/NLDAS_0.125/soil_texture_statsgo_nldas.1gd4r # Enter soil texture map +Soil texture spatial transform: mode # none # none | mode | neighbor | tile +Soil texture fill option: neighbor # none | neighbor +Soil texture fill radius: 5 # Number of pixels to search for neighbor +Soil texture fill value: 6 # Static value to fill where missing +Soil texture map projection: latlon +Soil texture lower left lat: 25.0625 +Soil texture lower left lon: -124.9375 +Soil texture upper right lat: 52.9375 +Soil texture upper right lon: -67.0625 +Soil texture resolution (dx): 0.125 +Soil texture resolution (dy): 0.125 + + +# Soil fraction +#Porosity map: # ../LS_PARAMETERS/UMD/25KM/porosity_FAO +Porosity data source: CONSTANT +Porosity fill value: 0.32 # Porosity fill is currently locked with Soils fill options + +Soil fraction data source: none # ISRIC # none +Soil fraction number of bands: 1 +Sand fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/SNDPPT_M_sl1_250m_ll.tif +Clay fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/CLYPPT_M_sl1_250m_ll.tif +Silt fraction map: ../input/LS_PARAMETERS/soil_parms/ISRIC/v2017/SLTPPT_M_sl1_250m_ll.tif +Soils spatial transform: average +Soils fill option: neighbor # none +Soils fill radius: 1 +Soils fill value: 0.333 +Sand fraction fill value: 0.30 +Clay fraction fill value: 0.35 +Silt fraction fill value: 0.35 + +Soils map projection: latlon +Soils lower left lat: -56.008104 +Soils lower left lon: -180.00 +Soils upper right lat: 83.9991672 +Soils upper right lon: 179.9999424 +Soils resolution (dx): 0.0020833 +Soils resolution (dy): 0.0020833 + + +#Topography maps +#Elevation data source: GTOPO30_Native +#Elevation number of bands: 1 +#Elevation map: ./input/LS_PARAMETERS/topo_parms/GTOPO30/raw_updated +#Elevation fill option: neighbor +#Elevation fill radius: 3 +#Elevation fill value: 287 +# SRTM Elevation data entries: +Elevation data source: "SRTM_LIS" +Elevation map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_elev1km.1gd4r +Elevation number of bands: 1 +Slope data source: "SRTM_LIS" +Slope map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_slope1km.1gd4r +Slope number of bands: 1 +Aspect data source: "SRTM_LIS" +Aspect map: ../input/LS_PARAMETERS/topo_parms/SRTM/SRTM30/srtm_aspect1km.1gd4r +Aspect number of bands: 1 + + +Topography spatial transform: average +Elevation fill option: average +Elevation fill radius: 5 +Elevation fill value: 0 +Slope fill option: average +Slope fill radius: 5 +Slope fill value: 0.1 +Aspect fill option: average +Aspect fill radius: 5 +Aspect fill value: 0 +Topography map projection: latlon +Topography lower left lat: -59.995 +Topography lower left lon: -179.995 +Topography upper right lat: 89.995 +Topography upper right lon: 179.995 +Topography resolution (dx): 0.01 +Topography resolution (dy): 0.01 + + +# Albedo maps: +Albedo data source: NCEP_Native # NCEP_LIS +Albedo map: ../input/LS_PARAMETERS/noah_2dparms/albedo # ./input/LS_PARAMETERS/NLDAS_0.125/albedo_nldas # Albedo files +Albedo climatology interval: monthly # monthly | quarterly +Albedo spatial transform: bilinear # average | neighbor | bilinear | budget-bilinear +Albedo fill option: neighbor # none | neighbor | average +Albedo fill radius: 1 # Number of pixels to search for neighbor +Albedo fill value: 0.14 # Static value to fill where missing +Albedo map projection: latlon +Albedo lower left lat: 25.0625 +Albedo lower left lon: -124.9375 +Albedo upper right lat: 52.9375 +Albedo upper right lon: -67.0625 +Albedo resolution (dx): 0.125 +Albedo resolution (dy): 0.12.5 + +Max snow albedo data source: NCEP_Native # NCEP_LIS +Max snow albedo map: ../input/LS_PARAMETERS/noah_2dparms/maxsnoalb.asc #./input/LS_PARAMETERS/NLDAS_0.125/maxsnalb_nldas.1gd4r # Max. snow albedo map +Max snow albedo spatial transform: budget-bilinear # none # average | neighbor | bilinear | budget-bilinear +Max snow albedo fill option: neighbor # none | neighbor | average +Max snow albedo fill radius: 3 # Number of pixels to search for neighbor +Max snow albedo fill value: 0.65 # Static value to fill where missing +Max snow albedo map projection: latlon +Max snow albedo lower left lat: 25.0625 +Max snow albedo lower left lon: -124.9375 +Max snow albedo upper right lat: 52.9375 +Max snow albedo upper right lon: -67.0625 +Max snow albedo resolution (dx): 0.125 +Max snow albedo resolution (dy): 0.125 + +# Greenness fraction maps: +Greenness data source: NCEP_Native #NCEP_LIS +Greenness fraction map: ../input/LS_PARAMETERS/noah_2dparms/gfrac # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas # Greenness fraction map +Greenness climatology interval: monthly # monthly +Calculate min-max greenness fraction: .false. +Greenness maximum map: ../input/LS_PARAMETERS/noah_2dparms/gfrac_max.asc # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas.MAX.1gd4r # Maximum greenness fraction map +Greenness minimum map: ../input/LS_PARAMETERS/noah_2dparms/gfrac_min.asc # ./input/LS_PARAMETERS/NLDAS_0.125/gfrac_nldas.MIN.1gd4r # Minimum greenness fraction map +Greenness spatial transform: bilinear #none # average | neighbor | bilinear | budget-bilinear +Greenness fill option: neighbor # none | neighbor | average +Greenness fill radius: 1 # Number of pixels to search for neighbor +Greenness fill value: 0.30 # Static value to fill where missing +Greenness maximum fill value: 0.40 # Static value to fill where missing +Greenness minimum fill value: 0.20 # Static value to fill where missing +Greenness map projection: latlon +Greenness lower left lat: 25.0625 +Greenness lower left lon: -124.9375 +Greenness upper right lat: 52.9375 +Greenness upper right lon: -67.0625 +Greenness resolution (dx): 0.125 +Greenness resolution (dy): 0.125 + +# Slope type map: +Slope type data source: NCEP_Native # NCEP_LIS +Slope type map: ../input/LS_PARAMETERS/noah_2dparms/islope #./input/LS_PARAMETERS/NLDAS_0.125/noah_slope_nldas.1gd4r # Slope type map +Slope type spatial transform: neighbor # none # none | neighbor | mode +Slope type fill option: neighbor # none | neighbor +Slope type fill radius: 1 # Number of pixels to search for neighbor +Slope type fill value: 3. # Static value to fill where missing +Slope type map projection: latlon +Slope type lower left lat: 25.0625 +Slope type lower left lon: -124.9375 +Slope type upper right lat: 52.9375 +Slope type upper right lon: -67.0625 +Slope type resolution (dx): 0.125 +Slope type resolution (dy): 0.125 + +# Bottom temperature map (lapse-rate correction option): +Bottom temperature data source: NCEP_LIS +Bottom temperature map: ../input/LS_PARAMETERS/NLDAS_0.125/tbot_nldas.1gd4r +Bottom temperature spatial transform: none # none | average | neighbor | bilinear | budget-bilinear +Bottom temperature fill option: none # none | average | neighbor +Bottom temperature fill radius: 1 # Number of pixels to search for neighbor +Bottom temperature fill value: 287. # Static value to fill where missing +Bottom temperature topographic downscaling: "none" # none | lapse-rate +Bottom temperature map projection: latlon # Projection type +Bottom temperature lower left lat: 25.0625 +Bottom temperature lower left lon: -124.9375 +Bottom temperature upper right lat: 52.9375 +Bottom temperature upper right lon: -67.0625 +Bottom temperature resolution (dx): 0.125 +Bottom temperature resolution (dy): 0.125 + +# ======================================================= +#Forcing elevation +NLDAS2 forcing directory: /discover/nobackup/projects/lis/MET_FORCING/NLDAS2.FORCING +NLDAS2 data center source: "GES-DISC" +NLDAS2 use model level data: 0 +NLDAS2 use model based swdown: 0 +NLDAS2 use model based precip: 0 +NLDAS2 use model based pressure: 0 +Forcing variables list file: ./ldt_forcing_vars.txt + +NLDAS2 elevation difference map: ../input/LS_PARAMETERS/NLDAS_0.125/NARR_elev-diff.1gd4r +NARR terrain height map: ../input/LS_PARAMETERS/NLDAS_0.125/NARR_elevation.1gd4r + +#Noah-MP LSM inputs +Noah-MP PBL Height Value: 900. + +# ----------------------------------------------------------------------------- +# SMAP SM L3 CDF Generation: +#------------------------------------------------------------------------------ +DA preprocessing method: "CDF generation" +DA observation source: "NASA SMAP soil moisture" +Name of the preprocessed DA file: "cdf_smapobs" + +Apply anomaly correction to obs: 0 +Temporal resolution of CDFs: "monthly" # monthly | yearly +Number of bins to use in the CDF: 100 +Observation count threshold: 30 +Temporal averaging interval: "1da" +Apply external mask: 0 +External mask directory: none + +NASA SMAP soil moisture observation directory: ../input/RS_DATA/SMAP/SPL3SMP.007 +NASA SMAP soil moisture data designation: SPL3SMP +NASA SMAP search radius for openwater proximity detection: 3 +SMAP(NASA) soil moisture Composite Release ID (e.g., R16): "R17" + + +Starting year: 2015 +Starting month: 03 +Starting day: 01 +Starting hour: 0 +Starting minute: 0 +Starting second: 0 +Ending year: 2022 +Ending month: 01 +Ending day: 01 +Ending hour: 0 +Ending minute: 0 +Ending second: 0 +LIS output timestep: "6hr" + + +Maximum number of surface type tiles per grid: 1 +Minimum cutoff percentage (surface type tiles): 0.05 +Maximum number of soil texture tiles per grid: 1 +Minimum cutoff percentage (soil texture tiles): 0.05 +Maximum number of soil fraction tiles per grid: 1 +Minimum cutoff percentage (soil fraction tiles): 0.05 +Maximum number of elevation bands per grid: 1 +Minimum cutoff percentage (elevation bands): 0.05 +Maximum number of slope bands per grid: 1 +Minimum cutoff percentage (slope bands): 0.05 +Maximum number of aspect bands per grid: 1 +Minimum cutoff percentage (aspect bands): 0.05 + +# ----------------------------------------------------------------------------- +# Stratification based on precipitation: +#------------------------------------------------------------------------------ +Stratify CDFs by external data: 1 +Number of bins to use for stratification: 15 +Stratification data source: "LIS LSM total precipitation" +External stratification file: "LVT_MEAN_FINAL.202201010000.d01.nc" # "../Precip_climatology/Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc" +Write stratified geolocation independent CDFs: 1 + +#LIS precipitation output model name: "Noah.4.0.1" +#LIS precipitation output directory: output.precip +#LIS precipitation output format: "netcdf" +#LIS precipitation output methodology: "2d gridspace" +#LIS precipitation output naming style: "3 level hierarchy" +#LIS precipitation output nest index: 1 +#LIS precipitation output map projection: "lambert" +#LIS precipitation domain lower left lat: 24.01347 #25.20226 +#LIS precipitation domain lower left lon: -13.1299 #-12.5475 +#LIS precipitation domain true lat1: 66.0 +#LIS precipitation domain true lat2: 29.0 +#LIS precipitation domain standard lon: 15.108 +#LIS precipitation domain resolution: 15.0 #5.0 # 1.0 +#LIS precipitation domain x-dimension size: 385 #1114 +#LIS precipitation domain y-dimension size: 289 #826 # 780 diff --git a/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/NOAHMP36_OUTPUT_LIST.TBL.dyn.full b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/NOAHMP36_OUTPUT_LIST.TBL.dyn.full new file mode 100755 index 000000000..924c0f29d --- /dev/null +++ b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/NOAHMP36_OUTPUT_LIST.TBL.dyn.full @@ -0,0 +1,218 @@ +#short_name select? units signconv timeavg? min/max? std? vert.levels grib_id grib_scalefactor longname +# 0 == Instantaneous output +# 1 == Time averaged output +# 2 == Instantaneous and Time averaged output +# 3 == Accumulated output + +#Energy balance components +Swnet: 0 W/m2 DN 1 0 0 1 111 10 # Net shortwave radiation (W/m2) +Lwnet: 0 W/m2 DN 1 0 0 1 112 10 # Net longwave radiation (W/m2) +Qle: 0 W/m2 UP 1 0 0 1 121 10 # Latent heat flux (W/m2) +Qh: 0 W/m2 UP 1 0 0 1 122 10 # Sensible heat flux (W/m2) +Qg: 0 W/m2 DN 1 0 0 1 155 10 # Ground heat flux (W/m2) +Qf: 0 W/m2 S2L 1 0 0 1 229 10 # Energy of fusion (W/m2) +Qv: 0 W/m2 S2V 1 0 0 1 198 10 # Energy of sublimation (W/m2) +Qa: 0 W/m2 DN 1 0 0 1 136 10 # Advective energy (W/m2) +Qtau: 0 N/m2 DN 1 0 0 1 172 10 # Momentum flux (N/m2) +DelSurfHeat: 0 J/m2 INC 1 0 0 1 137 10 # Change in surface heat storage (J/m2) +DelColdCont: 0 J/m2 INC 1 0 0 1 138 10 # Change in snow cold content (J/m2) +BR: 0 - - 1 0 1 1 256 10 # Bowen ratio (-) +EF: 0 - - 1 0 1 1 256 10 # Evaporative fraction (-) +Rnet: 0 W/m2 DN 1 0 1 1 256 10 # Total net radiation (W/m2) + +#Water balance components +Snowf: 0 kg/m2s DN 1 0 0 1 161 10000 # Snowfall rate (kg/m2s) +Rainf: 0 kg/m2s DN 1 0 0 1 162 10000 # Rainfall rate (kg/m2s) +RainfConv: 0 kg/m2s DN 1 0 0 1 63 10000 # Convective rainfall rate (kg/m2s) +TotalPrecip: 1 kg/m2s DN 1 0 0 1 61 10000 # Total precipitation rate (kg/m2s) +Evap: 1 kg/m2s UP 1 0 0 1 57 10000 # Total evapotranspiration (kg/m2s) +Qs: 1 kg/m2s OUT 1 0 0 1 235 10000 # Surface runoff (kg/m2s) +Qrec: 0 kg/m2s IN 1 0 0 1 163 10000 # Recharge (kg/m2s) +Qsb: 1 kg/m2s OUT 1 0 0 1 234 10000 # Subsurface runoff (kg/m2s) +Qsm: 0 kg/m2s S2L 1 0 0 1 99 10000 # Snowmelt (kg/m2s) +Qfz: 0 kg/m2s L2S 1 0 0 1 130 10000 # Refreezing of water in the snowpack (kg/m2s) +Qst: 0 kg/m2s - 1 0 0 1 131 10000 # Snow throughfall (kg/m2s) +DelSoilMoist: 0 kg/m2 INC 1 0 0 1 132 10000 # Change in soil moisture (kg/m2) +DelSWE: 0 kg/m2 INC 1 0 0 1 133 1000 # Change in snow water equivalent (kg/m2) +DelSurfStor: 0 kg/m2 INC 1 0 0 1 134 1000 # Change in surface water storage (kg/m2) +DelIntercept: 0 kg/m2 INC 1 0 0 1 135 1000 # Change in interception storage (kg/m2) +RHMin: 0 - - 1 0 0 1 52 10 # Minimum 2-meter relative humidity (-) +Ch: 0 - - 1 0 0 1 208 10 # Surface exchange coefficient for heat +Cm: 0 - - 1 0 0 1 252 10 # Surface exchange coefficient for momentum + +#Surface state variables +SnowT: 0 K - 1 0 0 1 165 10 # Snow surface temperature (K) +VegT: 0 K - 1 0 0 1 146 10 # Vegetation canopy temperature (K) +BareSoilT: 0 K - 1 0 0 1 147 10 # Temperature of bare soil (K) +AvgSurfT: 0 K - 1 0 0 1 148 10 # Average surface temperature (K) +RadT: 0 K - 1 0 0 1 149 10 # Surface radiative temperature (K) +Albedo: 0 - - 1 0 0 1 84 100 # Surface albedo (-) +SWE: 1 kg/m2 - 1 0 0 1 65 1000 # Snow Water Equivalent (kg/m2) +SWEVeg: 0 kg/m2 - 1 0 0 1 139 1000 # SWE intercepted by vegetation (kg/m2) +SurfStor: 0 kg/m2 - 1 0 0 1 150 1000 # Surface water storage (kg/m2) + +#Subsurface state variables +SoilMoist: 1 m3/m3 - 2 0 0 4 86 1000 # Average layer soil moisture (kg/m2) +SoilTemp: 0 K - 1 0 0 4 85 1000 # Average layer soil temperature (K) +SmLiqFrac: 0 - - 1 0 0 4 160 100 # Average layer fraction of liquid moisture (-) +SmFrozFrac: 0 - - 1 0 0 4 140 100 # Average layer fraction of frozen moisture (-) +SoilWet: 0 - - 1 0 0 1 144 100 # Total soil wetness (-) +RelSMC: 0 m3/m3 - 1 0 0 4 141 1000 # Relative soil moisture (-) +RootTemp: 0 K - 1 0 0 1 142 1000 # Root zone temperature (K) + +#Evaporation components +PotEvap: 0 kg/m2s UP 1 0 0 1 145 1 # Potential evapotranspiration (kg/m2s) +ECanop: 0 kg/m2s UP 1 0 0 1 200 1 # Interception evaporation (kg/m2s) +TVeg: 0 kg/m2s UP 1 0 0 1 210 1 # Vegetation transpiration (kg/m2s) +ESoil: 0 kg/m2s UP 1 0 0 1 199 1 # Bare soil evaporation (kg/m2s) +EWater: 0 kg/m2s UP 1 0 0 1 197 1 # Open water evaporation (kg/m2s) +RootMoist: 0 kg/m2 - 2 0 0 1 171 1 # Root zone soil moisture (kg/m2) +CanopInt: 0 kg/m2 - 1 0 0 1 223 1000 # Total canopy water storage (kg/m2) +EvapSnow: 0 kg/m2s - 1 0 0 1 173 1000 # Snow evaporation (kg/m2s) +SubSnow: 0 kg/m2s - 1 0 0 1 198 1000 # Snow sublimation (kg/m2s) +SubSurf: 0 kg/m2s - 1 0 0 1 143 1000 # Sublimation of the snow free area (kg/m2s) +ACond: 0 m/s - 1 0 0 1 179 100000 # Aerodynamic conductance (m/s) +CCond: 0 m/s - 1 0 0 1 181 100000 # Canopy conductance (m/s) +SoilET: 0 kg/m2 - 1 0 0 1 256 1 # Soil evaporation (kg/m2s) +AResist: 0 s/m - 1 0 0 1 256 1 # Aerodynamic resistance (s/m) + +#Other hydrologic variables +WaterTableD: 0 m - 1 0 0 1 174 1 # Water table depth (m) +TWS: 0 mm - 1 0 0 1 175 1 # Terrestrial Water Storage (mm) +GWS: 0 mm - 1 0 0 1 176 1 # Ground Water Storage (mm) +WT: 0 mm - 1 0 0 1 177 1 # Noah-MP WT variable (mm) + +#Cold season processes +Snowcover: 0 - - 1 0 0 1 238 100 # Snow cover (-) +SAlbedo: 0 - - 0 0 0 1 184 1000 # Albedo of the snow-covered area (-) +SnowTProf: 0 K - 0 0 0 1 239 1000 # Temperature of the snow pack (K) +SnowDepth: 0 m - 1 0 0 1 66 1000 # Snow depth (m) +SLiqFrac: 0 - - 0 0 0 1 185 1000 # Fraction of SWE in the liquid phase (-) + +#Variables to compared against remote sensed data +LWup: 0 W/m2 UP 1 0 0 1 212 1 # Longwave radiation up from the surface (W/m2) + +#Carbon variables +GPP: 0 g/m2s IN 1 0 0 1 256 1 # Gross Primary Production +NPP: 0 g/m2s IN 1 0 0 1 256 1 # Net Primary Production +NEE: 0 g/m2s IN 1 0 0 1 256 1 # Net Ecosystem Exchange +AutoResp: 0 kg/m2s2 UP 1 0 0 1 256 1 # Autotrophic respiration +HeteroResp: 0 kg/m2s2 UP 1 0 0 1 256 1 # Heterotrophic respiration +LeafResp: 0 kg/m2s2 UP 1 0 0 1 256 1 # Leaf respiration +TotSoilCarb: 0 kg/m2 - 1 0 0 1 256 1 # Total soil carbon +TotLivBiom: 0 kg/m2 - 1 0 0 1 256 1 # Total living biomass + +#Forcings +Wind_f: 1 m/s - 1 0 0 1 32 10 # Near surface wind (m/s) +Rainf_f: 1 kg/m2s DN 1 0 0 1 162 1000 # Average rainfall rate +Snowf_f: 0 kg/m2s DN 1 0 0 1 161 1000 # Average snowfall rate +CRainf_f: 0 kg/m2s DN 1 0 0 1 63 1000 # Average convective rainfall rate +Tair_f: 1 K - 1 0 0 1 11 10 # Near surface air temperature +Qair_f: 1 kg/kg - 1 0 0 1 51 1000 # Near surface specific humidity +Psurf_f: 1 Pa - 1 0 0 1 1 10 # Surface pressure +SWdown_f: 1 W/m2 DN 1 0 0 1 204 10 # Surface incident shortwave radiation +LWdown_f: 1 W/m2 DN 1 0 0 1 205 10 # Surface incident longwave radiation +PARDR_f: 0 W/m2 DN 1 0 0 1 256 10 # Surface incident PAR direct +PARDF_f: 0 W/m2 DN 1 0 0 1 256 10 # Surface incident PAR diffuse + +#Additional forcings +DirectSW_f: 0 W/m2 - 1 0 0 1 166 10 # Surface direct incident shortwave radiation +DiffuseSW_f: 0 W/m2 - 1 0 0 1 167 10 # Surface diffuse incident shortwave radiation +NWind_f: 0 m/s N 1 0 0 1 34 10 # Northward wind +EWind_f: 0 m/s E 1 0 0 1 33 10 # Eastward wind +FHeight_f: 0 m - 1 0 0 1 256 10 # Height of forcing variables +Ch_f: 0 - - 1 0 0 1 208 10 # Surface exchange coefficient for heat +Cm_f: 0 - - 1 0 0 1 252 10 # Surface exchange coefficient for momentum +Emiss_f: 0 - - 1 0 0 1 256 10 # Surface emissivity +MixRatio_f: 0 kg/kg - 1 0 0 1 53 10 # Surface mixing ratio +CosZenith_f: 0 - - 1 0 0 1 256 10 # Cosine of zenith angle +Albedo_f: 0 - - 1 0 0 1 84 10 # Surface albedo +CAPE_f: 0 J/kg - 1 0 0 1 157 10 # Convective Available Potential Energy +Z0brd: 0 m - 1 0 0 1 256 1 # Z0brd +T2diag: 0 K - 1 0 0 1 256 1 # Diagnostic t2 +Q2diag: 0 kg/kg - 1 0 0 1 256 1 # Diagnostic q2 +Snowflag_f: 0 - - 1 0 0 1 256 1 # Snowflag +Density_f: 0 kg/m3 - 1 0 0 1 256 1 # Atmospheric density +VaporPress_f: 0 - - 1 0 0 1 256 1 # Vapor pressure +VaporPressDeficit_f: 0 - - 1 0 0 1 256 1 # Vapor pressure deficit + +#Parameters +Landmask: 0 - - 0 0 0 1 81 1 # Land mask (0 - Water, 1 - Land) +Landcover: 0 - - 0 0 0 1 225 1 # Land cover +Soiltype: 0 - - 0 0 0 1 224 1 # Soil type +SandFrac: 0 - - 0 0 0 1 256 1 # Sand fraction +ClayFrac: 0 - - 0 0 0 1 256 1 # Clay fraction +SiltFrac: 0 - - 0 0 0 1 256 1 # Silt fraction +Porosity: 0 - - 0 0 0 1 240 1 # Porosity +Soilcolor: 0 - - 0 0 0 1 256 1 # Soil color +Elevation: 0 m - 0 0 0 1 196 10 # Elevation +Slope: 0 - - 0 0 0 1 222 10 # Slope +LAI: 0 - - 1 0 0 1 182 100 # LAI +SAI: 0 - - 1 0 0 1 256 100 # SAI +Snfralbedo: 0 - - 0 0 0 1 184 100 # Snow fraction albedo +Mxsnalbedo: 0 - - 0 0 0 1 159 100 # Maximum snow albedo +Greenness: 0 - - 1 0 0 1 87 100 # Greenness +Roughness: 0 m - 0 0 0 1 83 10 # Roughness +Tempbot: 0 K - 0 0 0 1 256 10 # Bottom soil temperature + +#Routing +Streamflow: 1 m3/s - 1 0 0 1 256 10 # Streamflow +RiverStor: 0 m3 - 1 0 0 1 256 10 # River storage +RiverDepth: 0 m - 1 0 0 1 256 10 # River depth +RiverVelocity: 0 m/s - 1 0 0 1 256 10 # River velocity +FloodQ: 0 m3/s - 1 0 0 1 256 10 # Flood discharge +FloodEvap: 0 m3 - 1 0 0 1 256 10 # Flood evaporation +FloodStor: 0 m3 - 1 0 0 1 256 10 # Flood storage +FloodDepth: 0 m - 1 0 0 1 256 10 # Flood depth +FloodVelocity: 0 m/s - 1 0 0 1 256 10 # Flood velocity +FloodedFrac: 0 - - 1 0 0 1 256 10 # Flooded fraction +FloodedArea: 0 m2 - 1 0 0 1 256 10 # Flooded area +SurfElev: 0 m - 1 0 0 1 256 10 # Surface elevation +RunoffStor: 0 m3 - 1 0 0 1 256 10 # Runoff storage +BaseflowStor: 0 m3 - 1 0 0 1 256 10 # Baseflow storage + +#Irrigation +Irrigated water: 1 kg/m2s - 1 0 0 1 256 10 # Irrigation amount + +#NoahMP +SnowIce: 0 mm - 1 0 0 3 85 1000 # snow ice contents in layers +SnowLiq: 0 mm - 1 0 0 3 85 1000 # snow water contents in layers +VegCanopT: 0 K - 1 0 0 1 146 10 # Vegetation canopy temperature (K) +CanopVP: 0 Pa - 1 0 0 1 146 10 # Canopy air vapor pressure +CanopWetFrac: 0 - - 1 0 0 1 146 10 # Canopy wet fraction +CanopIntLiq: 0 mm - 1 0 0 1 146 10 # Canopy intercepted liquid water +SnowAge: 0 - - 1 0 0 1 146 10 # snow age factor +AvgGrndT: 0 K - 1 0 0 1 148 10 # Average surface temperature (K) +ActSnowNL: 0 - - 1 0 0 1 148 10 # actual number of snow layers +LeafMass: 0 g/m2 - 1 0 0 1 148 10 # leaf mass +RootMass: 0 g/m2 - 1 0 0 1 148 10 # stem mass +StemMass: 0 g/m2 - 1 0 0 1 148 10 # wood mass +WoodMass: 0 g/m2 - 1 0 0 1 148 10 # mass of wood including woody roots [g/m2] +DeepSoilCarbon: 0 g/m2 - 1 0 0 1 148 10 # stable carbon in deep soil [g/m2] +ShallowSoilCarbon: 0 g/m2 - 1 0 0 1 148 10 # short-lived carbon in shallow soil [g/m2] +RechToGW: 0 m - 1 0 0 1 148 10 # recharge to water table when groundwater is deep +RechFromGW: 0 m - 1 0 0 1 148 10 # recharge from water table when groundwater shallow +SwReflect: 0 W/m2 UP 1 0 0 1 111 10 # Net shortwave radiation (W/m2) +VegT2m: 0 K - 1 0 0 1 146 10 # Vegetation temperature at 2m height (K) +QairT2m: 0 kg/kg - 1 0 0 1 51 1000 # 2-m over vegetation specific humidity +APAR: 0 W/m2 IN 1 0 0 1 111 10 # absorbed PAR energy by canopy (W/m2) +SAV: 0 W/m2 IN 1 0 0 1 111 10 # solar radiation absorbed by vegetation (W/m2) +SAG: 0 W/m2 IN 1 0 0 1 111 10 # solar radiation absorbed by ground (W/m2) +PSCO2: 0 umol/m2s IN 1 0 0 1 111 10 # total photosynthesis of CO2 (umol/m2s) +RsSunlit: 0 s/m - 0 0 0 1 238 100 # sunlit stomatal resistance +RsShaded: 0 s/m - 0 0 0 1 238 100 # shaded stomatal resistance +BCanoGapFrac: 0 - - 0 0 0 1 238 100 # between-canopy gap fraction for beam +WCanoGapFrac: 0 - - 0 0 0 1 238 100 # within-canopy gap fraction for beam +ChVeg: 0 s/m - 1 0 0 1 208 10 # Surface heat exchange coeff. over vegetated fraction +ChBare: 0 s/m - 1 0 0 1 208 10 # Surface heat exchange coeff. over bare soil fraction +QhCano: 0 W/m2 UP 1 0 0 1 122 10 # canopy sensible heat flux (W/m2) +QhBare: 0 W/m2 UP 1 0 0 1 122 10 # bare soil sensible heat flux (W/m2) +EvapHBare: 0 W/m2 UP 1 0 0 1 122 10 # bare soil evaporation heat (W/m2) +EvapHGrnd: 0 W/m2 UP 1 0 0 1 122 10 # ground evaporation heat (W/m2) +GrndHBare: 0 W/m2 UP 1 0 0 1 122 10 # bare ground heat flux (W/m2) +GrndHVeg: 0 W/m2 UP 1 0 0 1 122 10 # vegetated ground heat flux (W/m2) +ChLeaf: 0 s/m - 1 0 0 1 208 10 # Surface exchange coefficient for heat over leaf +ChV2: 0 s/m - 1 0 0 1 208 10 # sensible heat exchange coef. over vegetated fraction +ChB2: 0 s/m - 1 0 0 1 208 10 # sensible heat exchange coeff. over bare ground +fpice: 0 - - 1 0 0 1 208 10 # snow fraction in precipitation + diff --git a/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/README b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/README new file mode 100644 index 000000000..304b65a33 --- /dev/null +++ b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/README @@ -0,0 +1,25 @@ +Noah-MP.4.0.1 SMAP Assimilation with Relocated CDF + +This case demonstrates EnKF-based assimilation of NASA SMAP data into +Noah-MP.4.0.1 LSM using relocated CDFs + +It uses: +* MERRA2 +* Retrospective run mode +* Noah-MP.4.0.1 LSM +* Regional domain over Europe +* Time period from 1 June 2020 to 1 Jan 2022. + +This directory contains: +* This README file +* The lis.config file used for this test case +* The NOAHMP36_OUTPUT_LIST.TBL.dyn.full file used by lis.config to select + the output variables. + +Note that lis.config should be edited to make sure the locations of the +parameter and forcing files are specified correctly. + +To run this testcase: +* Compile LIS +* Run the LIS executable using the lis.config file and the testcase input + data. diff --git a/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/lis.config b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/lis.config new file mode 100755 index 000000000..ea1a74cb1 --- /dev/null +++ b/lis/testcases/dataassim/SMAP_sm_pclimo_transfer/lis.config @@ -0,0 +1,260 @@ +#Overall driver options +Running mode: retrospective +Map projection of the LIS domain: "lambert" # latlon # MN: why latlon should be lambert +Number of nests: 1 +Number of surface model types: 1 +Surface model types: LSM +Surface model output interval: 6hr +Land surface model: "Noah-MP.4.0.1" +Number of met forcing sources: 1 +Blending method for forcings: overlay +Met forcing sources: "MERRA2" # "COAMPSout" +Met forcing chosen ensemble member: 1 +Topographic correction method (met forcing): "none" +Enable spatial downscaling of precipitation: 0 +Spatial upscaling method (met forcing): average +Spatial interpolation method (met forcing): bilinear +Temporal interpolation method (met forcing): linear + +#Runtime options +Forcing variables list file: ./forcing_variables.txt +Output methodology: "2d gridspace" +Output model restart files: 1 +Output data format: netcdf +Output naming style: "3 level hierarchy" +Start mode: restart #coldstart +Starting year: 2020 #2015 ##2000 +Starting month: 05 #03 ##01 +Starting day: 31 #01 ##01 +Starting hour: 23 #0 +Starting minute: 45 #0 +Starting second: 0 +Ending year: 2022 #2015 +Ending month: 01 #03 +Ending day: 01 #01 +Ending hour: 0 +Ending minute: 0 +Ending second: 0 +Undefined value: -9999 +Output directory: "output.da.cdf.transfer.diff.forcing" +Diagnostic output file: "output.da.cdf.transfer.diff.forcing/logs/lislog" +Number of ensembles per tile: 12 + +#The following options are used for subgrid tiling based on vegetation +Maximum number of surface type tiles per grid: 1 +Minimum cutoff percentage (surface type tiles): 0.05 +Maximum number of soil texture tiles per grid: 1 +Minimum cutoff percentage (soil texture tiles): 0.05 +Maximum number of soil fraction tiles per grid: 1 +Minimum cutoff percentage (soil fraction tiles): 0.05 +Maximum number of elevation bands per grid: 1 +Minimum cutoff percentage (elevation bands): 0.05 +Maximum number of slope bands per grid: 1 +Minimum cutoff percentage (slope bands): 0.05 +Maximum number of aspect bands per grid: 1 +Minimum cutoff percentage (aspect bands): 0.05 + +#Processor layout +#Should match the total number of processors used +Number of processors along x: 256 #28 # 16 +Number of processors along y: 1 #16 +Halo size along x: 0 +Halo size along y: 0 + +#Sub-models +Routing model: "none" +Radiative transfer model: none +Number of application models: 0 + +#HYMAP router +HYMAP routing model time step: 15mn +HYMAP routing model output interval: 1da +HYMAP routing model restart interval: 1mo +HYMAP run in ensemble mode: 0 +# method: enter 1 - kinematic; 2 - diffusive +# linear reservoir flag: enter 1 - use; or 2 - do not use linear reservoirs +# evaporation option: enter 1 - compute; or 2 - do not compute evapotation in floodplains +HYMAP routing method: kinematic +HYMAP routing model linear reservoir flag: 1 +HYMAP routing model evaporation option: 2 +HYMAP routing model restart file: LIS_RST_HYMAP_router_201701312345.d01.bin +HYMAP routing model start mode: restart +HYMAP routing LIS output directory: HYMAPTEST + +#---------------------DATA ASSIMILATION ---------------------------------- +#Data Assimilation Options +Number of data assimilation instances: 1 + +Data assimilation algorithm: "EnKF" +Data assimilation set: "SMAP(NASA) soil moisture with CDF Transfer" # "SMAP(NASA) soil moisture" +Number of state variables: 4 +Data assimilation use a trained forward model: 0 +Data assimilation trained forward model output file: none +Data assimilation exclude analysis increments: 0 +Data assimilation output interval for diagnostics: "1da" +Data assimilation number of observation types: 1 +Data assimilation output ensemble spread: 1 +Data assimilation output processed observations: 1 +Data assimilation output innovations: 1 + +Data assimilation scaling strategy: "CDF matching" +Data assimilation observation domain file: ../procLSM_test2/lis_input.noahmp401.EU.nc + +Bias estimation algorithm: "none" +Bias estimation attributes file: "none" +Bias estimation restart output frequency: +Bias estimation start mode: +Bias estimation restart file: + +#Perturbation options +Perturbations start mode: "restart" #"coldstart" +Perturbations restart output interval: "1mo" +#Perturbations restart filename: output.da.cdf.transfer.diff.forcing/DAPERT/202005/LIS_DAPERT_202005312345.d01.bin # "none" +Perturbations restart filename: rst/LIS_DAPERT_202005312345.d01.bin # "none" + +Apply perturbation bias correction: 1 + +Forcing perturbation algorithm: "GMAO scheme" +Forcing perturbation frequency: "1hr" +Forcing attributes file: ../../attribs/forcing_attribs.txt +Forcing perturbation attributes file: ../../attribs/forcing_pertattribs.txt + +State perturbation algorithm: "GMAO scheme" +State perturbation frequency: "6hr" +State attributes file: ../../attribs/noah_sm_attribs.txt +State perturbation attributes file: ../../attribs/noah_sm_pertattribs.txt + +Observation perturbation algorithm: "GMAO scheme" +Observation perturbation frequency: "6hr" +Observation attributes file: ../../attribs/smap_attribs.txt +Observation perturbation attributes file: ../../attribs/smap_pertattribs.txt + +# SMAP DATA ENTRIES: +SMAP(NASA) soil moisture data designation: SPL3SMP +SMAP(NASA) soil moisture data directory: ../input/RS_DATA/SMAP/SPL3SMP.007 +SMAP(NASA) soil moisture use scaled standard deviation model: 0 +SMAP(NASA) soil moisture apply SMAP QC flags: 1 +SMAP(NASA) model CDF file: # ../DA_proc_LSM/OUTPUT.strat.p.climo.15bins/cdf_noahmp401.nc # ../DA_proc_LSM/OUTPUT/cdf_noahmp401.nc +SMAP(NASA) observation CDF file: # ../DA_proc_SMAP/OUTPUT.strat.p.climo.15bins/cdf_smapobs.nc #../DA_proc_SMAP/OUTPUT/cdf_smapobs.nc +SMAP(NASA) soil moisture number of bins in the CDF: 100 +SMAP(NASA) soil moisture use scaled standard deviation model: 0 +SMAP(NASA) CDF read option: 0 +SMAP(NASA) soil moisture Composite Release ID: "R17" + + +#----------------------- Soil moisture CDF transfer ------------- +Use CDF transfer for soil moisture data assimilation: 1 # defualt =0 +Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc # ref_model_cdf/stratified_cdf_noahmp401.nc +Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc # ref_obs_cdf/stratified_cdf_smapobs.nc +#Number of bins in the soil moisture CDF: 100 +Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc #Precip.climo.us.merra/LVT_MEAN_FINAL.202201010000.d01.nc +Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc +#---------------------------------------------------------------- + +GLASS LAI data directory: ../GLASSLAIdata + +Irrigation scheme: "none" +Irrigation output interval: "1da" +Irrigation threshold: 0.5 +Irrigation GVF parameter 1: 0.0 +Irrigation GVF parameter 2: 0.4 + +# UMD-landcover and "CROPMAP" crop types (Leff et al. 2004): +Sprinkler irrigation max root depth file: ../input/LS_PARAMETERS/irrigation/conus_modis/maxrootdepth32.txt +#------------------------DOMAIN SPECIFICATION-------------------------- + +#The following options list the choice of parameter maps to be used +LIS domain and parameter data file: ../procLSM_test2/lis_input.noahmp401.EU.nc +Landmask data source: LDT +Landcover data source: LDT +Soil texture data source: LDT +Soil fraction data source: none +Soil color data source: none +Elevation data source: LDT +Slope data source: LDT +Aspect data source: LDT +Curvature data source: none +LAI data source: none +SAI data source: none +Albedo data source: LDT +Max snow albedo data source: LDT +Greenness data source: LDT +Roughness data source: none +Porosity data source: none +Ksat data source: none +B parameter data source: none +Quartz data source: none +Emissivity data source: none + +#--------------------------------FORCINGS---------------------------------- + +MERRA2 forcing directory: ../input/MET_FORCING/MERRA2 +MERRA2 use lowest model level forcing: 1 +MERRA2 use 2m wind fields: 0 +MERRA2 use corrected total precipitation: 1 + +IMERG forcing directory: ../input/MET_FORCING/IMERG +IMERG product: 'final' +IMERG version: V06B + +COAMPS output forcing directory: ../../COAMPS/EU/COAMPS_forcing # ../../COAMPS/COAMPS_forcing # input/MET_FORCING/COAMPS_OUT/bak +COAMPS nest id: 1 # 1 # 1: 45 km ; 2: 15km + +#-----------------------LAND SURFACE MODELS-------------------------- + + +Noah-MP.4.0.1 model timestep: 15mn +Noah-MP.4.0.1 restart output interval: 1mo +#Noah-MP.4.0.1 restart file: output.da.cdf.transfer.diff.forcing/SURFACEMODEL/202005/LIS_RST_NOAHMP401_202005312345.d01.nc +Noah-MP.4.0.1 restart file: rst/LIS_RST_NOAHMP401_202005312345.d01.nc + +#Noah-MP.4.0.1 restart file: ../DA_ensrst/LIS_EnRST_NOAH36_201502282345.d01.nc +Noah-MP.4.0.1 restart file format: netcdf +Noah-MP.4.0.1 soil parameter table: ../input/LS_PARAMETERS/noahmp401_parms/SOILPARM.TBL +Noah-MP.4.0.1 general parameter table: ../input/LS_PARAMETERS/noahmp401_parms/GENPARM.TBL +Noah-MP.4.0.1 MP parameter table: ../input/LS_PARAMETERS/noahmp401_parms/MPTABLE.TBL +Noah-MP.4.0.1 number of soil layers: 4 +Noah-MP.4.0.1 thickness of soil layers: 0.1 0.3 0.6 1.0 +Noah-MP.4.0.1 dynamic vegetation option: 4 # Up to 10 different options +Noah-MP.4.0.1 canopy stomatal resistance option: 1 # 1=Ball-Berry; 2=Jarvis +Noah-MP.4.0.1 soil moisture factor for stomatal resistance: 1 # 1=Noah; 2=CLM; 3=SSiB +Noah-MP.4.0.1 runoff and groundwater option: 1 # 1=SIMGM; 2=SIMTOP; 3=Schaake96; 4=BATS; 5=Miguez-Macho&Fan +Noah-MP.4.0.1 surface layer drag coefficient option: 1 # 1=M-O; 2=Chen97 +Noah-MP.4.0.1 supercooled liquid water option: 1 # 1=NY06; 2=Koren99 +Noah-MP.4.0.1 frozen soil permeability option: 1 # 1=NY06; 2=Koren99 +Noah-MP.4.0.1 radiation transfer option: 3 # 1=gap=F(3D;cosz); 2=gap=0; 3=gap=1-Fveg +Noah-MP.4.0.1 snow surface albedo option: 2 # 1=BATS; 2=CLASS +Noah-MP.4.0.1 rainfall & snowfall option: 1 # 1=Jordan91; 2=BATS; 3=Noah +Noah-MP.4.0.1 lower boundary of soil temperature option: 2 # 1=zero-flux; 2=Noah +Noah-MP.4.0.1 snow&soil temperature time scheme option: 1 # 1=semi-implicit; 2=fully implicit; 3=FSNO for TS +Noah-MP.4.0.1 glacier option: 1 # 1=include phase change; 2=slab ice (Noah) +Noah-MP.4.0.1 surface resistance option: 1 # 1=Sakaguchi and Zeng 2009; 2=Sellers (1992); 3=adjusted Sellers; 4=option1 for non-snow and rsurf_snow for snow +Noah-MP.4.0.1 soil configuration option: 1 # 1=input dominant soil texture; 2=input soil texture varies that varies with depth; 3=soil composition and pedotransfer; 4=input soil properties +Noah-MP.4.0.1 soil pedotransfer function option: 1 # 1=Saxton and Rawls (2006) (used when soil_opt=3) +Noah-MP.4.0.1 crop model option: 0 # 0=No crop model; 1=Liu et al. 2016; 2=Gecros +Noah-MP.4.0.1 urban physics option: 0 # 0=No; 1=Single-layer; 2=Multi-layer BEP scheme; 3=Multi-layer BEM scheme +Noah-MP.4.0.1 reference height of temperature and humidity: 10.0 +Noah-MP.4.0.1 initial surface skin temperature: 288.0 +Noah-MP.4.0.1 initial snow water equivalent: 0.0 +Noah-MP.4.0.1 initial snow depth: 0.0 +Noah-MP.4.0.1 initial total canopy surface water: 0.0 +Noah-MP.4.0.1 initial soil temperatures: 288.0 288.0 288.0 288.0 +Noah-MP.4.0.1 initial total soil moistures: 0.20 0.20 0.20 0.20 +Noah-MP.4.0.1 initial leaf area index: 0.5 +Noah-MP.4.0.1 initial water table depth: 2.5 +Noah-MP.4.0.1 initial water in the aquifer: 4900.0 +Noah-MP.4.0.1 initial water in aquifer and saturated soil: 4900.0 + + +#---------------------------MODEL OUTPUT CONFIGURATION----------------------- +#Specify the list of ALMA variables that need to be featured in the +#LSM model output +Output start year: +Output start month: +Output start day: +Output start hour: +Output start minutes: +Output start seconds: + +Model output attributes file: './NOAHMP36_OUTPUT_LIST.TBL.dyn.full' + From 9e98eeea2635b8f3096e8ae3c161d7f335352239 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 23 Oct 2023 12:58:03 -0400 Subject: [PATCH 191/328] Improved error message if invalid LIS_ARCH env variable is set. --- lis/lib/lis-cmem3/Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/lib/lis-cmem3/Makefile b/lis/lib/lis-cmem3/Makefile index e4466d283..756ca37e5 100644 --- a/lis/lib/lis-cmem3/Makefile +++ b/lis/lib/lis-cmem3/Makefile @@ -7,7 +7,7 @@ else ifeq ($(LIS_ARCH),linux_gfortran) FC = gfortran LD = gfortran else -$(error "Please specify the compiler via the LIS_ARCH env variable. See the LISF Installation Guide for more information.") +$(error "Please specify the compiler via the LIS_ARCH env variable. Only linux_ifc and linux_gfortran supported. See the LISF Installation Guide for more information.") endif # compiler/linker flags From df420fd2ee9e5aabdde3f751aa5e278ff4981416 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 23 Oct 2023 13:06:15 -0400 Subject: [PATCH 192/328] Further clean-up of error messages for invalid LIS_ARCH env variable. --- lis/lib/lis-cmem3/Makefile | 2 +- lis/lib/lis-crtm-profile-utility/make.macros | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/lib/lis-cmem3/Makefile b/lis/lib/lis-cmem3/Makefile index 756ca37e5..71a75a7e8 100644 --- a/lis/lib/lis-cmem3/Makefile +++ b/lis/lib/lis-cmem3/Makefile @@ -7,7 +7,7 @@ else ifeq ($(LIS_ARCH),linux_gfortran) FC = gfortran LD = gfortran else -$(error "Please specify the compiler via the LIS_ARCH env variable. Only linux_ifc and linux_gfortran supported. See the LISF Installation Guide for more information.") +$(error "Please specify the compiler via the LIS_ARCH env variable. Only linux_ifc and linux_gfortran are supported. See the LISF Installation Guide for more information.") endif # compiler/linker flags diff --git a/lis/lib/lis-crtm-profile-utility/make.macros b/lis/lib/lis-crtm-profile-utility/make.macros index b35466570..5060b969e 100755 --- a/lis/lib/lis-crtm-profile-utility/make.macros +++ b/lis/lib/lis-crtm-profile-utility/make.macros @@ -519,5 +519,5 @@ LINUX_FLAGS = $(LINUX_FLAGS_INTEL) else ifeq ($(LIS_ARCH),linux_gfortran) LINUX_FLAGS = $(LINUX_FLAGS_GFORTRAN) else -$(error "Please specify the compiler via the LIS_ARCH env variable. See the LISF Installation Guide for more information.") +$(error "Please specify the compiler via the LIS_ARCH env variable. Only linux_ifc and linux_gfortran are supported. See the LISF Installation Guide for more information.") endif From 149157c29a462161d065a1adb9ef537dd9a6f991 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 30 Oct 2023 08:48:21 -0400 Subject: [PATCH 193/328] LIS now uses new gage code. Station and network ID now 32 characters long. NOTE: Have noticed Bratseth temperature analyses now change from run to run. Occurs with both Intel and GNU compilers with debugging flags. Does not appear to happen with support/lisf-557ww-7.5 branch, nor with master branch. Will investigate earlier commits to see if cause can be determined. --- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 1 + lis/metforcing/usaf/AGRMET_getsfc.F90 | 59 +++++---- lis/metforcing/usaf/AGRMET_processobs.F90 | 24 +++- lis/metforcing/usaf/AGRMET_sfcalc.F90 | 2 +- lis/metforcing/usaf/USAF_GagesMod.F90 | 114 +++++++++++++++--- lis/metforcing/usaf/USAF_ImergHHMod.F90 | 4 +- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 65 ++++++---- lis/metforcing/usaf/USAF_bratsethMod.F90 | 59 ++++++--- lis/metforcing/usaf/readagrmetpcpforcing.F90 | 43 ++++--- lis/metforcing/usaf/readcrd_agrmet.F90 | 30 +++++ .../RAPID_router/RAPID_routing_run.F90 | 3 +- 11 files changed, 291 insertions(+), 113 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index 20d0b53b9..ca6213abb 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -352,6 +352,7 @@ module AGRMET_forcingMod real*8 :: agrmetpcptime1, agrmetpcptime2 real*8 :: cmortime integer :: pcpobswch + integer :: pcpobsfmt ! EMK...File format for precip obs integer :: pwswch integer :: raswch integer :: cdfs2swch diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index 641c25506..7db822acb 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -244,7 +244,10 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & integer :: rc real, external :: AGRMET_calcrh_dpt - character(len=10) :: net10, platform10 + !character(len=10) :: net10, platform10 + character(len=32) :: net32, platform32 + character*32, parameter :: blank32 = " " + data norsou / 'NORTHERN', 'SOUTHERN' / ! ------------------------------------------------------------------ @@ -506,45 +509,51 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! EMK...Add to data structures. Handle reformated ! CDMS data that is missing platform and network if (rtmp .gt. 0) then - net10 = trim(netyp(irecord)) - platform10 = trim(platform(irecord)) - if (trim(net10) .eq. 'NULL') then - net10 = 'CDMS' + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' end if - if (trim(platform10) .eq. '-99999999') then - platform10 = '00000000' + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' end if - call USAF_assignObsData(t2mObs,net10, & - platform10,rtmp,rlat,rlon, & + call USAF_assignObsData(t2mObs,net32, & + platform32,rtmp,rlat,rlon, & agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr,& 0.) end if if (rrelh .gt. 0) then - net10 = trim(netyp(irecord)) - platform10 = trim(platform(irecord)) - if (trim(net10) .eq. 'NULL') then - net10 = 'CDMS' + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' end if - if (trim(platform10) .eq. '-99999999') then - platform10 = '00000000' + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' end if - call USAF_assignObsData(rh2mObs,net10, & - platform10,rrelh,rlat,rlon, & + call USAF_assignObsData(rh2mObs,net32, & + platform32,rrelh,rlat,rlon, & agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr, & 0.) end if if (rspd .gt. 0) then - net10 = trim(netyp(irecord)) - platform10 = trim(platform(irecord)) - if (trim(net10) .eq. 'NULL') then - net10 = 'CDMS' + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' end if - if (trim(platform10) .eq. '-99999999') then - platform10 = '00000000' + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' end if - call USAF_assignObsData(spd10mObs,net10, & - platform10,rspd,rlat,rlon, & + call USAF_assignObsData(spd10mObs,net32, & + platform32,rspd,rlat,rlon, & agrmet_struc(n)%bratseth_spd10m_stn_sigma_o_sqr, & 0.) diff --git a/lis/metforcing/usaf/AGRMET_processobs.F90 b/lis/metforcing/usaf/AGRMET_processobs.F90 index 714a65d51..cfc048fad 100644 --- a/lis/metforcing/usaf/AGRMET_processobs.F90 +++ b/lis/metforcing/usaf/AGRMET_processobs.F90 @@ -289,7 +289,9 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & type(rain_obs), allocatable :: obs_cur(:) type(rain_obs), allocatable :: obs_6(:) type(rain_obs), allocatable :: obs_12(:) - + + character*32 :: net32, platform32 + data chemi / '_nh.', '_sh.' / sumsqr(a,b,c,d) = ((a-b)**2) + ((c-d)**2) @@ -1142,8 +1144,10 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & obs_cur(i)%lat, obs_cur(i)%lon,ri,rj) ! EMK...Add observation + net32 = obs_cur(i)%net + platform32 = obs_cur(i)%platform call USAF_assignObsData(precip6, & - obs_cur(i)%net, obs_cur(i)%platform, & + net32, platform32, & float(obs_cur(i)%amt6) * 0.1, & obs_cur(i)%lat, obs_cur(i)%lon,& agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & @@ -1209,8 +1213,10 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & obs_cur(i)%lon,ri,rj) ! EMK...Add observation + net32 = obs_cur(i)%net + platform32 = obs_cur(i)%platform call USAF_assignObsData(precip12, & - obs_cur(i)%net, obs_cur(i)%platform, & + net32, platform32, & float(obs_cur(i)%amt12) * 0.1, & obs_cur(i)%lat, obs_cur(i)%lon, & agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & @@ -1275,8 +1281,10 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & obs_cur(i)%lon,ri,rj) ! EMK...Add observation + net32 = obs_cur(i)%net + platform32 = obs_cur(i)%platform call USAF_assignObsData(precip12, & - obs_cur(i)%net, obs_cur(i)%platform, & + net32, platform32, & 0.0, & obs_cur(i)%lat, obs_cur(i)%lon, & agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & @@ -1326,8 +1334,10 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & ri,rj) ! EMK...Add observation + net32 = obs_cur(i)%net + platform32 = obs_cur(i)%platform call USAF_assignObsData(precip12, & - obs_cur(i)%net, obs_cur(i)%platform, & + net32, platform32, & float(obs_cur(i)%amtmsc) * 0.1, & obs_cur(i)%lat, obs_cur(i)%lon, & agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & @@ -1382,8 +1392,10 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & ri,rj) ! EMK...Add observation + net32 = obs_6(i)%net + platform32 = obs_6(i)%platform call USAF_assignObsData(precip12, & - obs_6(i)%net, obs_6(i)%platform, & + net32, platform32, & float(obs_6(i)%amtmsc) * 0.1, & obs_6(i)%lat, obs_6(i)%lon, & agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & diff --git a/lis/metforcing/usaf/AGRMET_sfcalc.F90 b/lis/metforcing/usaf/AGRMET_sfcalc.F90 index cd45f7a3e..cdc6d54e5 100644 --- a/lis/metforcing/usaf/AGRMET_sfcalc.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcalc.F90 @@ -174,7 +174,7 @@ subroutine AGRMET_sfcalc(n) character(len=10) :: yyyymmddhh integer :: ierr integer :: r,c, L - character(len=10) :: type + character(len=32) :: type integer :: gdeltas, gid, ntiles integer :: count1 logical :: found_inq diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index 4dc340f98..e2825b5d4 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -50,7 +50,7 @@ module USAF_GagesMod character(10) :: date10 integer :: nobs character(14), allocatable :: YYYYMMDDhhmmss(:) - character(10), allocatable :: networks(:) + character(32), allocatable :: networks(:) character(32), allocatable :: platforms(:) character(2), allocatable :: wmocode_id(:) character(2), allocatable :: fipscode_id(:) @@ -84,7 +84,7 @@ module USAF_GagesMod integer, allocatable :: preswx(:) integer, allocatable :: pastwx(:) integer, allocatable :: pastwx_durations(:) - character(10), allocatable :: unique_networks(:) + character(32), allocatable :: unique_networks(:) integer, allocatable :: firsts(:) ! Starting indices for each network integer, allocatable :: lasts(:) ! Ending indices for each network integer :: num_unique_networks @@ -110,6 +110,7 @@ module USAF_GagesMod procedure :: fill_gaps => USAF_gages_fill_gaps procedure :: write_data => USAF_gages_write_data procedure :: set_pastwx_durations => USAF_gages_set_pastwx_durations + procedure :: copy_to_usaf_obsdata => USAF_copy_to_usaf_obsdata end type USAF_Gages_t ! Local parameters @@ -199,7 +200,7 @@ subroutine USAF_gages_new(this, date10, & character(10), intent(in) :: date10 integer, intent(in) :: nobs character(14), intent(in) :: YYYYMMDDhhmmss(nobs) - character(10), intent(in) :: networks(nobs) + character(32), intent(in) :: networks(nobs) character(32), intent(in) :: platforms(nobs) character(2), intent(in) :: wmocode_id(nobs) character(2), intent(in) :: fipscode_id(nobs) @@ -548,6 +549,8 @@ end subroutine USAF_gages_use_misc_precip ! Reconciles different accumulations from the same report. subroutine USAF_gages_reconcile_self(this) + use LIS_logMod, only: LIS_logunit + ! Defaults implicit none @@ -634,6 +637,8 @@ end subroutine USAF_gages_reconcile_self ! Fill gaps in precip record if bookend accumulations are identical. subroutine USAF_gages_fill_gaps(this) + use LIS_logmod, only: LIS_logunit + ! Defaults implicit none @@ -1565,6 +1570,8 @@ end subroutine USAF_gages_reconcile_gages21 ! (South America). Based on logic in AGRMET_processobs. subroutine USAF_gages_correct_region3_12Z(this) + use LIS_logmod, only: LIS_logunit + ! Defaults implicit none @@ -1660,6 +1667,9 @@ end subroutine USAF_gages_correct_region3_12Z ! Write gage data to output file. subroutine USAF_gages_write_data(this, filename) + ! Imports + use LIS_logMod, only: LIS_getNextUnitNumber, LIS_releaseUnitNumber, LIS_logunit + ! Defaults implicit none @@ -1671,6 +1681,7 @@ subroutine USAF_gages_write_data(this, filename) integer :: istat integer :: nobs, nobs_good integer :: i + integer :: iunit nobs = this%nobs @@ -1691,9 +1702,11 @@ subroutine USAF_gages_write_data(this, filename) nobs_good = nobs_good + 1 end do - open(11, file=trim(filename), iostat=istat, err=300) - write(11, *, iostat=istat, err=300) nobs_good + iunit = LIS_getNextUnitNumber() + open(iunit, file=trim(filename), iostat=istat, err=300) + write(iunit, *, iostat=istat, err=300) nobs_good do i = 1, nobs + if (this%amts24(i) .eq. MISSING .and. & this%amts21(i) .eq. MISSING .and. & this%amts18(i) .eq. MISSING .and. & @@ -1704,7 +1717,7 @@ subroutine USAF_gages_write_data(this, filename) this%amts03(i) .eq. MISSING .and. & this%amts02(i) .eq. MISSING .and. & this%amts01(i) .eq. MISSING) cycle - write(11, 6000, iostat=istat, err=300) & + write(iunit, 6000, iostat=istat, err=300) & this%YYYYMMDDhhmmss(i), & this%networks(i), this%platforms(i), & this%wmocode_id(i), this%fipscode_id(i), & @@ -1717,7 +1730,7 @@ subroutine USAF_gages_write_data(this, filename) this%amts00(i), this%durations(i), & this%preswx(i), this%pastwx(i) 6000 format (a14, 1x, & - a10, 1x, a32, 1x, & + a32, 1x, a32, 1x, & a2, 1x, a2, 1x, & i6, 1x, i6, 1x, & i9, 1x, i9, 1x, & @@ -1727,16 +1740,21 @@ subroutine USAF_gages_write_data(this, filename) i9, 1x, i9, 1x, & i9, 1x, i9, 1x & i9, 1x, i9) + end do 300 continue - close(11) + close(iunit) + call LIS_releaseUnitNumber(iunit) end subroutine USAF_gages_write_data ! Read gage data from file. Acts as an alternative constructor. subroutine USAF_gages_read_data(this, filename, date10) + ! Imports + use LIS_logMod, only: LIS_getNextUnitNumber, LIS_releaseUnitNumber + ! Defaults implicit none @@ -1748,7 +1766,7 @@ subroutine USAF_gages_read_data(this, filename, date10) ! Locals integer :: nobs character(14), allocatable :: YYYYMMDDhhmmss(:) - character(10), allocatable :: networks(:) + character(32), allocatable :: networks(:) character(32), allocatable :: platforms(:) character(2), allocatable :: wmocode_id(:) character(2), allocatable :: fipscode_id(:) @@ -1773,17 +1791,21 @@ subroutine USAF_gages_read_data(this, filename, date10) integer :: istat logical :: found integer :: i + integer :: iunit call this%delete() ! Make sure structure is empty inquire(file=trim(filename), exist=found) if (.not. found) return - open(11, file=trim(filename), iostat=istat, err=300) - read(11, *, iostat=istat, err=300, end=300) nobs + iunit = LIS_getNextUnitNumber() + + open(iunit, file=trim(filename), iostat=istat, err=300) + read(iunit, *, iostat=istat, err=300, end=300) nobs if (nobs .le. 0) then - close(11) + close(iunit) + call LIS_releaseUnitNumber(iunit) return end if @@ -1812,7 +1834,7 @@ subroutine USAF_gages_read_data(this, filename, date10) allocate(pastwx(nobs)) do i = 1, nobs - read(11, 6000, iostat=istat, err=300, end=300) & + read(iunit, 6000, iostat=istat, err=300, end=300) & YYYYMMDDhhmmss(i), & networks(i), platforms(i), & wmocode_id(i), fipscode_id(i), & @@ -1825,7 +1847,7 @@ subroutine USAF_gages_read_data(this, filename, date10) amts00(i), durations(i), & preswx(i), pastwx(i) 6000 format (a14, 1x, & - a10, 1x, a32, 1x, & + a32, 1x, a32, 1x, & a2, 1x, a2, 1x, & i6, 1x, i6, 1x, & i9, 1x, i9, 1x, & @@ -1837,8 +1859,9 @@ subroutine USAF_gages_read_data(this, filename, date10) i9, 1x, i9) end do - close(11) - 300 continue + close(iunit) + call LIS_releaseUnitNumber(iunit) +300 continue ! If read was successful, copy to USAF_gages_t structure. if (istat .eq. 0) then @@ -2081,7 +2104,7 @@ subroutine set_unique_networks(this) class(USAF_gages_t), intent(inout) :: this ! Locals - character(10) :: prior_net + character(32) :: prior_net integer :: net_count integer :: nobs integer :: i @@ -2143,7 +2166,7 @@ function search_pcpobs(this, network, plat_id, & ! Arguments class(USAF_gages_t), intent(in) :: this - character(10), intent(in) :: network + character(32), intent(in) :: network character(32), intent(in) :: plat_id character(2), intent(in) :: wmocode_id character(2), intent(in) :: fipscode_id @@ -2480,4 +2503,59 @@ function set_india_precip_threshold(utc_hour) result (threshold) end function set_india_precip_threshold + ! Method for copying appropriate data to a USAF_ObsData structure + ! for use in data assimilation. + subroutine USAF_copy_to_usaf_obsdata(this, hr, gage_sigma_o_sqr, & + precipObs) + + ! Imports + use LIS_logMod, only: LIS_logunit, LIS_endrun + use USAF_bratsethMod, only: USAF_ObsData, USAF_assignObsData + + ! Defaults + implicit none + + ! Arguments + class(USAF_Gages_t), intent(in) :: this + integer, intent(in) :: hr + real, intent(in) :: gage_sigma_o_sqr + type(USAF_ObsData), intent(inout) :: precipObs + + ! Locals + integer :: i + + ! Sanity checks + if (this%nobs == 0) return + if (hr .ne. 6 .and. hr .ne. 12) then + write(LIS_logunit,*) & + '[ERR] Invalid hour passed to USAF_copy_to_usaf_obsdata' + write(LIS_logunit,*) & + '[ERR] Should be 6 or 12, received ', hr + call LIS_endrun() + end if + + if (hr == 6) then + do i = 1, this%nobs + if (this%amts06(i) < 0) cycle + call USAF_assignObsData(precipObs, & + this%networks(i), & + this%platforms(i), & + real(this%amts06(i)) * 0.1, & + real(this%lats(i)) * 0.01, & + real(this%lons(i)) * 0.01, & + gage_sigma_o_sqr, 0.) + end do + else if (hr == 12) then + do i = 1, this%nobs + if (this%amts12(i) < 0) cycle + call USAF_assignObsData(precipObs, & + this%networks(i), & + this%platforms(i), & + real(this%amts12(i)) * 0.1, & + real(this%lats(i)) * 0.01, & + real(this%lons(i)) * 0.01, & + gage_sigma_o_sqr, 0.) + end do + end if + end subroutine USAF_copy_to_usaf_obsdata end module USAF_GagesMod diff --git a/lis/metforcing/usaf/USAF_ImergHHMod.F90 b/lis/metforcing/usaf/USAF_ImergHHMod.F90 index 5a50ca7a4..b5eba8a71 100644 --- a/lis/metforcing/usaf/USAF_ImergHHMod.F90 +++ b/lis/metforcing/usaf/USAF_ImergHHMod.F90 @@ -109,8 +109,8 @@ subroutine copyToObsDataImergHHPrecip(this, sigmaOSqr, oErrScaleLength, & type(ImergHHPrecip), intent(in) :: this real, intent(in) :: sigmaOSqr real, intent(in) :: oErrScaleLength - character*10, intent(in) :: net - character*10, intent(in) :: platform + character*32, intent(in) :: net + character*32, intent(in) :: platform type(USAF_ObsData), intent(inout) :: obsData_struc ! Local variables diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index 8e2a04cc9..0ab09134e 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -29,7 +29,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & ! Imports use ESMF + use LIS_coreMod, only: LIS_masterproc use LIS_logMod, only: LIS_logunit + use LIS_mpiMod, only: LIS_mpi_comm use USAF_GagesMod, only: USAF_Gages_t ! Defaults @@ -54,7 +56,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & integer, allocatable :: ilat(:) integer, allocatable :: ilon(:) integer, allocatable :: bsn(:) - character(10), allocatable :: network(:) + character(32), allocatable :: network(:) character(32), allocatable :: plat_id(:) character(2), allocatable :: wmocode_id(:) character(2), allocatable :: fipscode_id(:) @@ -68,7 +70,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & integer :: ilat_tmp integer :: ilon_tmp character(14) :: YYYYMMDDhhmmss_tmp - character(10) :: network_tmp + character(32) :: network_tmp character(32) :: plat_id_tmp character(2) :: wmocode_id_tmp, fipscode_id_tmp integer :: pastwx_tmp @@ -464,6 +466,11 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & end if else ! This isn't the same station, so save it. + !if (trim(network_tmp) == "AMIL" .and. & + ! trim(plat_id_tmp) == "KQTC") then + ! write(LIS_logunit,*)'EMK: KQTC, twfprc = ', twfprc_tmp + !end if + stncnt = stncnt + 1 twfprc(stncnt) = twfprc_tmp duration(stncnt) = duration_tmp @@ -505,7 +512,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & call swap_int(ilat(j), ilat(j+1)) call swap_int(ilon(j), ilon(j+1)) call swap_int(bsn(j), bsn(j+1)) - call swap_char10(network(j), network(j+1)) + call swap_char32(network(j), network(j+1)) call swap_char32(plat_id(j), plat_id(j+1)) call swap_char2(wmocode_id(j), wmocode_id(j+1)) call swap_char2(fipscode_id(j), fipscode_id(j+1)) @@ -534,7 +541,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & call swap_int(ilat(j), ilat(j+1)) call swap_int(ilon(j), ilon(j+1)) call swap_int(bsn(j), bsn(j+1)) - call swap_char10(network(j), network(j+1)) + call swap_char32(network(j), network(j+1)) call swap_char32(plat_id(j), plat_id(j+1)) call swap_char2(wmocode_id(j), wmocode_id(j+1)) call swap_char2(fipscode_id(j), fipscode_id(j+1)) @@ -674,12 +681,19 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & '[INFO] Correcting overnight reporting in South America' call obscur%correct_region3_12z() - ! Write the final presave file - write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & - trim(presavdir), '/presav2.03hr.', & - year, month, day, hour - write(LIS_logunit,*)'[INFO] Writing to ', trim(presav_filename) - call obscur%write_data(presav_filename) + ! Have the master process write the data to file. + if (LIS_masterproc) then + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(presavdir), '/presav2.03hr.', & + year, month, day, hour + write(LIS_logunit,*)'[INFO] Writing to ', trim(presav_filename) + call obscur%write_data(presav_filename) + end if +#if (defined SPMD) + call MPI_Barrier(LIS_mpi_comm, ierr) +#endif + + ! Clean up call obscur%delete() end subroutine USAF_read_preobs @@ -704,31 +718,32 @@ subroutine get_preobs_filename(filename, preobsdir, & integer, intent(in) :: use_expanded_station_ids ! Locals - character(10) :: ftime1, ftime2 + character(8) :: ftime1 + character(10) :: ftime2 character(2), parameter :: FHEMI(2) = (/'nh', 'sh'/) write(ftime2, '(i4.4, i2.2, i2.2, i2.2)') year, month, day, hour if (use_expanded_station_ids == 0) then - if (use_timestamp == 1) then - write(ftime1, '(i4.4, i2.2, i2.2)') & - year, month, day, '/' - filename = ftime1 // '/' // trim(preobsdir) // & - '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 - else + !if (use_timestamp == 1) then + ! write(ftime1, '(i4.4, i2.2, i2.2)') & + ! year, month, day + ! filename = ftime1 // '/' // trim(preobsdir) // & + ! '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 + !else filename = trim(preobsdir) // & '/preobs_' // FHEMI(ihemi) // '.03hr.' // ftime2 - endif + !endif else if (use_expanded_station_ids == 1) then - if (use_timestamp == 1) then - write(ftime1, '(i4.4, i2.2, i2.2)') & - year, month, day - filename = ftime1 // '/' // trim(preobsdir) // & - '/preobs_03hr_' // ftime2 // ".txt" - else + !if (use_timestamp == 1) then + ! write(ftime1, '(i4.4, i2.2, i2.2)') & + ! year, month, day + ! filename = ftime1 // '/' // trim(preobsdir) // & + ! '/preobs_03hr_' // ftime2 // ".txt" + !else filename = trim(preobsdir) // & '/preobs_03hr_' // ftime2 // ".txt" - endif + !endif end if end subroutine get_preobs_filename diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index d3bbd0fae..ef7ecd667 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -96,8 +96,8 @@ module USAF_bratsethMod type USAF_obsData private integer :: nobs - character*10, allocatable :: net(:) - character*10, allocatable :: platform(:) + character*32, allocatable :: net(:) + character*32, allocatable :: platform(:) real, allocatable :: obs(:) ! Observed variable real, allocatable :: lat(:) ! Latitude of observation (deg N) real, allocatable :: lon(:) ! Longitude of observation (deg E) @@ -280,8 +280,8 @@ subroutine USAF_assignObsData(this,net,platform,ob,lat,lon,sigmaOSqr, & ! Arguments type(USAF_ObsData),intent(inout) :: this - character(len=10), intent(in) :: net - character(len=10), intent(in) :: platform + character(len=32), intent(in) :: net + character(len=32), intent(in) :: platform real, intent(in) :: ob real, intent(in) :: lat real, intent(in) :: lon @@ -622,7 +622,8 @@ subroutine USAF_addSSMIObsData(this,imax,jmax,ra_tmp,nest) real, allocatable :: xpts(:), ypts(:), rlat(:), rlon(:) real :: sigmaOSqr, ob, xi1, xj1, oErrScaleLength real :: xpnmcaf, ypnmcaf, orient, xmesh, xmeshl - character(len=10) :: net, platform + character(len=32) :: net + character(len=32) :: platform integer :: icount integer :: i,j integer :: count_good_ssmi @@ -1128,7 +1129,8 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& real, allocatable :: xpts(:), ypts(:), rlat(:), rlon(:) real :: sigmaOSqr, ob, xi1, xj1, oErrScaleLength real :: xpnmcaf, ypnmcaf, orient, xmesh, xmeshl - character(len=10) :: net, platform + character(len=32) :: net + character(len=32) :: platform integer :: count_good_geo_precip, icount integer :: npts integer :: i,j,jj @@ -1460,7 +1462,7 @@ subroutine USAF_interpBackToTypeObsData(this,nest,imax,jmax,back,type) integer,intent(in) :: imax integer,intent(in) :: jmax real, intent(in) :: back(imax,jmax) - character(len=10),intent(in) :: type + character(len=32),intent(in) :: type ! Local variables integer :: nobs @@ -1566,7 +1568,7 @@ subroutine USAF_analyzePrecip(precipAll,nest,back,hourindex,mrgp,precipOBA) real, allocatable :: sumObsEstimates(:) integer :: npasses integer :: r - character(len=10) :: new_name,type + character(len=32) :: new_name,type real :: convergeThresh real :: sigmaBSqr integer :: good_obs @@ -2043,7 +2045,7 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& integer :: imaxabsdiff real :: maxabsdiff, y_prev, y_new, normdev integer :: icount, num_high_dev - integer :: c,r,i,j,iob,job + integer :: c,r,i,j,iob,job,ii integer :: ierr double precision :: t0,t1, t2 logical :: verbose @@ -2318,6 +2320,21 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& end if end if + !EMK TEST + ! do ii = 1, nobs + ! write(LIS_logunit,*) & + ! '[INFO] ii,net,platform,obs, back, ana, est, dataDensity: ', & + ! ii, + ! trim(this%net(ii)), ' ',& + ! trim(this%platform(ii)), & + ! ' ',this%obs(ii),& + ! ' ',this%back(ii),& + ! ' ',pnew_ana(ii),& + ! ' ',pnew_est(ii),& + ! ' ',1./invDataDensities(ii) + + ! end do + if (done) exit ! No more iterations! if (verbose) then @@ -3176,7 +3193,7 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) ! Arguments type(USAF_ObsData), intent(inout) :: this integer,intent(in) :: nest - character(len=10), intent(in) :: new_name + character(len=32), intent(in) :: new_name character(len=*), optional :: network logical,optional,intent(in) :: silent_rejects @@ -3186,7 +3203,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) real :: dlat, dlon integer :: c,r,j real :: ctrlat, ctrlon - character(len=10) :: net_new, platform_new + character(len=32) :: net_new + character(len=32) :: platform_new integer, allocatable :: actions(:), actions_pet(:) real, allocatable :: superobs_pet(:),superlat_pet(:),superlon_pet(:) real, allocatable :: means(:) @@ -3608,7 +3626,8 @@ subroutine USAF_dupQC(this) integer :: count_dups integer :: total_reject_count, total_merge_count, total_create_count real :: mean,back,newlat,newlon,sigmaOSqr,oErrScaleLength - character(len=10) :: net,platform + character(len=32) :: net + character(len=32) :: platform real :: diff integer :: r,c,i integer :: nobs @@ -4069,7 +4088,7 @@ end subroutine USAF_backQC ! Checks if observation network is recognized as a gauge. logical function is_gauge(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .false. if (trim(net) .eq. "AMIL") answer = .true. @@ -4092,7 +4111,7 @@ end function is_gauge ! surface stations, all observations should have uncorrelated errors. logical function is_stn(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .true. is_stn = answer @@ -4102,7 +4121,7 @@ end function is_stn ! Checks if observation "network" is recognized as SSMI retrievals. logical function is_ssmi(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .false. if (trim(net) .eq. "SSMI") answer = .true. @@ -4113,7 +4132,7 @@ end function is_ssmi ! Checks if observation "network" is recognized as GEOPRECIP retrievals. logical function is_geoprecip(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .false. if (trim(net) .eq. "GEOPRECIP") answer = .true. @@ -4124,7 +4143,7 @@ end function is_geoprecip ! Checks if observation "network" is recognized as CMORPH estimate. logical function is_cmorph(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .false. if (trim(net) .eq. "CMORPH") answer = .true. @@ -4135,7 +4154,7 @@ end function is_cmorph ! Checks if observation "network" is recognized as IMERG retrievals. logical function is_imerg(net) implicit none - character(len=10), intent(in) :: net + character(len=32), intent(in) :: net logical :: answer answer = .false. if (trim(net) .eq. "IMERG") answer = .true. @@ -5440,7 +5459,7 @@ subroutine USAF_analyzeScreen(screenObs,nest,back,sigmaBSqr, & real, allocatable :: invDataDensities(:) real, allocatable :: sumObsEstimates(:) integer :: npasses - character(len=10) :: new_name,type + character(len=32) :: new_name,type real :: convergeThresh integer :: i,j @@ -5603,7 +5622,7 @@ subroutine USAF_getCMORPHObsData(nest,j6hr,use_twelve, & integer, parameter :: YD = 1649 integer, parameter :: NCMOR = XD*YD real :: precip(XD,YD) - character(len=10) :: net, platform + character(len=32) :: net, platform real :: sigmaOSqr, oErrScaleLength integer :: count_good_obs character(len=120) :: fname diff --git a/lis/metforcing/usaf/readagrmetpcpforcing.F90 b/lis/metforcing/usaf/readagrmetpcpforcing.F90 index b875ff14e..dc446e836 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcing.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcing.F90 @@ -267,7 +267,7 @@ subroutine readagrmetpcpforcing(n,findex, order) ! precip12Imerg_tmp integer :: hourindex integer :: k1,k2,k3,k4 - character(len=10) :: type + character(len=32) :: type character(len=10) :: yyyymmddhh character(len=50) :: pathOBA logical :: found_inq @@ -280,9 +280,10 @@ subroutine readagrmetpcpforcing(n,findex, order) integer*2 :: imerg_plp_thresh real :: imerg_sigmaOSqr real :: imerg_oErrScaleLength - character(len=10) :: imerg_net, imerg_platform + character(len=32) :: imerg_net, imerg_platform real :: sigmaBSqr - character(len=10) :: new_name + character(len=32) :: new_name + integer :: use_expanded_station_ids data alert_number / 0 / data srcwts /100.0,50.0,4.0,4.0,1.0,1.0,60.0,1.0/ data addrad /0, -1, -2, -4, -5, -5, 0, -2/ @@ -399,10 +400,14 @@ subroutine readagrmetpcpforcing(n,findex, order) write(LIS_logunit,*) & '[INFO] Fetching 6-hr gage data' call USAF_createObsData(precip_6hr_gage_tmp,n,maxobs=15000) - call AGRMET_getpcpobs(n, julbeg, LIS_rc%mo, prcpwe, & - use_twelve, p6, p12, alert_number, precip_6hr_gage_tmp, & - precip_12hr_gage_tmp, & - pcp_src) + !call AGRMET_getpcpobs(n, julbeg, LIS_rc%mo, prcpwe, & + ! use_twelve, p6, p12, alert_number, precip_6hr_gage_tmp, & + ! precip_12hr_gage_tmp, & + ! pcp_src) + use_expanded_station_ids = agrmet_struc(n)%pcpobsfmt - 1 + call USAF_getpcpobs(n, julbeg, LIS_rc%mo, use_twelve, & + pcp_src, use_expanded_station_ids, alert_number, & + precip_6hr_gage_tmp, precip_12hr_gage_tmp) ! Reject data over water write(LIS_logunit,*) & @@ -912,14 +917,22 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_createObsData(precip_12hr_gage_tmp,n,maxobs=15000) ! EMK...Call this twice to ensure we get obs for first two time ! levels. - call AGRMET_getpcpobs(n, julbeg, LIS_rc%mo, prcpwe, & - .false., p6, p12, alert_number,precip_6hr_gage_tmp, & - precip_12hr_gage_tmp, & - pcp_src) - call AGRMET_getpcpobs(n, julbeg+6, LIS_rc%mo, prcpwe, & - .true., p6, p12, alert_number,precip_6hr_gage_tmp, & - precip_12hr_gage_tmp, & - pcp_src) + !call AGRMET_getpcpobs(n, julbeg, LIS_rc%mo, prcpwe, & + ! .false., p6, p12, alert_number,precip_6hr_gage_tmp, & + ! precip_12hr_gage_tmp, & + ! pcp_src) + !call AGRMET_getpcpobs(n, julbeg+6, LIS_rc%mo, prcpwe, & + ! .true., p6, p12, alert_number,precip_6hr_gage_tmp, & + ! precip_12hr_gage_tmp, & + ! pcp_src) + use_expanded_station_ids = agrmet_struc(n)%pcpobsfmt - 1 + call USAF_getpcpobs(n, julbeg, LIS_rc%mo, .false., pcp_src, & + use_expanded_station_ids, alert_number, & + precip_6hr_gage_tmp, precip_12hr_gage_tmp) + call USAF_getpcpobs(n, julbeg+6, LIS_rc%mo, .true., pcp_src, & + use_expanded_station_ids, alert_number, & + precip_6hr_gage_tmp, precip_12hr_gage_tmp) + ! Not needed at this point since we have the 12hr accum call USAF_destroyObsData(precip_6hr_gage_tmp) diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 4586dce74..dbf352d3f 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -194,6 +194,36 @@ subroutine readcrd_agrmet() do n=1,LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,agrmet_struc(n)%pcpobswch,rc=rc) enddo + + ! EMK...Precip observation file formats + call ESMF_ConfigFindLabel(LIS_config,"AGRMET precip obs file format:", & + rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + agrmet_struc(n)%pcpobsfmt, rc=rc) + if (agrmet_struc(n)%pcpobsfmt .ne. 1 .and. & + agrmet_struc(n)%pcpobsfmt .ne. 2) then + write(LIS_logunit,*) & + "[ERR] Bad 'AGRMET precip obs file format:' option" + write(LIS_logunit,*) & + '[ERR] Expected 1 or 2, found ', agrmet_struc(n)%pcpobsfmt + write(LIS_logunit,*) '[ERR] Aborting...' + + flush(LIS_logunit) + message(1) = & + '[ERR] Illegal value for AGRMET precip obs file format' +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) +#endif + if (LIS_masterproc) then + call LIS_abort(message) + else + call sleep(10) + call LIS_endrun() + end if + end if + enddo + call ESMF_ConfigFindLabel(LIS_config,"AGRMET native imax:",rc=rc) do n=1,LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,agrmet_struc(n)%imaxnative,rc=rc) diff --git a/lis/routing/RAPID_router/RAPID_routing_run.F90 b/lis/routing/RAPID_router/RAPID_routing_run.F90 index 9c724b616..108df15f8 100644 --- a/lis/routing/RAPID_router/RAPID_routing_run.F90 +++ b/lis/routing/RAPID_router/RAPID_routing_run.F90 @@ -197,6 +197,7 @@ subroutine RAPID_routing_run(n) writeint=RAPID_routing_struc(n)%outInterval) ! run RAPID +#ifdef PETSc call RAPID_model_main (n,RAPID_routing_struc(n)%bQinit,RAPID_routing_struc(n)%bQfinal,RAPID_routing_struc(n)%bV, & RAPID_routing_struc(n)%bhum,RAPID_routing_struc(n)%bfor,RAPID_routing_struc(n)%bdam, & RAPID_routing_struc(n)%binfluence,RAPID_routing_struc(n)%buq, & @@ -208,7 +209,7 @@ subroutine RAPID_routing_run(n) RAPID_routing_struc(n)%nmlfile,qout_filename, & LIS_rc%gnc(n),LIS_rc%gnr(n),surface_runoff,baseflow,RAPID_routing_struc(n)%initCheck, & RAPID_routing_struc(n)%dt,RAPID_routing_struc(n)%routingInterval) - +#endif deallocate(surface_runoff) deallocate(baseflow) From 1147d0a728a824eb1d8ecac7c9b20c362c93ced2 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 30 Oct 2023 09:24:00 -0400 Subject: [PATCH 194/328] Forgot to add a new file. --- lis/metforcing/USAF_getpcpobs.F90 | 105 ++++++++++++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 lis/metforcing/USAF_getpcpobs.F90 diff --git a/lis/metforcing/USAF_getpcpobs.F90 b/lis/metforcing/USAF_getpcpobs.F90 new file mode 100644 index 000000000..401d510f0 --- /dev/null +++ b/lis/metforcing/USAF_getpcpobs.F90 @@ -0,0 +1,105 @@ +! ROUTINE: USAF_getpcpcobs +! +! REVISION HISTORY: +! 17 Oct 2023 Initial version. Eric Kemp/SSAI/NASA. +! +! DESCRIPTION: +! New routine to retrieve precip observations and process with new +! USAF_Gages library. Supports legacy hemispheric and new global +! preobs file formats, and new presav2 file format. Borrows heavily +! from older AGRMET_getpcpobs subroutine. +!-------------------------------------------------------------------------- + +subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & + use_expanded_station_ids, alert_number, precip6, precip12) + + ! Imports + use AGRMET_forcingMod, only: agrmet_struc + use ESMF + use LIS_coreMod, only: LIS_rc + use LIS_logMod, only: LIS_logunit + use LIS_timeMgrMod, only: LIS_tick, LIS_julhr_date + use USAF_bratsethMod, only: USAF_ObsData, USAF_setbratsethprecipstats + use USAF_GagesMod, only : USAF_Gages_t + use USAF_PreobsReaderMod, only: USAF_read_preobs + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + integer, intent(in) :: j6hr + integer, intent(in) :: month + logical, intent(in) :: use_twelve + character*6, intent(in) :: pcp_src(4) + integer, intent(in) :: use_expanded_station_ids + integer, intent(inout):: alert_number + type(USAF_ObsData), intent(inout) :: precip6 + type(USAF_ObsData), intent(inout) :: precip12 + + ! Locals + integer :: j3hr + integer :: k + integer :: yr, mo, da, hr + character*255 :: preobsdir + character*8 :: yyyymmdd + character*10 :: yyyymmddhh + character*255 :: presav_filename + logical :: file_exists + type(USAF_Gages_t) :: obscur + + if (use_twelve) then + k = 3 + else + k = 1 + end if + + do j3hr = j6hr+3, j6hr+6, 3 + + ! Set Bratseth error statistics based on source of background field. + call USAF_setBratsethPrecipStats(pcp_src(k), n) + + call LIS_julhr_date(j3hr, yr, mo, da, hr) + if (agrmet_struc(n)%use_timestamp == 1) then + write(unit=yyyymmdd, fmt='(i4.4, i2.2, i2.2)') & + yr, mo, da + preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & + // yyyymmdd // '/' & + // trim(agrmet_struc(n)%cdmsdir) // '/' + else + preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & + // trim(agrmet_struc(n)%cdmsdir) // '/' + end if + + ! Read appropriate preobs file(s), intercompare with older presav2 + ! files, and create new presav2 file for current date/time. + call USAF_read_preobs(preobsdir, & + trim(agrmet_struc(n)%analysisdir), & + agrmet_struc(n)%use_timestamp, yr, mo, da, hr, & + use_expanded_station_ids) + + ! If this is a synoptic time, read the presav2 file back in and + ! populate the appropriate USAF_ObsData object. + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(agrmet_struc(n)%analysisdir), '/presav2.03hr.', & + yr, mo, da, hr + inquire(file=presav_filename, exist=file_exists) + if (file_exists) then + write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & + yr, mo, da, hr + call obscur%read_data(presav_filename, yyyymmddhh) + if (.not. use_twelve) then + call obscur%copy_to_usaf_obsdata(6, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip6) + else + call obscur%copy_to_usaf_obsdata(12, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip12) + end if + end if + + k = k + 1 + end do + +end subroutine USAF_getpcpobs From 482777f7ccdaefb39c24dcc1b9b4f461d34f6e4f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 30 Oct 2023 09:41:55 -0400 Subject: [PATCH 195/328] Again, added missing file. --- lis/metforcing/usaf/USAF_getpcpobs.F90 | 105 +++++++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 lis/metforcing/usaf/USAF_getpcpobs.F90 diff --git a/lis/metforcing/usaf/USAF_getpcpobs.F90 b/lis/metforcing/usaf/USAF_getpcpobs.F90 new file mode 100644 index 000000000..401d510f0 --- /dev/null +++ b/lis/metforcing/usaf/USAF_getpcpobs.F90 @@ -0,0 +1,105 @@ +! ROUTINE: USAF_getpcpcobs +! +! REVISION HISTORY: +! 17 Oct 2023 Initial version. Eric Kemp/SSAI/NASA. +! +! DESCRIPTION: +! New routine to retrieve precip observations and process with new +! USAF_Gages library. Supports legacy hemispheric and new global +! preobs file formats, and new presav2 file format. Borrows heavily +! from older AGRMET_getpcpobs subroutine. +!-------------------------------------------------------------------------- + +subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & + use_expanded_station_ids, alert_number, precip6, precip12) + + ! Imports + use AGRMET_forcingMod, only: agrmet_struc + use ESMF + use LIS_coreMod, only: LIS_rc + use LIS_logMod, only: LIS_logunit + use LIS_timeMgrMod, only: LIS_tick, LIS_julhr_date + use USAF_bratsethMod, only: USAF_ObsData, USAF_setbratsethprecipstats + use USAF_GagesMod, only : USAF_Gages_t + use USAF_PreobsReaderMod, only: USAF_read_preobs + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + integer, intent(in) :: j6hr + integer, intent(in) :: month + logical, intent(in) :: use_twelve + character*6, intent(in) :: pcp_src(4) + integer, intent(in) :: use_expanded_station_ids + integer, intent(inout):: alert_number + type(USAF_ObsData), intent(inout) :: precip6 + type(USAF_ObsData), intent(inout) :: precip12 + + ! Locals + integer :: j3hr + integer :: k + integer :: yr, mo, da, hr + character*255 :: preobsdir + character*8 :: yyyymmdd + character*10 :: yyyymmddhh + character*255 :: presav_filename + logical :: file_exists + type(USAF_Gages_t) :: obscur + + if (use_twelve) then + k = 3 + else + k = 1 + end if + + do j3hr = j6hr+3, j6hr+6, 3 + + ! Set Bratseth error statistics based on source of background field. + call USAF_setBratsethPrecipStats(pcp_src(k), n) + + call LIS_julhr_date(j3hr, yr, mo, da, hr) + if (agrmet_struc(n)%use_timestamp == 1) then + write(unit=yyyymmdd, fmt='(i4.4, i2.2, i2.2)') & + yr, mo, da + preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & + // yyyymmdd // '/' & + // trim(agrmet_struc(n)%cdmsdir) // '/' + else + preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & + // trim(agrmet_struc(n)%cdmsdir) // '/' + end if + + ! Read appropriate preobs file(s), intercompare with older presav2 + ! files, and create new presav2 file for current date/time. + call USAF_read_preobs(preobsdir, & + trim(agrmet_struc(n)%analysisdir), & + agrmet_struc(n)%use_timestamp, yr, mo, da, hr, & + use_expanded_station_ids) + + ! If this is a synoptic time, read the presav2 file back in and + ! populate the appropriate USAF_ObsData object. + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(agrmet_struc(n)%analysisdir), '/presav2.03hr.', & + yr, mo, da, hr + inquire(file=presav_filename, exist=file_exists) + if (file_exists) then + write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & + yr, mo, da, hr + call obscur%read_data(presav_filename, yyyymmddhh) + if (.not. use_twelve) then + call obscur%copy_to_usaf_obsdata(6, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip6) + else + call obscur%copy_to_usaf_obsdata(12, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip12) + end if + end if + + k = k + 1 + end do + +end subroutine USAF_getpcpobs From d07c1f7d817d03cbda386584d3c07cbd25597eec Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 30 Oct 2023 16:44:59 -0400 Subject: [PATCH 196/328] Removed file that was committed in wrong directory. It already exists elsewhere. --- lis/metforcing/USAF_getpcpobs.F90 | 105 ------------------------------ 1 file changed, 105 deletions(-) delete mode 100644 lis/metforcing/USAF_getpcpobs.F90 diff --git a/lis/metforcing/USAF_getpcpobs.F90 b/lis/metforcing/USAF_getpcpobs.F90 deleted file mode 100644 index 401d510f0..000000000 --- a/lis/metforcing/USAF_getpcpobs.F90 +++ /dev/null @@ -1,105 +0,0 @@ -! ROUTINE: USAF_getpcpcobs -! -! REVISION HISTORY: -! 17 Oct 2023 Initial version. Eric Kemp/SSAI/NASA. -! -! DESCRIPTION: -! New routine to retrieve precip observations and process with new -! USAF_Gages library. Supports legacy hemispheric and new global -! preobs file formats, and new presav2 file format. Borrows heavily -! from older AGRMET_getpcpobs subroutine. -!-------------------------------------------------------------------------- - -subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & - use_expanded_station_ids, alert_number, precip6, precip12) - - ! Imports - use AGRMET_forcingMod, only: agrmet_struc - use ESMF - use LIS_coreMod, only: LIS_rc - use LIS_logMod, only: LIS_logunit - use LIS_timeMgrMod, only: LIS_tick, LIS_julhr_date - use USAF_bratsethMod, only: USAF_ObsData, USAF_setbratsethprecipstats - use USAF_GagesMod, only : USAF_Gages_t - use USAF_PreobsReaderMod, only: USAF_read_preobs - - ! Defaults - implicit none - - ! Arguments - integer, intent(in) :: n - integer, intent(in) :: j6hr - integer, intent(in) :: month - logical, intent(in) :: use_twelve - character*6, intent(in) :: pcp_src(4) - integer, intent(in) :: use_expanded_station_ids - integer, intent(inout):: alert_number - type(USAF_ObsData), intent(inout) :: precip6 - type(USAF_ObsData), intent(inout) :: precip12 - - ! Locals - integer :: j3hr - integer :: k - integer :: yr, mo, da, hr - character*255 :: preobsdir - character*8 :: yyyymmdd - character*10 :: yyyymmddhh - character*255 :: presav_filename - logical :: file_exists - type(USAF_Gages_t) :: obscur - - if (use_twelve) then - k = 3 - else - k = 1 - end if - - do j3hr = j6hr+3, j6hr+6, 3 - - ! Set Bratseth error statistics based on source of background field. - call USAF_setBratsethPrecipStats(pcp_src(k), n) - - call LIS_julhr_date(j3hr, yr, mo, da, hr) - if (agrmet_struc(n)%use_timestamp == 1) then - write(unit=yyyymmdd, fmt='(i4.4, i2.2, i2.2)') & - yr, mo, da - preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & - // yyyymmdd // '/' & - // trim(agrmet_struc(n)%cdmsdir) // '/' - else - preobsdir = trim(agrmet_struc(n)%agrmetdir) // '/' & - // trim(agrmet_struc(n)%cdmsdir) // '/' - end if - - ! Read appropriate preobs file(s), intercompare with older presav2 - ! files, and create new presav2 file for current date/time. - call USAF_read_preobs(preobsdir, & - trim(agrmet_struc(n)%analysisdir), & - agrmet_struc(n)%use_timestamp, yr, mo, da, hr, & - use_expanded_station_ids) - - ! If this is a synoptic time, read the presav2 file back in and - ! populate the appropriate USAF_ObsData object. - write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & - trim(agrmet_struc(n)%analysisdir), '/presav2.03hr.', & - yr, mo, da, hr - inquire(file=presav_filename, exist=file_exists) - if (file_exists) then - write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & - yr, mo, da, hr - call obscur%read_data(presav_filename, yyyymmddhh) - if (.not. use_twelve) then - call obscur%copy_to_usaf_obsdata(6, & - agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & - precip6) - else - call obscur%copy_to_usaf_obsdata(12, & - agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & - precip12) - end if - end if - - k = k + 1 - end do - -end subroutine USAF_getpcpobs From 22e83d7c20c8d33f7660339ee8142ca73177c290 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 1 Nov 2023 09:13:20 -0400 Subject: [PATCH 197/328] Added MPI error checks. Also added some debugging print statements. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 155 ++++++++++++++++++++--- 1 file changed, 140 insertions(+), 15 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 2719c21c3..e9d3f89ee 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -885,6 +885,8 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_getBackNWP') #endif if(LIS_masterproc) then call LIS_alert( 'LIS.USAF_getBackNWP ', 1, & @@ -1848,6 +1850,8 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_invDataDensities') t1 = MPI_Wtime() #endif @@ -1954,8 +1958,12 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & allocate(invDataDensities(nobs)) invDataDensities(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_invDataDensities') call MPI_ALLREDUCE(dataDensities_pet,invDataDensities,nobs,MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_ALLREDUCE call in calc_invDataDensities') #endif ! Clean up @@ -1973,6 +1981,8 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_invDataDensities') t2 = MPI_Wtime() if (verbose) then write(LIS_logunit,*) & @@ -2078,6 +2088,12 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& call LIS_endrun() end if + ! EMK TEST + !do ii = 1, nobs + ! write(LIS_logunit,*)'EMK: ii, invDataDensity: ', ii, & + ! invDataDensities(ii) + !end do + ! Here we create a 2d hash table storing the index values of each ob ! in linked lists for each LIS grid box. This can help us screen ! out obviously unnecessary ob comparisons later. @@ -2113,6 +2129,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') t0 = MPI_Wtime() #endif @@ -2120,6 +2138,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') t1 = MPI_Wtime() #endif pnew_est_pet(:) = 0 @@ -2222,11 +2242,19 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& pnew_est(:) = 0 pnew_ana(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') call MPI_ALLREDUCE(pnew_est_pet, pnew_est, nobs, MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_ALLREDUCE call in calc_obsAnalysis') call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') call MPI_ALLREDUCE(pnew_ana_pet, pnew_ana, nobs, MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_ALLREDUCE call in calc_obsAnalysis') #endif ! Finish analysis and observation estimates for this iteration @@ -2250,8 +2278,12 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& ! Share sumObsEstimates across all processors. sumObsEstimates(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') call MPI_ALLREDUCE(sumObsEstimates_pet, sumObsEstimates, nobs, & MPI_REAL, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_ALLREDUCE call in calc_obsAnalysis') #else do j = 1, nobs sumObsEstimates(j) = sum(sumObsEstimates_pet) @@ -2321,19 +2353,18 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& end if !EMK TEST - ! do ii = 1, nobs - ! write(LIS_logunit,*) & - ! '[INFO] ii,net,platform,obs, back, ana, est, dataDensity: ', & - ! ii, - ! trim(this%net(ii)), ' ',& - ! trim(this%platform(ii)), & - ! ' ',this%obs(ii),& - ! ' ',this%back(ii),& - ! ' ',pnew_ana(ii),& - ! ' ',pnew_est(ii),& - ! ' ',1./invDataDensities(ii) - - ! end do + do ii = 1, nobs + write(LIS_logunit,*) & + '[INFO] ii,net,platform,obs, back, ana, est, dataDensity: ', & + ii, & + trim(this%net(ii)), ' ',& + trim(this%platform(ii)), & + ' ',this%obs(ii),& + ' ',this%back(ii),& + ' ',pnew_ana(ii),& + ' ',pnew_est(ii),& + ' ',1./invDataDensities(ii) + end do if (done) exit ! No more iterations! @@ -2365,6 +2396,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') t2 = MPI_Wtime() if (verbose) then write(LIS_logunit,*) & @@ -2402,6 +2435,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_obsAnalysis') t2 = MPI_Wtime() if (verbose) then write(LIS_logunit,*) & @@ -2534,6 +2569,8 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_gridAnalysis') t1 = MPI_Wtime() #endif @@ -2619,9 +2656,13 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& allocate(mrgp_1d(LIS_rc%gnc(nest)*LIS_rc%gnr(nest))) mrgp_1d(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_gridAnalysis') call MPI_ALLREDUCE(mrgp_1d_pet,mrgp_1d, & LIS_rc%gnc(nest)*LIS_rc%gnr(nest),MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_ALLREDUCE call in calc_gridAnalysis') deallocate(mrgp_1d_pet) #endif @@ -2648,6 +2689,8 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in calc_gridAnalysis') t2 = MPI_Wtime() write(LIS_logunit,*)'[INFO] Elapsed time for grid analysis is ', & t2 - t1,' seconds' @@ -3156,6 +3199,8 @@ subroutine check_grib_file(gribfile,yr1,mo1,da1,hr1,found, & message(3) = ' LIS was not compiled with GRIBAPI or ECCODES support!' #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in check_grib_file') #endif if(LIS_masterproc) then call LIS_alert( 'LIS.check_grib_file', 1, & @@ -3249,6 +3294,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_superstatQC') t1 = MPI_Wtime() #endif @@ -3410,6 +3457,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Allreduce(superobs_pet,means,glbcr,MPI_REAL, MPI_SUM, & LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') #else do j = 1, glbcr means(j) = sum(superobs_pet) @@ -3420,6 +3469,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Allreduce(superob_count_pet,superob_count,glbcr,& MPI_INTEGER, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') #else do j = 1, glbcr superob_count(j) = sum(superob_count_pet) @@ -3444,35 +3495,49 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_superstatQC') superob_count(:) = 0 call MPI_Allreduce(superob_count_pet, superob_count, glbcr,& MPI_INTEGER, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superob_count_pet(:) = 0 superobs(:) = 0 call MPI_Allreduce(superobs_pet, superobs, glbcr, MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superobs_pet(:) = 0 superlat(:) = 0 call MPI_Allreduce(superlat_pet, superlat, glbcr, MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superlat_pet(:) = 0 superlon(:) = 0 call MPI_Allreduce(superlon_pet, superlon, glbcr, MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superlon_pet(:) = 0 superSigmaOSqr(:) = 0 call MPI_Allreduce(superSigmaOSqr_pet, superSigmaOSqr, glbcr, & MPI_REAL, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superSigmaOSqr_pet(:) = 0 superOErrScaleLength(:) = 0 call MPI_Allreduce(superOErrScaleLength_pet, & superOErrScaleLength, glbcr, & MPI_REAL, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') superOErrScaleLength_pet(:) = 0 #endif @@ -3505,9 +3570,13 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_superstatQC') actions(:) = 0 call MPI_Allreduce(actions_pet, actions, nobs,& MPI_INTEGER, MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_superstatQC') actions_pet(:) = 0 #endif end if ! ipass .eq. 3 @@ -3584,6 +3653,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_superstatQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in superstatQC is ',t2 - t1,' seconds' @@ -3645,6 +3716,8 @@ subroutine USAF_dupQC(this) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_dupQC') t1 = MPI_Wtime() #endif @@ -3933,6 +4006,8 @@ subroutine USAF_dupQC(this) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_dupQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in dupQC is ',t2 - t1,' seconds' @@ -4039,6 +4114,8 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_backQC') t1 = MPI_Wtime() #endif @@ -4077,6 +4154,8 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_backQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in backQC is ',t2 - t1,' seconds' @@ -4823,6 +4902,8 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in find_LIS_cols_rows') #endif do j = 1, nobs @@ -4903,8 +4984,12 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) cols = 0 #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in find_LIS_cols_rows') call MPI_ALLREDUCE(cols_pet,cols,nobs,MPI_INTEGER, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in find_LIS_cols_rows') #else cols(:) = cols_pet(:) #endif @@ -4915,8 +5000,12 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) rows = 0 #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in find_LIS_cols_rows') call MPI_ALLREDUCE(rows_pet,rows,nobs,MPI_INTEGER, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in find_LIS_cols_rows') #else rows(:) = rows_pet(:) #endif @@ -4968,6 +5057,8 @@ subroutine USAF_waterQC(this,nest,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_waterQC') t1 = MPI_Wtime() #endif @@ -5005,6 +5096,8 @@ subroutine USAF_waterQC(this,nest,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_waterQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in waterQC is ',t2-t1,' seconds' @@ -5065,6 +5158,8 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowQC') t1 = MPI_Wtime() #endif @@ -5108,9 +5203,13 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) allocate(sfctmp_1d(LIS_rc%gnc(nest)*LIS_rc%gnr(nest))) sfctmp_1d(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowQC') call MPI_ALLREDUCE(sfctmp_1d_pet,sfctmp_1d, & LIS_rc%gnc(nest)*LIS_rc%gnr(nest),MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_snowQC') deallocate(sfctmp_1d_pet) #endif allocate(sfctmp(LIS_rc%gnc(nest), LIS_rc%gnr(nest))) @@ -5187,6 +5286,8 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in snowQC is ',t2-t1,' seconds' @@ -5248,6 +5349,8 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowDepthQC') t1 = MPI_Wtime() #endif @@ -5299,9 +5402,13 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) allocate(snowdepth_1d(LIS_rc%gnc(nest)*LIS_rc%gnr(nest))) snowdepth_1d(:) = 0 call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowDepthQC') call MPI_ALLREDUCE(snowdepth_1d_pet,snowdepth_1d, & LIS_rc%gnc(nest)*LIS_rc%gnr(nest),MPI_REAL, & MPI_SUM, LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Allreduce call in USAF_snowDepthQC') deallocate(snowdepth_1d_pet) #endif allocate(snowdepth(LIS_rc%gnc(nest), LIS_rc%gnr(nest))) @@ -5369,6 +5476,8 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) #if (defined SPMD) call MPI_Barrier(LIS_MPI_COMM, ierr) + call handle_mpi_error(ierr, & + 'MPI_Barrier call in USAF_snowDepthQC') t2 = MPI_Wtime() write(LIS_logunit,*) & '[INFO] Elapsed time in snowDepthQC is ',t2-t1,' seconds' @@ -6483,8 +6592,24 @@ subroutine USAF_pcpBackBiasRatio_s2s(n, yyyymmddhh) 'n90_get_var failed for PPT_ratio in LIS param file') call LIS_verify(nf90_close(ncid),& 'nf90_close failed in USAF_pcpBackBiasRatio_s2s') - #endif end subroutine USAF_pcpBackBiasRatio_s2s -end module USAF_bratsethMod + + subroutine handle_mpi_error(errorcode, msg) + use LIS_logMod, only: LIS_logunit, LIS_endrun + use LIS_mpiMod + implicit none + integer, intent(in) :: errorcode + character(*), intent(in) :: msg + character*(MPI_MAX_ERROR_STRING) :: buf + integer :: resultlen, ierr + if (errorcode .ne. MPI_SUCCESS) then + write(LIS_logunit,*)'[ERR] ', trim(msg) + call MPI_error_string(errorcode, buf, resultlen, ierr) + write(LIS_logunit,*)'[ERR] MPI error: ', trim(buf) + flush(LIS_logunit) + call LIS_endrun() + end if + end subroutine handle_mpi_error + end module USAF_bratsethMod From a4f6f922def1957a6fc5e8e46ab44a0d480eae24 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 6 Nov 2023 09:24:52 -0500 Subject: [PATCH 198/328] Corrected QC flag data types. Changes to avoid direct check of real zeros. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 63 +++++++++++++++--------- 1 file changed, 41 insertions(+), 22 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index e9d3f89ee..1cc946f36 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -145,10 +145,10 @@ module USAF_bratsethMod real, parameter :: MISSING = -9999 ! Quality control flags. Should these be public? - real, parameter :: QC_UNKNOWN = 0 - real, parameter :: QC_GOOD = 1 - real, parameter :: QC_SUSPECT = 2 - real, parameter :: QC_REJECT = 3 + integer, parameter :: QC_UNKNOWN = 0 + integer, parameter :: QC_GOOD = 1 + integer, parameter :: QC_SUSPECT = 2 + integer, parameter :: QC_REJECT = 3 contains @@ -1045,7 +1045,8 @@ subroutine USAF_getSSMIObsData(nest,j6hr,use_twelve,precip3,precip6, & ! Honor option to reset SSMI zero precip values to missing if (.not. use_zeros) then write(LIS_logunit,*)'- SSMI ZEROS NOT USED' - where ( ra(:,:,:) .eq. 0.0 ) + where ( .not. ra(:,:,:) > 0.0 .and. & + .not. ra(:,:,:) < 0) ra(:,:,:) = MISSING end where end if @@ -1916,7 +1917,8 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & else if (trim(this%net(iob)) .eq. trim(this%net(job))) then ! Satellite observations have correlated errors. if (.not. isUncorrObType(this%net(job))) then - if (this%oErrScaleLength(job) .eq. 0) then + if (.not. this%oErrScaleLength(job) > 0 .and. & + .not. this%oErrScaleLength(job) < 0) then write(LIS_logunit,*) & '[ERR]: job, network, oErrScaleLength: ', & job, trim(this%net(job)), & @@ -2410,24 +2412,24 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& ! production, we will allow the program to continue instead of ! aborting. !if (npasses .eq. 100) then - if (npasses .eq. 5) then ! For Ops - - write(LIS_logunit,*) & - '[WARN] Bratseth failed to converge after ',npasses, & - ' iterations!' - write(LIS_logunit,*) & - '[WARN] Will stop iterating' - flush(LIS_logunit) - exit - end if + if (npasses .eq. 5) then ! For Ops + + write(LIS_logunit,*) & + '[WARN] Bratseth failed to converge after ',npasses, & + ' iterations!' + write(LIS_logunit,*) & + '[WARN] Will stop iterating' + flush(LIS_logunit) + exit + end if end do ! Iterate until convergence if (verbose) then if (done) then - write(LIS_logunit,*) & + write(LIS_logunit,*) & '[INFO] Bratseth analysis converged after ',npasses, & ' iterations' - endif + endif write(LIS_logunit,*) & '[INFO] Mean absolute difference against obs: ana: ',mad_ana, & ' est: ',mad_est @@ -3784,9 +3786,11 @@ subroutine USAF_dupQC(this) ptr => head do i = 1, count_dups diff = this%lat(ptr%ob_index) - this%lat(r) - if (diff .ne. 0) location_issue = .true. + if (.not. diff > 0 .and. & + .not. diff < 0) location_issue = .true. diff = this%lon(ptr%ob_index) - this%lon(r) - if (diff .ne. 0) location_issue = .true. + if (.not. diff > 0 .and. & + .not. diff < 0) location_issue = .true. if (location_issue) exit ! Get out of loop ptr => ptr%next end do ! i @@ -3822,7 +3826,8 @@ subroutine USAF_dupQC(this) reject_all = .false. do i = 1, count_dups diff = this%obs(ptr%ob_index) - this%obs(r) - if (diff .eq. 0) then + if (.not. diff > 0 .and. & + .not. diff < 0) then this%qc(ptr%ob_index) = QC_REJECT total_reject_count = total_reject_count + 1 write(LIS_logunit,*) & @@ -3883,7 +3888,8 @@ subroutine USAF_dupQC(this) if (count_dups .eq. 1 .and. .not. location_issue) then ptr => head diff = this%obs(ptr%ob_index) - this%obs(r) - if (diff .eq. 0) then + if (.not. diff < 0 .and. & + .not. diff > 0) then this%qc(ptr%ob_index) = QC_REJECT total_reject_count = total_reject_count + 1 write(LIS_logunit,*) & @@ -4119,6 +4125,9 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) t1 = MPI_Wtime() #endif + !write(LIS_logunit,*)'EMK: nobs, sigmaBSqr = ', nobs, sigmaBSqr + !flush(LIS_Logunit) + reject_count = 0 do r = 1,nobs @@ -6460,6 +6469,11 @@ subroutine USAF_setBratsethScreenStats(src,n) agrmet_struc(n)%galwem_t2m_back_err_scale_length agrmet_struc(n)%bratseth_t2m_back_sigma_b_sqr = & agrmet_struc(n)%galwem_t2m_back_sigma_b_sqr + + !write(LIS_logunit,*)'EMK: n, GALWEM T2 err = ', n, & + ! agrmet_struc(n)%bratseth_t2m_back_sigma_b_sqr + !flush(LIS_logunit) + agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr = & agrmet_struc(n)%galwem_t2m_stn_sigma_o_sqr agrmet_struc(n)%bratseth_t2m_max_dist = & @@ -6488,6 +6502,11 @@ subroutine USAF_setBratsethScreenStats(src,n) agrmet_struc(n)%gfs_t2m_back_err_scale_length agrmet_struc(n)%bratseth_t2m_back_sigma_b_sqr = & agrmet_struc(n)%gfs_t2m_back_sigma_b_sqr + + !write(LIS_logunit,*)'EMK: n, GFS T2 err = ', n, & + ! agrmet_struc(n)%bratseth_t2m_back_sigma_b_sqr + !flush(LIS_Logunit) + agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr = & agrmet_struc(n)%gfs_t2m_stn_sigma_o_sqr agrmet_struc(n)%bratseth_t2m_max_dist = & From 20af7290a96c5de4b5e84e35805be1a5086ff5a4 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 6 Nov 2023 09:26:16 -0500 Subject: [PATCH 199/328] Added initialization after array allocations. Valgrind complained that the lack of immediate initialization caused problems later in the LIS execution. I'm skeptical, but it is known that Linux doesn't finish allocation until a program starts writing to the "allocated" memory. So this is not a bad idea in general. --- lis/core/LIS_domainMod.F90 | 9 ++++++++- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 19 +++++++++++++++++-- 2 files changed, 25 insertions(+), 3 deletions(-) diff --git a/lis/core/LIS_domainMod.F90 b/lis/core/LIS_domainMod.F90 index e0efcd7b9..e9be57c8d 100644 --- a/lis/core/LIS_domainMod.F90 +++ b/lis/core/LIS_domainMod.F90 @@ -397,15 +397,22 @@ subroutine LIS_domain_setup(n) TRACE_ENTER("dom_setup") allocate(LIS_domain(n)%ntiles_pergrid(LIS_rc%gnc(n)*LIS_rc%gnr(n))) + LIS_domain(n)%ntiles_pergrid = 0 ! EMK TEST allocate(LIS_domain(n)%str_tind(LIS_rc%gnc(n)*LIS_rc%gnr(n))) + LIS_domain(n)%str_tind = 0 ! EMK TEST allocate(ntiles_pergrid(LIS_rc%lnc(n)*LIS_rc%lnr(n)),stat=ierr) + ntiles_pergrid = 0 allocate(ntiles_pergrid_red(LIS_rc%lnc_red(n)*LIS_rc%lnr_red(n)),stat=ierr) - + ntiles_pergrid_red = 0 allocate(npatch_pergrid(LIS_rc%lnc(n)*LIS_rc%lnr(n),LIS_rc%max_model_types)) + npatch_pergrid = 0 allocate(npatch_pergrid_red(LIS_rc%lnc(n)*LIS_rc%lnr(n),LIS_rc%max_model_types)) + npatch_pergrid_red = 0 do m=1,LIS_rc%max_model_types allocate(LIS_surface(n,m)%npatch_pergrid(LIS_rc%gnc(n)*LIS_rc%gnr(n))) + LIS_surface(n,m)%npatch_pergrid = 0 allocate(LIS_surface(n,m)%str_patch_ind(LIS_rc%gnc(n)*LIS_rc%gnr(n))) + LIS_surface(n,m)%str_patch_ind = 0 enddo do t=1,LIS_rc%ntiles(n) diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index 97bc09474..18873b19d 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -2053,26 +2053,41 @@ subroutine init_AGRMET(findex) agrmet_struc(n)%pcpclimoAlarmTime = 0.0 allocate(agrmet_struc(n)%cliprc1(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%cliprc1 = 0 allocate(agrmet_struc(n)%clippd1(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%clippd1 = 0 allocate(agrmet_struc(n)%clirtn1(LIS_rc%lnc(n), LIS_rc%lnr(n))) - + agrmet_struc(n)%clirtn1 = 0 allocate(agrmet_struc(n)%cliprc2(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%cliprc2 = 0 allocate(agrmet_struc(n)%clippd2(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%clippd2 = 0 allocate(agrmet_struc(n)%clirtn2(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%clirtn2 = 0 allocate(agrmet_struc(n)%cliprc(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%cliprc = 0 allocate(agrmet_struc(n)%clippd(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%clippd = 0 allocate(agrmet_struc(n)%clirtn(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%clirtn = 0 allocate(agrmet_struc(n)%sfcprs(6,LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%sfcprs = 0 allocate(agrmet_struc(n)%sfcrlh(6,LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%sfcrlh = 0 allocate(agrmet_struc(n)%sfcspd(6,LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%sfcspd = 0 allocate(agrmet_struc(n)%sfctmp(6,LIS_rc%lnc(n), LIS_rc%lnr(n))) - + agrmet_struc(n)%sfctmp = 0 allocate(agrmet_struc(n)%lasprs(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%lasprs = 0 allocate(agrmet_struc(n)%lasrlh(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%lasrlh = 0 allocate(agrmet_struc(n)%lasspd(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%lasspd = 0 allocate(agrmet_struc(n)%lastmp(LIS_rc%lnc(n), LIS_rc%lnr(n))) + agrmet_struc(n)%lastmp = 0 ! EMK BEGIN ! From f855ffb0a4e34c2fb021fac0e2bddde35d7a1c26 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 7 Nov 2023 16:46:46 +0000 Subject: [PATCH 200/328] Add function prototypes to address compiler error error: ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration] --- lis/surfacemodels/land/rdhm.3.5.6/frz/gen_frzst.c | 4 ++++ lis/surfacemodels/land/rdhm.3.5.6/frz/scale_frzst.c | 8 ++++++++ lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c | 3 +++ lis/surfacemodels/land/rdhm.3.5.6/sac/days_of_month.c | 2 ++ lis/surfacemodels/land/rdhm.3.5.6/sac/get_daily_pe.c | 2 ++ lis/surfacemodels/land/rdhm.3.5.6/sac/get_ped.c | 2 ++ 6 files changed, 21 insertions(+) diff --git a/lis/surfacemodels/land/rdhm.3.5.6/frz/gen_frzst.c b/lis/surfacemodels/land/rdhm.3.5.6/frz/gen_frzst.c index ca6f22a08..295d8ead3 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/frz/gen_frzst.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/frz/gen_frzst.c @@ -6,6 +6,10 @@ #include "linux.h" /* #include "models.h" */ +extern void fstfg1_(int *, int *, int *, int *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *); + +extern void frzind1_(float *, float *, float *, float *, int *, float *, float *, float *); + int gen_frzst(int npix, int *nsoil, int *nupl, float *sac_parx, float *frz_parx, float *frz_stx, float *sac_stx, float *sacst_prv, float *smc, float *sh2o, float dthr, diff --git a/lis/surfacemodels/land/rdhm.3.5.6/frz/scale_frzst.c b/lis/surfacemodels/land/rdhm.3.5.6/frz/scale_frzst.c index a3b7c3062..a15c23eb8 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/frz/scale_frzst.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/frz/scale_frzst.c @@ -4,6 +4,14 @@ #include "com_header.h" #include "linux.h" +extern void fstfg1_(int *, int *, int *, int *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *, float *); + +extern void soil_int1_(float *,int *,float *,float *,int *,float *); + +extern void scale_sh2o_(float *, float *, float *, int *, int *, float *, float *, float *, float *, float *, float *, float *); + +extern void frzind1_(float *, float *, float *, float *, int *, float *, float *, float *); + int scale_frzst(int npix, int *nsoil, int *nupl, float *sac_parx, float *frz_parx, float *frz_stx, float *sac_stx, float *sacst_prv, float *smc, float *sh2o, float dthr, diff --git a/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c b/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c index b0a3358b1..ad97bf88e 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c @@ -9,6 +9,9 @@ //-------------------------END NOTICE -- DO NOT EDIT----------------------- /* wrapper for calling get_ped Shugong Wang 10/25/2013 */ + +extern void get_ped(int, int, int, int, int, float *, float *, float *); + void rdhm_get_ped_(int *year, /* */ int *month, /* */ int *day, /* */ diff --git a/lis/surfacemodels/land/rdhm.3.5.6/sac/days_of_month.c b/lis/surfacemodels/land/rdhm.3.5.6/sac/days_of_month.c index cef3f38c3..b109acf20 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/sac/days_of_month.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/sac/days_of_month.c @@ -13,6 +13,8 @@ #include "com_header.h" #include "models.h" +extern int is_leap_year(int); + int days_of_month(int m, int y) { int num_days[12]={31,28,31,30,31,30,31,31,30,31,30,31}; diff --git a/lis/surfacemodels/land/rdhm.3.5.6/sac/get_daily_pe.c b/lis/surfacemodels/land/rdhm.3.5.6/sac/get_daily_pe.c index e6f2aa2c1..d30f3a0fa 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/sac/get_daily_pe.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/sac/get_daily_pe.c @@ -15,6 +15,8 @@ #include "models.h" +extern int days_of_month(int, int); + void get_daily_pe(int yr, int mon, int day, int npix, float *pe, float *pe_adj, float *pe_day) { diff --git a/lis/surfacemodels/land/rdhm.3.5.6/sac/get_ped.c b/lis/surfacemodels/land/rdhm.3.5.6/sac/get_ped.c index 65dca8f2b..80af81203 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/sac/get_ped.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/sac/get_ped.c @@ -16,6 +16,8 @@ #include "com_header.h" #include "models.h" +extern void get_daily_pe(int, int, int, int, float *, float *, float *); + void get_ped(int y, int m, int d, int npix, int dtm, float *pe, float *pe_adj, float *ped) { From 44fb0e5675682a8afba549568afb0a471cbca0b5 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 7 Nov 2023 13:56:27 -0500 Subject: [PATCH 201/328] Added alert files if problem occurs with preobs or presav2 file. --- lis/metforcing/usaf/USAF_GagesMod.F90 | 77 +++++++++++++++-- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 91 +++++++++++++++++--- lis/metforcing/usaf/USAF_getpcpobs.F90 | 4 +- 3 files changed, 150 insertions(+), 22 deletions(-) diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index e2825b5d4..365420470 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -1750,10 +1750,12 @@ subroutine USAF_gages_write_data(this, filename) end subroutine USAF_gages_write_data ! Read gage data from file. Acts as an alternative constructor. - subroutine USAF_gages_read_data(this, filename, date10) + subroutine USAF_gages_read_data(this, filename, date10, alert_number) ! Imports - use LIS_logMod, only: LIS_getNextUnitNumber, LIS_releaseUnitNumber + use LIS_coreMod, only: LIS_masterproc + use LIS_logMod, only: LIS_getNextUnitNumber, LIS_releaseUnitNumber, & + LIS_alert, LIS_logunit ! Defaults implicit none @@ -1762,6 +1764,7 @@ subroutine USAF_gages_read_data(this, filename, date10) class(USAF_gages_t), intent(out) :: this character(*), intent(in) :: filename character(10), intent(in) :: date10 + integer, intent(inout) :: alert_number ! Locals integer :: nobs @@ -1792,18 +1795,69 @@ subroutine USAF_gages_read_data(this, filename, date10) logical :: found integer :: i integer :: iunit + character(255) :: message(20) + message = '' call this%delete() ! Make sure structure is empty inquire(file=trim(filename), exist=found) - if (.not. found) return - + if (.not. found) then + write(LIS_logunit,*)'[WARN] Cannot find ', trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_data' + message(3) = ' Cannot find presav2 file ' // & + trim(filename) + message(4) = ' Observation count will be reduced' + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_data', & + alert_number, message) + alert_number = alert_number + 1 + end if + return + end if iunit = LIS_getNextUnitNumber() - open(iunit, file=trim(filename), iostat=istat, err=300) - read(iunit, *, iostat=istat, err=300, end=300) nobs + open(iunit, file=trim(filename), iostat=istat) + if (istat .ne. 0) then + write(LIS_logunit,*)'[WARN] Problem opening ', trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_gages_read_data' + message(3) = ' Cannot open file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_gages_read_data', & + alert_number, message) + alert_number = alert_number + 1 + end if + return + end if + + read(iunit, *, iostat=istat) nobs + if (istat .ne. 0) then + write(LIS_logunit,*)'[WARN] Problem reading ', trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_gages_read_data' + message(3) = ' Problem reading file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_gages_read_data', & + alert_number, message) + alert_number = alert_number + 1 + end if + close(iunit) + call LIS_releaseUnitNumber(iunit) + return + end if if (nobs .le. 0) then + write(LIS_logunit,*)'[WARN] No precip obs found in ', & + trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_gages_read_data' + message(3) = ' No precip obs found in file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_gages_read_data', & + alert_number, message) + alert_number = alert_number + 1 + end if close(iunit) call LIS_releaseUnitNumber(iunit) return @@ -1872,6 +1926,17 @@ subroutine USAF_gages_read_data(this, filename, date10) amts24, amts21, amts18, amts15, amts12, amts09, amts06, & amts03, amts02, amts01, & amts00, durations, preswx, pastwx) + else + write(LIS_logunit,*)'[WARN] Problem reading from ', & + trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_gages_read_data' + message(3) = ' Problem reading from file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_gages_read_data', & + alert_number, message) + alert_number = alert_number + 1 + end if end if ! Clean up diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index 0ab09134e..cf389335e 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -25,12 +25,14 @@ module USAF_PreobsReaderMod ! in database. subroutine USAF_read_preobs(preobsdir, presavdir, & use_timestamp, & - year, month, day, hour, use_expanded_station_ids) + year, month, day, hour, use_expanded_station_ids, & + alert_number) ! Imports use ESMF use LIS_coreMod, only: LIS_masterproc - use LIS_logMod, only: LIS_logunit + use LIS_logMod, only: LIS_logunit, LIS_alert, LIS_getNextUnitNumber, & + LIS_releaseUnitNumber use LIS_mpiMod, only: LIS_mpi_comm use USAF_GagesMod, only: USAF_Gages_t @@ -46,6 +48,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & integer, intent(in) :: day integer, intent(in) :: hour integer, intent(in) :: use_expanded_station_ids + integer, intent(inout) :: alert_number ! Locals character(255) :: filename @@ -110,6 +113,10 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & character(10) :: prevdate10 integer :: yyyy, mm, dd, h, m, s character(255) :: timestring + integer :: iunit + character(255) :: message(20) + + message = '' write(LIS_logunit,*)'---------------------------------------------' @@ -131,29 +138,72 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & inquire(file=trim(filename), exist=found_file) if (.not. found_file) then write(LIS_logunit,*) '[WARN] Cannot find ', trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_preobs' + message(3) = ' Cannot find file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_preobs', & + alert_number, message) + alert_number = alert_number + 1 + end if + if (use_expanded_station_ids == 1) exit ! These files are global cycle end if - open(22, file=trim(filename), status='old', iostat=ierr) + iunit = LIS_getNextUnitNumber() + open(iunit, file=trim(filename), status='old', iostat=ierr) if (ierr .ne. 0) then write(LIS_logunit,*) '[WARN] Problem opening ', trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_preobs' + message(3) = ' Cannot open file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_preobs', & + alert_number, message) + alert_number = alert_number + 1 + end if + if (use_expanded_station_ids == 1) exit ! These files are global cycle end if nsize = 0 - read(22, *, iostat=ierr) nsize + read(iunit, *, iostat=ierr) nsize if (ierr .ne. 0) then write(LIS_logunit,*) '[WARN] Problem reading ', trim(filename) - close(22) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_preobs' + message(3) = ' Problem reading file ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_preobs', & + alert_number, message) + alert_number = alert_number + 1 + end if + close(iunit) + call LIS_releaseUnitNumber(iunit) + if (use_expanded_station_ids == 1) exit ! These files are global cycle end if - write(LIS_logunit,*) '[INFO] Will process ', trim(filename) + if (nsize == 0) then + write(LIS_logunit,*)'[WARN] No precip obs found in ', & + trim(filename) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_preobs' + message(3) = ' No precip obs found in ' // trim(filename) + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_preobs', & + alert_number, message) + alert_number = alert_number + 1 + end if + else + write(LIS_logunit,*) '[INFO] Will process ', trim(filename) + end if nsize_total = nsize_total + nsize - close(22) + close(iunit) + call LIS_releaseUnitNumber(iunit) - if (use_expanded_station_ids == 1) cycle ! These files are global + if (use_expanded_station_ids == 1) exit ! These files are global end do if (nsize_total == 0) then @@ -213,13 +263,15 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & cycle end if - open(22, file=trim(filename), status='old', iostat=ierr) + iunit = LIS_getNextUnitNumber() + open(iunit, file=trim(filename), status='old', iostat=ierr) if (ierr .ne. 0) cycle nsize = 0 - read(22, *, iostat=ierr) nsize + read(iunit, *, iostat=ierr) nsize if (ierr .ne. 0) then - close(22) + close(iunit) + call LIS_releaseUnitNumber(iunit) if (use_expanded_station_ids == 1) exit cycle end if @@ -229,7 +281,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & if (use_expanded_station_ids == 1) then twfprc_tmp = MISSING sixprc_tmp = MISSING - read(22, 6001, iostat=ierr) YYYYMMDDhhmmss_tmp, & + read(iunit, 6001, iostat=ierr) YYYYMMDDhhmmss_tmp, & network_tmp, plat_id_tmp, ilat_tmp, ilon_tmp, & wmocode_id_tmp, fipscode_id_tmp, wmoblk_tmp, & mscprc_tmp, duration_tmp, pastwx_tmp, preswx_tmp @@ -238,7 +290,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & if (wmocode_id_tmp == " ") wmocode_id_tmp = "??" if (fipscode_id_tmp == " ") fipscode_id_tmp = "??" else - read(22, 6000, iostat=ierr) twfprc_tmp, duration_tmp, & + read(iunit, 6000, iostat=ierr) twfprc_tmp, duration_tmp, & sixprc_tmp, & mscprc_tmp, ilat_tmp, ilon_tmp, network_tmp, & plat_id_tmp, & @@ -651,7 +703,8 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & trim(presav_filename) write(prevdate10,'(i4.4,i2.2,i2.2,i2.2)') & prevyear, prevmonth, prevday, prevhour - call obsprev%read_data(presav_filename, prevdate10) + call obsprev%read_data(presav_filename, prevdate10, & + alert_number) if (deltahr == 3) then call obscur%reconcile_gages03(obsprev) else if (deltahr == 6) then @@ -673,6 +726,16 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & write(LIS_logunit,*) & '[WARN] Will skip reconciling with obs from ', & abs(deltahr),' hours ago' + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: USAF_read_preobs' + message(3) = ' Cannot find earlier presav2 file ' // & + trim(presav_filename) + message(4) = ' Observation count will be reduced' + if (LIS_masterproc) then + call LIS_alert('LIS.USAF_read_preobs', & + alert_number, message) + alert_number = alert_number + 1 + end if end if end do diff --git a/lis/metforcing/usaf/USAF_getpcpobs.F90 b/lis/metforcing/usaf/USAF_getpcpobs.F90 index 401d510f0..9046e5803 100644 --- a/lis/metforcing/usaf/USAF_getpcpobs.F90 +++ b/lis/metforcing/usaf/USAF_getpcpobs.F90 @@ -76,7 +76,7 @@ subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & call USAF_read_preobs(preobsdir, & trim(agrmet_struc(n)%analysisdir), & agrmet_struc(n)%use_timestamp, yr, mo, da, hr, & - use_expanded_station_ids) + use_expanded_station_ids, alert_number) ! If this is a synoptic time, read the presav2 file back in and ! populate the appropriate USAF_ObsData object. @@ -87,7 +87,7 @@ subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & if (file_exists) then write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & yr, mo, da, hr - call obscur%read_data(presav_filename, yyyymmddhh) + call obscur%read_data(presav_filename, yyyymmddhh, alert_number) if (.not. use_twelve) then call obscur%copy_to_usaf_obsdata(6, & agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & From a01370a38c2247c045d118dc48eff68429f8848e Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 8 Nov 2023 18:15:20 +0000 Subject: [PATCH 202/328] Temporarily disable call to vic411_read_vegparam in setup_vic411.c --- lis/surfacemodels/land/vic.4.1.1/setup_vic411.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c index eaec5d847..ac6505528 100644 --- a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c +++ b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c @@ -304,8 +304,10 @@ void FTN(setup_vic411)(int *NGRIDS, int *NTILES, if ( *vtscheme == VIC_BASED ) { /** Read Grid Cell Vegetation Parameters **/ + /* kluge vic411_lis_veg_con[t] = vic411_read_vegparam(vic411_filep.vegparam, vic411_lis_soil_con[t].gridcel, Nveg_type); + */ } else { From a35dd0e3db61846bf8a0c7fdd9f9d674c0957935 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 8 Nov 2023 18:18:37 +0000 Subject: [PATCH 203/328] Add function prototypes to address compiler error error: ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration] --- lis/surfacemodels/land/vic.4.1.1/setup_vic411.c | 4 ++++ lis/surfacemodels/land/vic.4.1.1/vic411_run.c | 3 +-- lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c | 2 ++ .../land/vic.4.1.2.l/physics/initialize_model_state.c | 2 ++ lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c | 2 ++ lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c | 4 ++++ lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c | 3 +-- lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c | 2 ++ lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c | 3 +++ 9 files changed, 21 insertions(+), 4 deletions(-) diff --git a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c index ac6505528..1a64140c2 100644 --- a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c +++ b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c @@ -17,6 +17,10 @@ #define VIC_BASED ( 0 ) #define LIS_BASED ( 1 ) +extern void vic411_lis_scan_soilparam_flat_ascii(FILE *, float *, float *); + +extern void vic411_compute_treeline_lis(double, double *, char *); + vic411_soil_con_struct vic411_lis_read_soilparam_arc(FILE *, char *, float *, float *); vic411_veg_con_struct *vic411_set_vegparam(int tile_idx, // index of current tile int vegclass, // vegetation class determined by LIS diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_run.c b/lis/surfacemodels/land/vic.4.1.1/vic411_run.c index f30fa281b..c41114f99 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_run.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_run.c @@ -18,8 +18,7 @@ #define VIC_BASED 0 /* VIC based tiling */ #define LIS_BASED 1 /* LIS based tiling */ -//extern void FTN(vic411_diagnoseoutputvar)(int, int, int, int, float, -// char *, char *); +extern void FTN(vic411_diagnoseoutputvar)(int *, int *, int *, int *, double *, char *, int *, char *, int *); //BOP // diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c index 0c0845779..a5e036a4f 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c @@ -14,6 +14,8 @@ #define BARETYPE ( 12 ) // UMD -- HARDCODED! +extern int vic411_read_vegparam(FILE *, int, int, int, vic411_veg_con_struct *); + int vic411_real_2_vic(int real_type, int Nveg_type) { extern vic411_veg_lib_struct *vic411_veg_lib; diff --git a/lis/surfacemodels/land/vic.4.1.2.l/physics/initialize_model_state.c b/lis/surfacemodels/land/vic.4.1.2.l/physics/initialize_model_state.c index a79475e00..d9a4e01e0 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/physics/initialize_model_state.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/physics/initialize_model_state.c @@ -5,6 +5,8 @@ static char vcid[] = "$Id$"; +extern void unpack_model_state(dist_prcp_struct *, global_param_struct *, int, int, int, soil_con_struct *, int, char *, int *, lake_con_struct, float *); + int initialize_model_state(dist_prcp_struct *prcp, dmy_struct dmy, global_param_struct *global_param, diff --git a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c index f1d3923ce..043efd7ea 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c @@ -14,6 +14,8 @@ #define BARETYPE ( 12 ) // UMD -- HARDCODED! +extern int vic412_read_vegparam(FILE *, int, int, int, veg_con_struct *); + int real_2_vic(int real_type, int Nveg_type) { extern veg_lib_struct *veg_lib; diff --git a/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c b/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c index 305cf4586..0d11b4f81 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c @@ -17,6 +17,10 @@ #define VIC_BASED ( 0 ) #define LIS_BASED ( 1 ) +extern void lis_scan_soilparam_flat_ascii(FILE *, float *, float *); + +extern void vic412_compute_treeline(double, double *, char *); + soil_con_struct *lis_soil_con; dmy_struct *dmy; atmos_data_struct **lis_atmos; diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c index eaa138800..f6e322776 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c @@ -18,8 +18,7 @@ #define VIC_BASED 0 /* VIC based tiling */ #define LIS_BASED 1 /* LIS based tiling */ -//extern void FTN(vic412_diagnoseoutputvar)(int, int, int, int, float, -// char *, char *); +extern void FTN(vic412_diagnoseoutputvar)(int *, int *, int *, int *, double *, char *, int *, char *, int *); //BOP // diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c index 81874bb5d..9830394a3 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c @@ -11,6 +11,8 @@ #include #include "ftn.h" +extern void write_atmosdata(atmos_data_struct *, int); + //BOP // // !ROUTINE: vic412_write_atmos diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c index 3a57c3e89..4fbd36c50 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c @@ -13,6 +13,9 @@ #include "ftn.h" #define VIC_BASED 0 /** VIC based vegetation tiling Added by Shugong Wang on 05/01/2012 **/ #define LIS_BASED 1 /** LIS based vegetation tiling Added by Shugong Wang on 05/01/2012 **/ + +extern void pack_model_state(dist_prcp_struct *, global_param_struct *, int, int, filep_struct *, soil_con_struct *, char *, int *, float *, int *); + //BOP // // !ROUTINE: vic412_write_state From 35bb01e294cc0021bd51fd72d2e46fe1a8c91444 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 8 Nov 2023 13:45:27 -0500 Subject: [PATCH 204/328] Added support for new (WIGOS-friendly) sfcobs files. --- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 1 + lis/metforcing/usaf/AGRMET_getsfc.F90 | 404 +++++++++++++--------- lis/metforcing/usaf/AGRMET_sfcalc.F90 | 8 +- lis/metforcing/usaf/readcrd_agrmet.F90 | 29 ++ 4 files changed, 286 insertions(+), 156 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index 18873b19d..9bc120d2c 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -353,6 +353,7 @@ module AGRMET_forcingMod real*8 :: cmortime integer :: pcpobswch integer :: pcpobsfmt ! EMK...File format for precip obs + integer :: sfcobsfmt ! EMK...File format for sfcobs integer :: pwswch integer :: raswch integer :: cdfs2swch diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index 7db822acb..fb0ae5de3 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -40,20 +40,23 @@ ! 25 Jun 20 Modified to check valid times of surface obs. ! ..............................Eric Kemp/NASA/SSAI ! 16 Dec 21 Replaced julhr with YYYYMMDDHH in log...Eric Kemp/NASA/SSAI +! 07 Nov 23 Added new sfcobs format.......Eric Kemp/NASA/SSAI ! ! !INTERFACE: subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ri, rj, obstmp, obsrlh, obsspd, obscnt, & isize, minwnd, alert_number, imax, jmax, rootdir,cdmsdir,& - use_timestamp) + use_timestamp, use_wigos_sfcobs) ! !USES: + use ESMF ! EMK Patch for DTG check use AGRMET_forcingMod, only : agrmet_struc use LIS_coreMod, only : LIS_domain, LIS_masterproc use LIS_timeMgrMod, only : LIS_julhr_date - use LIS_logMod, only : LIS_logunit, LIS_alert + use LIS_logMod, only : LIS_logunit, LIS_alert, & + LIS_getNextUnitNumber, LIS_releaseUnitNumber use map_utils, only : latlon_to_ij use USAF_bratsethMod, only: USAF_ObsData, USAF_assignObsData - use ESMF ! EMK Patch for DTG check + implicit none ! !ARGUMENTS: @@ -76,6 +79,7 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & character(len=*) :: rootdir character(len=*) :: cdmsdir integer, intent(in) :: use_timestamp + logical, intent(in) :: use_wigos_sfcobs ! ! !DESCRIPTION: ! @@ -220,11 +224,14 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & character*10 :: date10 ! EMK replace cjulhr in log character*14, allocatable :: dtg ( : ) character*100 :: message ( 20 ) - character*8, allocatable :: netyp ( : ) + !character*8, allocatable :: netyp ( : ) + character*9, allocatable :: netyp ( : ) character*8 :: norsou ( 2 ) ! character*8, allocatable :: platform ( : ) - character*9, allocatable :: platform ( : ) ! EMK BUG FIX - character*8, allocatable :: rptyp ( : ) + !character*9, allocatable :: platform ( : ) ! EMK BUG FIX + character*32, allocatable :: platform ( : ) ! EMK WIGOS + !character*8, allocatable :: rptyp ( : ) + character*9, allocatable :: rptyp ( : ) ! WIGOS logical, allocatable :: skip (:) ! EMK real :: rlat real :: rlon @@ -245,8 +252,12 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & real, external :: AGRMET_calcrh_dpt !character(len=10) :: net10, platform10 + character(len=8) :: netyp8 + character(len=9) :: platform9 character(len=32) :: net32, platform32 + character(len=8) :: rptyp8 character*32, parameter :: blank32 = " " + integer :: iunit data norsou / 'NORTHERN', 'SOUTHERN' / @@ -295,12 +306,14 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & skip(:) = .false. ! EMK call getsfcobsfilename(sfcobsfile, rootdir, cdmsdir, & - use_timestamp,hemi, yr, mo, da, hr) - - write(LIS_logunit,*)'Reading OBS: ',trim(sfcobsfile) - open(22,file=trim(sfcobsfile),status='old', iostat=ierr1) - if(ierr1.eq.0) then - read(22,*, iostat=ierr2) nsize + use_timestamp,hemi, yr, mo, da, hr, use_wigos_sfcobs) + + write(LIS_logunit,*)'[INFO] Reading OBS: ',trim(sfcobsfile) + + iunit = LIS_getNextUnitNumber() + open(iunit,file=trim(sfcobsfile),status='old', iostat=ierr1) + if(ierr1.eq.0) then + read(iunit,*, iostat=ierr2) nsize ! ------------------------------------------------------------------ ! If the number of obs in the file is greater than the array size @@ -324,9 +337,25 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & end if do i=1,nsize - read(22,*, iostat=ierr3) platform(i), dtg(i), & - itmp(i), idpt(i), irelh(i), ilat(i), ilon(i), & - ispd(i), rptyp(i), netyp(i) + if (.not. use_wigos_sfcobs) then + !read(iunit, *, iostat=ierr3) platform(i), dtg(i), & + ! itmp(i), idpt(i), irelh(i), ilat(i), ilon(i), & + ! ispd(i), rptyp(i), netyp(i) + read(iunit, *, iostat=ierr3) platform9, dtg(i), & + itmp(i), idpt(i), irelh(i), ilat(i), ilon(i), & + ispd(i), rptyp8, netyp8 + if (ierr3 == 0) then + platform(i) = platform9 + rptyp(i) = rptyp8 + netyp(i) = netyp8 + end if + else + read(iunit, 1000, iostat=ierr3) platform(i), dtg(i), & + itmp(i), idpt(i), irelh(i), ilat(i), ilon(i), & + ispd(i), rptyp(i), netyp(i) +1000 format(a32, 1x, a14, 1x, i9, 1x, i9, 1x, i9, 1x, & + i9, 1x, i9, 1x, i9, 1x, a9, 1x, a9) + end if !if (ierr3 .ne. 0) skip(i) = .true. ! EMK ! EMK Patch Skip report if problem occurred reading it @@ -369,7 +398,8 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & end if enddo - close(22) + close(iunit) + call LIS_releaseUnitNumber(iunit) !if(ierr2.eq.0.and.ierr3.eq.0) then ! EMK Patch...Allow observation storage even if problem occurred @@ -402,20 +432,21 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! ------------------------------------------------------------------ ! Only process the observations for the current hemisphere. ! ------------------------------------------------------------------ - + + ! EMK...Use all obs if we are using a WIGOS global file if( ((hemi .eq. 1) .and. (rlat .ge. 0.0)) .or. & - ((hemi .eq. 2) .and. (rlat .lt. 0.0)) ) then + ((hemi .eq. 2) .and. (rlat .lt. 0.0)) .or. & + use_wigos_sfcobs) then ! ------------------------------------------------------------------ ! Convert point's lat/lon to i/j coordinates. ! check for values of rigrid and rjgrid outside of ! the AGRMET model grid, or in the other hemisphere. ! ------------------------------------------------------------------ - call latlon_to_ij(LIS_domain(n)%lisproj, rlat, rlon, & rigrid, rjgrid) -! if(rigrid.ge.1.and.rigrid.le.imax.and. & + !if(rigrid.ge.1.and.rigrid.le.imax.and. & ! rjgrid.ge.1.and.rjgrid.le.jmax) then ! EMK TEST if (.true.) then @@ -426,16 +457,16 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! observations had to be discared for this reason. ! ------------------------------------------------------------------ - if ( ( (itmp(irecord) .gt. -99999998) .and. & - (ispd(irecord) .gt. -99999998) ) .and. & - ( (irelh(irecord) .gt. -99999998) .or. & - (idpt(irecord) .gt. -99999998) ) ) then - - ! EMK...Make sure dew point .le. temperature - if ( (itmp(irecord) .gt. -99999998) .and. & - (idpt(irecord) .gt. -99999998) ) then - if (idpt(irecord) .gt. itmp(irecord)) cycle - end if + if ( ( (itmp(irecord) .gt. -99999998) .and. & + (ispd(irecord) .gt. -99999998) ) .and. & + ( (irelh(irecord) .gt. -99999998) .or. & + (idpt(irecord) .gt. -99999998) ) ) then + + ! EMK...Make sure dew point .le. temperature + if ( (itmp(irecord) .gt. -99999998) .and. & + (idpt(irecord) .gt. -99999998) ) then + if (idpt(irecord) .gt. itmp(irecord)) cycle + end if ! ------------------------------------------------------------------ ! Gross error check and set temperature. @@ -445,14 +476,14 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! so the Barnes scheme will ignore it. ! ------------------------------------------------------------------ - if (itmp(irecord) .gt. -99999998) then - rtmp = float (itmp(irecord)) / 100.0 - if ( (rtmp .lt. 200.0) .or. (rtmp .gt. 350.0) ) then + if (itmp(irecord) .gt. -99999998) then + rtmp = float (itmp(irecord)) / 100.0 + if ( (rtmp .lt. 200.0) .or. (rtmp .gt. 350.0) ) then + rtmp = -1.0 + end if + else rtmp = -1.0 end if - else - rtmp = -1.0 - end if ! ------------------------------------------------------------------ ! Gross error check and set relative humidity values. @@ -461,21 +492,21 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! value of -1, so the Barnes scheme will ignore it. ! ------------------------------------------------------------------ - if (irelh(irecord) .gt. -99999998) then - rrelh = float(irelh(irecord)) / 10000.0 - if ( (rrelh .gt. 1.0) .or. (rrelh .lt. 0.0) ) then - rrelh = -1.0 - end if - else if ( (idpt(irecord) .gt. -99999998) .and. & - (rtmp .ne. -1.0) ) then - rdpt = float(idpt(irecord)) / 100.0 - rrelh = AGRMET_calcrh_dpt(rtmp, rdpt) - if ( (rrelh .gt. 1.0) .or. (rrelh .lt. 0.0) ) then + if (irelh(irecord) .gt. -99999998) then + rrelh = float(irelh(irecord)) / 10000.0 + if ( (rrelh .gt. 1.0) .or. (rrelh .lt. 0.0) ) then + rrelh = -1.0 + end if + else if ( (idpt(irecord) .gt. -99999998) .and. & + (rtmp .ne. -1.0) ) then + rdpt = float(idpt(irecord)) / 100.0 + rrelh = AGRMET_calcrh_dpt(rtmp, rdpt) + if ( (rrelh .gt. 1.0) .or. (rrelh .lt. 0.0) ) then + rrelh = -1.0 + end if + else rrelh = -1.0 end if - else - rrelh = -1.0 - end if ! ------------------------------------------------------------------ ! Constrain surface wind speed to a value between @@ -484,103 +515,114 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! of -1, so the Barnes scheme will ignore it. ! ------------------------------------------------------------------ - if (ispd(irecord) .gt. -99999998) then - rspd = float(ispd(irecord)) / 10.0 - rspd = max( min( rspd, 75.0 ), minwnd ) - else - rspd = -1.0 - end if - + if (ispd(irecord) .gt. -99999998) then + rspd = float(ispd(irecord)) / 10.0 + rspd = max( min( rspd, 75.0 ), minwnd ) + else + rspd = -1.0 + end if + ! ------------------------------------------------------------------ ! If all the data is out of range and/or missing, don't store ! this observation. ! ------------------------------------------------------------------ - if ( (nint(rtmp) .gt. 0) .and. & - (nint(rrelh) .gt. 0) .and.& - (nint(rspd) .gt. 0) ) then - + if ( (nint(rtmp) .gt. 0) .and. & + (nint(rrelh) .gt. 0) .and.& + (nint(rspd) .gt. 0) ) then + ! ------------------------------------------------------------------ ! If we make it here, the observation probably has some good ! data, so increment the observation counter, store the ! data into the observation arrays. ! ------------------------------------------------------------------ - ! EMK...Add to data structures. Handle reformated - ! CDMS data that is missing platform and network - if (rtmp .gt. 0) then - net32 = blank32 - net32 = netyp(irecord) - platform32 = blank32 - platform32 = platform(irecord) - if (trim(net32) .eq. 'NULL') then - net32 = 'CDMS' - end if - if (trim(platform32) .eq. '-99999999') then - platform32 = '00000000' - end if - call USAF_assignObsData(t2mObs,net32, & - platform32,rtmp,rlat,rlon, & - agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr,& - 0.) + ! EMK...Add to data structures. Handle reformated + ! CDMS data that is missing platform and network + if (rtmp .gt. 0) then + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' + end if + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' + end if + call USAF_assignObsData(t2mObs,net32, & + platform32,rtmp,rlat,rlon, & + agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr,& + 0.) - end if - if (rrelh .gt. 0) then - net32 = blank32 - net32 = netyp(irecord) - platform32 = blank32 - platform32 = platform(irecord) - if (trim(net32) .eq. 'NULL') then - net32 = 'CDMS' - end if - if (trim(platform32) .eq. '-99999999') then - platform32 = '00000000' end if - call USAF_assignObsData(rh2mObs,net32, & - platform32,rrelh,rlat,rlon, & - agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr, & - 0.) - end if - if (rspd .gt. 0) then - net32 = blank32 - net32 = netyp(irecord) - platform32 = blank32 - platform32 = platform(irecord) - if (trim(net32) .eq. 'NULL') then - net32 = 'CDMS' + if (rrelh .gt. 0) then + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' + end if + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' + end if + call USAF_assignObsData(rh2mObs,net32, & + platform32,rrelh,rlat,rlon, & + agrmet_struc(n)%bratseth_t2m_stn_sigma_o_sqr, & + 0.) end if - if (trim(platform32) .eq. '-99999999') then - platform32 = '00000000' + if (rspd .gt. 0) then + net32 = blank32 + net32 = netyp(irecord) + platform32 = blank32 + platform32 = platform(irecord) + if (trim(net32) .eq. 'NULL') then + net32 = 'CDMS' + end if + if (trim(platform32) .eq. '-99999999') then + platform32 = '00000000' + end if + call USAF_assignObsData(spd10mObs,net32, & + platform32,rspd,rlat,rlon, & + agrmet_struc(n)%bratseth_spd10m_stn_sigma_o_sqr, & + 0.) end if - call USAF_assignObsData(spd10mObs,net32, & - platform32,rspd,rlat,rlon, & - agrmet_struc(n)%bratseth_spd10m_stn_sigma_o_sqr, & - 0.) - end if + obscnt = obscnt + 1 - obscnt = obscnt + 1 - - ri(obscnt) = rigrid - rj(obscnt) = rjgrid - obstmp(obscnt) = rtmp - obsrlh(obscnt) = rrelh - obsspd(obscnt) = rspd - if(rspd.lt.0) then - print*, 'probl ',rlat,rlon, rspd + ri(obscnt) = rigrid + rj(obscnt) = rjgrid + obstmp(obscnt) = rtmp + obsrlh(obscnt) = rrelh + obsspd(obscnt) = rspd + !if(rspd.lt.0) then + ! print*, 'probl ',rlat,rlon, rspd + !endif endif - endif ! ------------------------------------------------------------------ ! If we have reached the number of obs that our hard-wired ! arrays can hold, then exit the loop. ! ------------------------------------------------------------------ - if ( obscnt .eq. isize ) exit + if ( obscnt .eq. isize ) then + write(LIS_logunit,*) & + '[WARN] ROUTINE GETSFC: REACHED MAXIMUM NUMBER OF SFC OBS TO SAVE IN MEMORY' + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' reached maximum number of sfc obs to save memory in memory' + alert_number = alert_number + 1 + if(LIS_masterproc) then + call lis_alert( 'sfcalc ', alert_number, & + message ) + endif + exit ! Jump out of hemi do loop + end if + endif endif endif - endif - enddo - else + enddo + else ! ------------------------------------------------------------------ ! There was an error retrieving obs for this Julhr and hemi. ! Send an alert message, but don't abort. @@ -588,51 +630,82 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! EMK...Replace julhr with YYYYMMDD !write(cjulhr,'(i6)',iostat=istat1) julhr - write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) yr, mo, da, hr + write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & + yr, mo, da, hr write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*)'- THE '//norsou(hemi)//' HEMISPHERE.' - write(LIS_logunit,*)'- ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the '//norsou(hemi)//' hemisphere.' + if (use_wigos_sfcobs) then + write(LIS_logunit,*) & + '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' + write(LIS_logunit,*)'[WARN] THE GLOBE' + write(LIS_logunit,*)'[WARN} ISTAT IS ', ierr1 + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' error retrieving sfc obs from database for' + message(4) = ' the globe' + else + write(LIS_logunit,*) & + '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' + write(LIS_logunit,*) & + '[WARN] THE '//norsou(hemi)//' HEMISPHERE.' + write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' error retrieving sfc obs from database for' + message(4) = ' the '//norsou(hemi)//' hemisphere.' + end if if( istat1 .eq. 0 ) then ! EMK...Replace julhr with YYYYMMDD !write(LIS_logunit,*)'- JULHR IS ' // cjulhr !message(5) = ' julhr is ' // trim(cjulhr) // '.' - write(LIS_logunit,*)' - YYYYMMDDHH is ' // date10 + write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 message(5) = ' yyyymmddhh is ' // trim(date10) // '.' endif alert_number = alert_number + 1 - if(LIS_masterproc) then - call lis_alert( 'sfcalc ', alert_number, message ) + if(LIS_masterproc) then + call lis_alert( 'sfcalc ', alert_number, & + message ) endif endif else ! EMK...Replace julhr with YYYYMMDD !write(cjulhr,'(i6)',iostat=istat1) julhr - write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) yr, mo, da, hr - write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- ROUTINE AGRMET_GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*)'- THE '//norsou(hemi)//' HEMISPHERE.' - write(LIS_logunit,*)'- ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the '//norsou(hemi)//' hemisphere.' + write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & + yr, mo, da, hr + if (use_wigos_sfcobs) then + write(LIS_logunit,*)' ' + write(LIS_logunit,*) & + '[WARN] ROUTINE AGRMET_GETSFC: ERROR RETRIEVING SFC OBS FOR' + write(LIS_logunit,*)'[WARN] THE GLOBE' + write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' error retrieving sfc obs from database for' + message(4) = ' the globe.' + else + write(LIS_logunit,*)' ' + write(LIS_logunit,*) & + '[WARN] ROUTINE AGRMET_GETSFC: ERROR RETRIEVING SFC OBS FOR' + write(LIS_logunit,*)'[WARN] THE '//norsou(hemi)//' HEMISPHERE.' + write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' error retrieving sfc obs from database for' + message(4) = ' the '//norsou(hemi)//' hemisphere.' + end if if( istat1 .eq. 0 ) then ! EMK...Replace julhr with YYYYMMDDHH !write(LIS_logunit,*)'- JULHR IS ' // cjulhr !message(5) = ' julhr is ' // trim(cjulhr) // '.' - write(LIS_logunit,*)' - YYYYMMDDHH is ' // date10 + write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 message(5) = ' yyyymmddhh is ' // trim(date10) // '.' endif alert_number = alert_number + 1 - if(LIS_masterproc) then + if(LIS_masterproc) then call lis_alert( 'sfcalc ', alert_number, message ) endif endif + + if (use_wigos_sfcobs) exit ! New sfcobs file is global enddo deallocate ( idpt ) @@ -647,6 +720,8 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & deallocate ( rptyp ) deallocate(skip) ! EMK + + write(LIS_logunit,*)'[INFO] Stored ', obscnt, ' sfc obs' end subroutine AGRMET_getsfc !BOP @@ -656,15 +731,18 @@ end subroutine AGRMET_getsfc ! ! !INTERFACE: subroutine getsfcobsfilename(filename, rootdir, dir, & - use_timestamp, hemi, yr,mo,da,hr) + use_timestamp, hemi, yr, mo, da, hr, use_wigos_sfcobs) implicit none + ! !ARGUMENTS: - character(len=*) :: filename - character(len=*) :: rootdir - character(len=*) :: dir - integer, intent(in) :: yr,mo,da,hr, hemi + character(len=*), intent(inout) :: filename + character(len=*), intent(in) :: rootdir + character(len=*), intent(in) :: dir integer, intent(in) :: use_timestamp + integer, intent(in) :: hemi + integer, intent(in) :: yr, mo, da, hr + logical, intent(in) :: use_wigos_sfcobs ! ! !DESCRIPTION: ! This routines generates the name of the surface obs file @@ -708,14 +786,30 @@ subroutine getsfcobsfilename(filename, rootdir, dir, & write(unit=fhemi,fmt='(a2)') 'sh' endif - if(use_timestamp.eq.1) then - filename = trim(rootdir)//'/'//trim(fyr)//trim(fmo)//trim(fda)//& - '/'//trim(dir)//'/sfcobs_'& - //trim(fhemi)//'.01hr.'//trim(fyr)//trim(fmo)//trim(fda)//trim(fhr) + if(use_timestamp.eq.1) then + if (use_wigos_sfcobs) then + filename = trim(rootdir) // '/' // & + trim(fyr) // trim(fmo) // trim(fda) // & + '/' // trim(dir) // '/sfcobs_01hr_' // & + trim(fyr) // trim(fmo) // trim(fda) // trim(fhr) // ".txt" + else + filename = trim(rootdir) // '/' // & + trim(fyr) // trim(fmo) // trim(fda) // & + '/' // trim(dir) // '/sfcobs_' // & + trim(fhemi) // '.01hr.' // & + trim(fyr) // trim(fmo) // trim(fda) // trim(fhr) + end if else - filename = trim(rootdir)//& - '/'//trim(dir)//'/sfcobs_'& - //trim(fhemi)//'.01hr.'//trim(fyr)//trim(fmo)//trim(fda)//trim(fhr) + if (use_wigos_sfcobs) then + filename = trim(rootdir) // & + '/' // trim(dir) // '/sfcobs_01hr_' // & + trim(fyr) // trim(fmo) // trim(fda) // trim(fhr) // ".txt" + else + filename = trim(rootdir) // & + '/' // trim(dir) // '/sfcobs_' // & + trim(fhemi) // '.01hr.' // & + trim(fyr) // trim(fmo) // trim(fda) // trim(fhr) + end if endif end subroutine getsfcobsfilename diff --git a/lis/metforcing/usaf/AGRMET_sfcalc.F90 b/lis/metforcing/usaf/AGRMET_sfcalc.F90 index cdc6d54e5..4ac2ea02a 100644 --- a/lis/metforcing/usaf/AGRMET_sfcalc.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcalc.F90 @@ -180,6 +180,7 @@ subroutine AGRMET_sfcalc(n) logical :: found_inq integer :: rc integer, external :: LIS_create_subdirs + logical :: use_wigos_sfcobs data lokspd / 15, 25, 30, 40, 50 / data lokrlh / 10, 15, 25, 35, 40 / @@ -486,12 +487,17 @@ subroutine AGRMET_sfcalc(n) call USAF_createObsData(spd10mObs, n, & maxobs=agrmet_struc(n)%max_sfcobs) + if (agrmet_struc(n)%sfcobsfmt == 1) then + use_wigos_sfcobs = .false. + else + use_wigos_sfcobs = .true. + end if call AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ri, rj, obstmp, obsrlh, obsspd, & obscnt, agrmet_struc(n)%max_sfcobs, agrmet_struc(n)%minwnd, & alert_number, LIS_rc%lnc(n), LIS_rc%lnr(n),& agrmet_struc(n)%agrmetdir,agrmet_struc(n)%cdmsdir,& - agrmet_struc(n)%use_timestamp) + agrmet_struc(n)%use_timestamp, use_wigos_sfcobs) ! call MPI_Barrier(LIS_mpi_comm, ierr) ! stop diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 8499f43bd..3a506f729 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -224,6 +224,35 @@ subroutine readcrd_agrmet() end if enddo + ! EMK...Sfc observation file formats + call ESMF_ConfigFindLabel(LIS_config,"AGRMET sfc obs file format:", & + rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + agrmet_struc(n)%sfcobsfmt, rc=rc) + if (agrmet_struc(n)%sfcobsfmt .ne. 1 .and. & + agrmet_struc(n)%sfcobsfmt .ne. 2) then + write(LIS_logunit,*) & + "[ERR] Bad 'AGRMET sfc obs file format:' option" + write(LIS_logunit,*) & + '[ERR] Expected 1 or 2, found ', agrmet_struc(n)%sfcobsfmt + write(LIS_logunit,*) '[ERR] Aborting...' + + flush(LIS_logunit) + message(1) = & + '[ERR] Illegal value for AGRMET sfc obs file format' +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) +#endif + if (LIS_masterproc) then + call LIS_abort(message) + else + call sleep(10) + call LIS_endrun() + end if + end if + enddo + call ESMF_ConfigFindLabel(LIS_config,"AGRMET native imax:",rc=rc) do n=1,LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,agrmet_struc(n)%imaxnative,rc=rc) From 24d28f62d5031e2e317d2efc7664357f10fea3ea Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 8 Nov 2023 19:51:18 +0000 Subject: [PATCH 205/328] Restore original version of vic411_read_vegparam.c --- .../{vic411_read_vegparam.c.origin => vic411_read_vegparam.c} | 0 .../{vic411_read_vegparam.c => vic411_read_vegparam_lis.c} | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename lis/surfacemodels/land/vic.4.1.1/physics/{vic411_read_vegparam.c.origin => vic411_read_vegparam.c} (100%) rename lis/surfacemodels/land/vic.4.1.1/{vic411_read_vegparam.c => vic411_read_vegparam_lis.c} (100%) diff --git a/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c.origin b/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c similarity index 100% rename from lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c.origin rename to lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam.c b/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c similarity index 100% rename from lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam.c rename to lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c From 4c14b2617e7649ae9b56b84f11a439154bc6b6e0 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 8 Nov 2023 20:38:32 +0000 Subject: [PATCH 206/328] Restore vic411_read_vegparam Use vic411_read_vegparam with the VIC tiling scheme. Use vic411_read_vegparam_lis with the LIS tiling scheme. See 'VIC411 veg tiling scheme:' in the LIS Users' Guide. --- .../land/vic.4.1.1/physics/vic411_read_vegparam.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/physics/vic411_vicNl.h | 2 +- lis/surfacemodels/land/vic.4.1.1/setup_vic411.c | 2 -- lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c | 4 ++-- 5 files changed, 7 insertions(+), 9 deletions(-) diff --git a/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c b/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c index b50986ec4..a87371872 100644 --- a/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.1/physics/vic411_read_vegparam.c @@ -359,7 +359,7 @@ vic411_veg_con_struct *vic411_read_vegparam(FILE *vegparam, - +#if 0 /* trim trailing newlines */ #define END '\0' @@ -372,4 +372,4 @@ void vic411_ttrim( char *c ) for( ; *--c == NEW; *c = END ); } - +#endif diff --git a/lis/surfacemodels/land/vic.4.1.1/physics/vic411_vicNl.h b/lis/surfacemodels/land/vic.4.1.1/physics/vic411_vicNl.h index 72507a592..e04da3738 100644 --- a/lis/surfacemodels/land/vic.4.1.1/physics/vic411_vicNl.h +++ b/lis/surfacemodels/land/vic.4.1.1/physics/vic411_vicNl.h @@ -395,7 +395,7 @@ void read_snowmodel(vic411_atmos_data_struct *, FILE *, int, int, int, int); vic411_soil_con_struct vic411_read_soilparam(FILE *, int); //vic411_soil_con_struct vic411_read_soilparam_arc(FILE *, char *, int *, int *, int); vic411_veg_lib_struct *vic411_read_veglib(FILE *, int *); -// vic411_veg_con_struct *vic411_read_vegparam(FILE *, int, int); +vic411_veg_con_struct *vic411_read_vegparam(FILE *, int, int); int vic411_redistribute_during_storm(vic411_cell_data_struct ***, vic411_veg_var_struct ***, int, int, int, double, double, double, double *); diff --git a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c index 1a64140c2..b7fabf560 100644 --- a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c +++ b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c @@ -308,10 +308,8 @@ void FTN(setup_vic411)(int *NGRIDS, int *NTILES, if ( *vtscheme == VIC_BASED ) { /** Read Grid Cell Vegetation Parameters **/ - /* kluge vic411_lis_veg_con[t] = vic411_read_vegparam(vic411_filep.vegparam, vic411_lis_soil_con[t].gridcel, Nveg_type); - */ } else { diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c b/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c index c89ba26df..e02ca8bfb 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c @@ -13,9 +13,9 @@ #include "vic411_vicNl.h" #include -static char vcid[] = "$Id: vic411_read_vegparam.c,v 4.5.2.11 2009/10/01 21:12:16 vicadmin Exp $"; +static char vcid[] = "$Id: vic411_read_vegparam_lis.c,v 4.5.2.11 2009/10/01 21:12:16 vicadmin Exp $"; // shugong: if cannot find entry for the gridid+vegetation class, return 0, other return 1 -int vic411_read_vegparam(FILE *vegparam, +int vic411_read_vegparam_lis(FILE *vegparam, int gridcel, int Nveg_type, int lis_veg_class, diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c index a5e036a4f..cfe7e8c04 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c @@ -14,7 +14,7 @@ #define BARETYPE ( 12 ) // UMD -- HARDCODED! -extern int vic411_read_vegparam(FILE *, int, int, int, vic411_veg_con_struct *); +extern int vic411_read_vegparam_lis(FILE *, int, int, int, vic411_veg_con_struct *); int vic411_real_2_vic(int real_type, int Nveg_type) { @@ -361,7 +361,7 @@ vic411_veg_con_struct *vic411_set_vegparam(int tile_idx, depth_sum = 0; // added by Shugong Wang to read in root zone information and update vic411_lis_veg_lib - vic411_flag = vic411_read_vegparam(fp_vegparam, gridcel , Nveg_type, vegclass, &(temp[i])); + vic411_flag = vic411_read_vegparam_lis(fp_vegparam, gridcel , Nveg_type, vegclass, &(temp[i])); if(vic411_flag==0) // cannot find veg parameters { // Since root zones are not defined they are copied from the last From f69fcbddb05ed7f8120c4e5798b6a6891126102b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 9 Nov 2023 21:33:38 +0000 Subject: [PATCH 207/328] Removed two debug flags rejected by new Intel ICX compiler. This is to allow compiling with debugging on Narwhal. --- lis/arch/Config.pl | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index c26605256..1d954cc1e 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -165,9 +165,11 @@ $sys_c_opt .= " -Wunused-function -Wunused-parameter"; $sys_c_opt .= " -Wunused-variable -Wwrite-strings"; # Run-time flags - $sys_c_opt .= " -check=conversions,stack,uninit"; + #EMK 20231109...Disabled several flags that are rejected by the new ICX + #compiler on Narwhal. + #$sys_c_opt .= " -check=conversions,stack,uninit"; $sys_c_opt .= " -fp-stack-check -fp-trap=common -fp-trap-all=common"; - $sys_c_opt .= " -ftrapuv"; + #$sys_c_opt .= " -ftrapuv"; } elsif($sys_arch eq "linux_pgi") { print "Optimization level $opt_lev is not defined for $sys_arch.\n"; From 724760af31bc658ae3663d60396b22c2264dea54 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 09:36:53 -0500 Subject: [PATCH 208/328] Added alert files for problems with sfcobs files. --- lis/metforcing/usaf/AGRMET_getsfc.F90 | 213 ++++++++++++++++---------- 1 file changed, 129 insertions(+), 84 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index fb0ae5de3..07e992e2b 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -258,9 +258,12 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & character(len=8) :: rptyp8 character*32, parameter :: blank32 = " " integer :: iunit + logical :: found_file data norsou / 'NORTHERN', 'SOUTHERN' / + message = '' + ! ------------------------------------------------------------------ ! Executable code begins here. Intialize observation counter to 0. ! ------------------------------------------------------------------ @@ -308,20 +311,76 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & call getsfcobsfilename(sfcobsfile, rootdir, cdmsdir, & use_timestamp,hemi, yr, mo, da, hr, use_wigos_sfcobs) - write(LIS_logunit,*)'[INFO] Reading OBS: ',trim(sfcobsfile) + inquire(file=trim(sfcobsfile), exist=found_file) + if (.not. found_file) then + write(LIS_logunit,*) '[WARN] Cannot find ', trim(sfcobsfile) + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: AGRMET_getsfc' + message(3) = ' Cannot find file ' // trim(sfcobsfile) + if (LIS_masterproc) then + call LIS_alert('LIS.AGRMET_getsfc', & + alert_number, message) + alert_number = alert_number + 1 + end if + message = '' + if (use_wigos_sfcobs) exit ! These files are global + cycle + end if + write(LIS_logunit,*)'[INFO] Opening: ',trim(sfcobsfile) iunit = LIS_getNextUnitNumber() open(iunit,file=trim(sfcobsfile),status='old', iostat=ierr1) + + if (ierr1 .ne. 0) then + write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & + yr, mo, da, hr + write(LIS_logunit,*)' ' + write(LIS_logunit,*) & + '[WARN] ROUTINE AGRMET_GETSFC: ERROR OPENING ', & + trim(sfcobsfile) + write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' error opening file ' // trim(sfcobsfile) + alert_number = alert_number + 1 + if(LIS_masterproc) then + call lis_alert( 'LIS.AGRMET_getsfc', alert_number, message ) + endif + message = '' + if (use_wigos_sfcobs) exit ! New WIGOS version is global + cycle + endif + if(ierr1.eq.0) then read(iunit,*, iostat=ierr2) nsize - + + if (ierr2 .ne. 0) then + write(LIS_logunit,*) & + '[WARN] Problem reading total report count from ', & + trim(sfcobsfile) + message(1) = 'program: LIS' + message(2) = ' routine: AGRMET_getsfc' + message(3) = ' Cannot read total report count from ' // & + trim(sfcobsfile) + alert_number = alert_number + 1 + if(LIS_masterproc) then + call lis_alert( 'LIS.AGRMET_getsfc', alert_number, & + message ) + endif + message = '' + close(iunit) + call LIS_releaseUnitNumber(iunit) + if (use_wigos_sfcobs) exit + cycle + end if + ! ------------------------------------------------------------------ ! If the number of obs in the file is greater than the array size ! write an alert to the log and set back the number to read to ! prevent a segfault. ! ------------------------------------------------------------------ - if ( nsize .GT. isize ) then + if ( nsize .GT. isize ) then write(LIS_logunit,*)' ' write(LIS_logunit,*)"******************************************************" @@ -613,96 +672,82 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & message(3) = ' reached maximum number of sfc obs to save memory in memory' alert_number = alert_number + 1 if(LIS_masterproc) then - call lis_alert( 'sfcalc ', alert_number, & + call lis_alert( 'LIS.AGRMET_getsfc', & + alert_number, & message ) endif + message = '' exit ! Jump out of hemi do loop end if endif endif endif enddo - else -! ------------------------------------------------------------------ -! There was an error retrieving obs for this Julhr and hemi. -! Send an alert message, but don't abort. -! ------------------------------------------------------------------ - - ! EMK...Replace julhr with YYYYMMDD - !write(cjulhr,'(i6)',iostat=istat1) julhr - write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & - yr, mo, da, hr - write(LIS_logunit,*)' ' - if (use_wigos_sfcobs) then - write(LIS_logunit,*) & - '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*)'[WARN] THE GLOBE' - write(LIS_logunit,*)'[WARN} ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the globe' - else - write(LIS_logunit,*) & - '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*) & - '[WARN] THE '//norsou(hemi)//' HEMISPHERE.' - write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the '//norsou(hemi)//' hemisphere.' - end if - if( istat1 .eq. 0 ) then - ! EMK...Replace julhr with YYYYMMDD - !write(LIS_logunit,*)'- JULHR IS ' // cjulhr - !message(5) = ' julhr is ' // trim(cjulhr) // '.' - write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 - message(5) = ' yyyymmddhh is ' // trim(date10) // '.' - endif - alert_number = alert_number + 1 - if(LIS_masterproc) then - call lis_alert( 'sfcalc ', alert_number, & - message ) - endif - endif - else - ! EMK...Replace julhr with YYYYMMDD - !write(cjulhr,'(i6)',iostat=istat1) julhr - write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & - yr, mo, da, hr - if (use_wigos_sfcobs) then - write(LIS_logunit,*)' ' - write(LIS_logunit,*) & - '[WARN] ROUTINE AGRMET_GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*)'[WARN] THE GLOBE' - write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the globe.' - else - write(LIS_logunit,*)' ' - write(LIS_logunit,*) & - '[WARN] ROUTINE AGRMET_GETSFC: ERROR RETRIEVING SFC OBS FOR' - write(LIS_logunit,*)'[WARN] THE '//norsou(hemi)//' HEMISPHERE.' - write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 - message(1) = 'program: LIS' - message(2) = ' routine: AGRMET_getsfc' - message(3) = ' error retrieving sfc obs from database for' - message(4) = ' the '//norsou(hemi)//' hemisphere.' - end if - if( istat1 .eq. 0 ) then - ! EMK...Replace julhr with YYYYMMDDHH - !write(LIS_logunit,*)'- JULHR IS ' // cjulhr - !message(5) = ' julhr is ' // trim(cjulhr) // '.' - write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 - message(5) = ' yyyymmddhh is ' // trim(date10) // '.' - endif - alert_number = alert_number + 1 - if(LIS_masterproc) then - call lis_alert( 'sfcalc ', alert_number, message ) + ! EMK...Handling ierr2 .ne. 0 is now handled above. +! else ! ierr2 .ne. 0 +! ! ------------------------------------------------------------------ +! ! There was an error retrieving obs for this Julhr and hemi. +! ! Send an alert message, but don't abort. +! ! ------------------------------------------------------------------ + +! ! EMK...Replace julhr with YYYYMMDD +! !write(cjulhr,'(i6)',iostat=istat1) julhr +! write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & +! yr, mo, da, hr +! write(LIS_logunit,*)' ' +! if (use_wigos_sfcobs) then +! write(LIS_logunit,*) & +! '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' +! write(LIS_logunit,*)'[WARN] THE GLOBE' +! write(LIS_logunit,*)'[WARN} ISTAT IS ', ierr1 +! message(1) = 'program: LIS' +! message(2) = ' routine: AGRMET_getsfc' +! message(3) = ' error retrieving sfc obs from database for' +! message(4) = ' the globe' +! else +! write(LIS_logunit,*) & +! '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' +! write(LIS_logunit,*) & +! '[WARN] THE '//norsou(hemi)//' HEMISPHERE.' +! write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 +! message(1) = 'program: LIS' +! message(2) = ' routine: AGRMET_getsfc' +! message(3) = ' error retrieving sfc obs from database for' +! message(4) = ' the '//norsou(hemi)//' hemisphere.' +! end if +! if( istat1 .eq. 0 ) then +! ! EMK...Replace julhr with YYYYMMDD +! !write(LIS_logunit,*)'- JULHR IS ' // cjulhr +! !message(5) = ' julhr is ' // trim(cjulhr) // '.' +! write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 +! message(5) = ' yyyymmddhh is ' // trim(date10) // '.' +! endif +! alert_number = alert_number + 1 +! if(LIS_masterproc) then +! call lis_alert( 'sfcalc ', alert_number, & +! message ) +! endif +! message = '' endif + ! EMK...ierr1 .ne. 0 case now handled above. + ! else ! ierr1 .ne. 0 + ! ! EMK...Replace julhr with YYYYMMDD + ! !write(cjulhr,'(i6)',iostat=istat1) julhr + ! write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & + ! yr, mo, da, hr + ! write(LIS_logunit,*)' ' + ! write(LIS_logunit,*) & + ! '[WARN] ROUTINE AGRMET_GETSFC: ERROR OPENING ', & + ! trim(sfcobsfile) + ! write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 + ! message(1) = 'program: LIS' + ! message(2) = ' routine: AGRMET_getsfc' + ! message(3) = ' error opening file ', trim(sfcobsfile) + ! alert_number = alert_number + 1 + ! if(LIS_masterproc) then + ! call lis_alert( 'sfcalc ', alert_number, message ) + ! endif + ! message = '' endif if (use_wigos_sfcobs) exit ! New sfcobs file is global From 7efec4bf5ad5dd124cd97b780c5e8ea26aaf1e7e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 11:19:57 -0500 Subject: [PATCH 209/328] Removed dead code. --- lis/metforcing/usaf/AGRMET_getsfc.F90 | 71 +-------------------------- 1 file changed, 2 insertions(+), 69 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index 07e992e2b..075cf23a1 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -503,8 +503,8 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! ------------------------------------------------------------------ call latlon_to_ij(LIS_domain(n)%lisproj, rlat, rlon, & - rigrid, rjgrid) - + rigrid, rjgrid) + !if(rigrid.ge.1.and.rigrid.le.imax.and. & ! rjgrid.ge.1.and.rjgrid.le.jmax) then ! EMK TEST @@ -655,9 +655,6 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & obstmp(obscnt) = rtmp obsrlh(obscnt) = rrelh obsspd(obscnt) = rspd - !if(rspd.lt.0) then - ! print*, 'probl ',rlat,rlon, rspd - !endif endif ! ------------------------------------------------------------------ ! If we have reached the number of obs that our hard-wired @@ -683,71 +680,7 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & endif endif enddo - ! EMK...Handling ierr2 .ne. 0 is now handled above. -! else ! ierr2 .ne. 0 -! ! ------------------------------------------------------------------ -! ! There was an error retrieving obs for this Julhr and hemi. -! ! Send an alert message, but don't abort. -! ! ------------------------------------------------------------------ - -! ! EMK...Replace julhr with YYYYMMDD -! !write(cjulhr,'(i6)',iostat=istat1) julhr -! write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & -! yr, mo, da, hr -! write(LIS_logunit,*)' ' -! if (use_wigos_sfcobs) then -! write(LIS_logunit,*) & -! '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' -! write(LIS_logunit,*)'[WARN] THE GLOBE' -! write(LIS_logunit,*)'[WARN} ISTAT IS ', ierr1 -! message(1) = 'program: LIS' -! message(2) = ' routine: AGRMET_getsfc' -! message(3) = ' error retrieving sfc obs from database for' -! message(4) = ' the globe' -! else -! write(LIS_logunit,*) & -! '[WARN] ROUTINE GETSFC: ERROR RETRIEVING SFC OBS FOR' -! write(LIS_logunit,*) & -! '[WARN] THE '//norsou(hemi)//' HEMISPHERE.' -! write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 -! message(1) = 'program: LIS' -! message(2) = ' routine: AGRMET_getsfc' -! message(3) = ' error retrieving sfc obs from database for' -! message(4) = ' the '//norsou(hemi)//' hemisphere.' -! end if -! if( istat1 .eq. 0 ) then -! ! EMK...Replace julhr with YYYYMMDD -! !write(LIS_logunit,*)'- JULHR IS ' // cjulhr -! !message(5) = ' julhr is ' // trim(cjulhr) // '.' -! write(LIS_logunit,*)'[WARN] YYYYMMDDHH is ' // date10 -! message(5) = ' yyyymmddhh is ' // trim(date10) // '.' -! endif -! alert_number = alert_number + 1 -! if(LIS_masterproc) then -! call lis_alert( 'sfcalc ', alert_number, & -! message ) -! endif -! message = '' endif - ! EMK...ierr1 .ne. 0 case now handled above. - ! else ! ierr1 .ne. 0 - ! ! EMK...Replace julhr with YYYYMMDD - ! !write(cjulhr,'(i6)',iostat=istat1) julhr - ! write(date10,'(i4, i2.2, i2.2, i2.2)', iostat=istat1) & - ! yr, mo, da, hr - ! write(LIS_logunit,*)' ' - ! write(LIS_logunit,*) & - ! '[WARN] ROUTINE AGRMET_GETSFC: ERROR OPENING ', & - ! trim(sfcobsfile) - ! write(LIS_logunit,*)'[WARN] ISTAT IS ', ierr1 - ! message(1) = 'program: LIS' - ! message(2) = ' routine: AGRMET_getsfc' - ! message(3) = ' error opening file ', trim(sfcobsfile) - ! alert_number = alert_number + 1 - ! if(LIS_masterproc) then - ! call lis_alert( 'sfcalc ', alert_number, message ) - ! endif - ! message = '' endif if (use_wigos_sfcobs) exit ! New sfcobs file is global From 8ff8de6b81df68467cb9ebe3df4e93866e3b265b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 12:41:29 -0500 Subject: [PATCH 210/328] Tweaked code so first alert message for preobs is 001, not 000. --- lis/metforcing/usaf/AGRMET_getpcpobs.F90 | 6 +++--- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 10 +++++----- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_getpcpobs.F90 b/lis/metforcing/usaf/AGRMET_getpcpobs.F90 index 5ff482c9f..bd60dd8d6 100644 --- a/lis/metforcing/usaf/AGRMET_getpcpobs.F90 +++ b/lis/metforcing/usaf/AGRMET_getpcpobs.F90 @@ -297,9 +297,9 @@ subroutine AGRMET_getpcpobs(n, j6hr, month, prcpwe, & message(6) = ' Observations beyond array size will be ignored' message(7) = ' Increase number of AGRMET maximum precip obs in lis.config file!' if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.AGRMET_getpcpobs', & alert_number, message) - alert_number = alert_number + 1 end if nsize = agrmet_struc(n)%max_pcpobs @@ -397,9 +397,9 @@ subroutine AGRMET_getpcpobs(n, j6hr, month, prcpwe, & message(2) = ' Routine: AGRMET_getpcpobs' message(3) = ' Problem reading '// trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.AGRMET_getpcpobs', & alert_number, message) - alert_number = alert_number + 1 end if end if else @@ -416,9 +416,9 @@ subroutine AGRMET_getpcpobs(n, j6hr, month, prcpwe, & message(2) = ' Routine: AGRMET_getpcpobs' message(3) = ' Missing rain gage file '// trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.AGRMET_getpcpobs', & alert_number, message) - alert_number = alert_number + 1 end if endif diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index cf389335e..cf2f362df 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -142,9 +142,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & message(2) = ' Routine: USAF_read_preobs' message(3) = ' Cannot find file ' // trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) - alert_number = alert_number + 1 end if if (use_expanded_station_ids == 1) exit ! These files are global cycle @@ -158,9 +158,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & message(2) = ' Routine: USAF_read_preobs' message(3) = ' Cannot open file ' // trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) - alert_number = alert_number + 1 end if if (use_expanded_station_ids == 1) exit ! These files are global cycle @@ -174,9 +174,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & message(2) = ' Routine: USAF_read_preobs' message(3) = ' Problem reading file ' // trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) - alert_number = alert_number + 1 end if close(iunit) call LIS_releaseUnitNumber(iunit) @@ -191,9 +191,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & message(2) = ' Routine: USAF_read_preobs' message(3) = ' No precip obs found in ' // trim(filename) if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) - alert_number = alert_number + 1 end if else write(LIS_logunit,*) '[INFO] Will process ', trim(filename) @@ -732,9 +732,9 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & trim(presav_filename) message(4) = ' Observation count will be reduced' if (LIS_masterproc) then + alert_number = alert_number + 1 call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) - alert_number = alert_number + 1 end if end if end do From f763b35afd49f34c5e7e8b39df8e2f576610db1e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 17:33:48 -0500 Subject: [PATCH 211/328] Added info print statements. --- lis/metforcing/usaf/USAF_GagesMod.F90 | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index 365420470..c926e8916 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -1831,6 +1831,7 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) return end if + write(LIS_logunit,*) '[INFO] Reading ', trim(filename) read(iunit, *, iostat=istat) nobs if (istat .ne. 0) then write(LIS_logunit,*)'[WARN] Problem reading ', trim(filename) @@ -1969,6 +1970,8 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) if (istat .eq. 0) then call set_unique_networks(this) end if + + !write(LIS_logunit,*)'[INFO] Read in ', nobs, ' gage reports' end subroutine USAF_gages_read_data ! Search USAF_gages_t type for presumed erroneous accumulations. @@ -2588,6 +2591,7 @@ subroutine USAF_copy_to_usaf_obsdata(this, hr, gage_sigma_o_sqr, & ! Locals integer :: i + integer :: num_obs_copied ! Sanity checks if (this%nobs == 0) return @@ -2599,6 +2603,7 @@ subroutine USAF_copy_to_usaf_obsdata(this, hr, gage_sigma_o_sqr, & call LIS_endrun() end if + num_obs_copied = 0 if (hr == 6) then do i = 1, this%nobs if (this%amts06(i) < 0) cycle @@ -2609,7 +2614,10 @@ subroutine USAF_copy_to_usaf_obsdata(this, hr, gage_sigma_o_sqr, & real(this%lats(i)) * 0.01, & real(this%lons(i)) * 0.01, & gage_sigma_o_sqr, 0.) + num_obs_copied = num_obs_copied + 1 end do + write(LIS_logunit,*)'[INFO] Copied ', num_obs_copied, & + ' 6-hr gage reports' else if (hr == 12) then do i = 1, this%nobs if (this%amts12(i) < 0) cycle @@ -2620,7 +2628,12 @@ subroutine USAF_copy_to_usaf_obsdata(this, hr, gage_sigma_o_sqr, & real(this%lats(i)) * 0.01, & real(this%lons(i)) * 0.01, & gage_sigma_o_sqr, 0.) + num_obs_copied = num_obs_copied + 1 end do + write(LIS_logunit,*)'[INFO] Copied ', num_obs_copied, & + ' 12-hr gage reports' end if + + end subroutine USAF_copy_to_usaf_obsdata end module USAF_GagesMod From 3f53f28c46dc3f62c9e1074082d07e68708c85e1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 17:34:54 -0500 Subject: [PATCH 212/328] Commented out debugging print statement. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 26 ++++++++++++------------ 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 1cc946f36..80f691b93 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -2354,19 +2354,19 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& end if end if - !EMK TEST - do ii = 1, nobs - write(LIS_logunit,*) & - '[INFO] ii,net,platform,obs, back, ana, est, dataDensity: ', & - ii, & - trim(this%net(ii)), ' ',& - trim(this%platform(ii)), & - ' ',this%obs(ii),& - ' ',this%back(ii),& - ' ',pnew_ana(ii),& - ' ',pnew_est(ii),& - ' ',1./invDataDensities(ii) - end do + ! !EMK TEST + ! do ii = 1, nobs + ! write(LIS_logunit,*) & + ! '[INFO] ii,net,platform,obs, back, ana, est, dataDensity: ', & + ! ii, & + ! trim(this%net(ii)), ' ',& + ! trim(this%platform(ii)), & + ! ' ',this%obs(ii),& + ! ' ',this%back(ii),& + ! ' ',pnew_ana(ii),& + ! ' ',pnew_est(ii),& + ! ' ',1./invDataDensities(ii) + ! end do if (done) exit ! No more iterations! From d8e98a0b7f739e777c32c032d1a7d16bc08cbb41 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 17:35:34 -0500 Subject: [PATCH 213/328] Tweaked info print statements. --- lis/metforcing/usaf/readagrmetpcpforcing.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/metforcing/usaf/readagrmetpcpforcing.F90 b/lis/metforcing/usaf/readagrmetpcpforcing.F90 index dc446e836..c47c1f020 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcing.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcing.F90 @@ -411,7 +411,7 @@ subroutine readagrmetpcpforcing(n,findex, order) ! Reject data over water write(LIS_logunit,*) & - '[INFO] Running waterQC on 0-6 hr gauge observations' + '[INFO] Running waterQC on 6 hr gauge observations' call USAF_waterQC(precip_6hr_gage_tmp,n) nobs_good = USAF_countGoodObs(precip_6hr_gage_tmp) nobs_good_extra = nint(nobs_good*1.10) @@ -938,7 +938,7 @@ subroutine readagrmetpcpforcing(n,findex, order) ! Reject and filter out gage reports over water write(LIS_logunit,*) & - '[INFO] Running waterQC on 6-12 hr gauge observations' + '[INFO] Running waterQC on 12 hr gauge observations' call USAF_waterQC(precip_12hr_gage_tmp,n) nobs_good = USAF_countGoodObs(precip_12hr_gage_tmp) nobs_good_extra = nint(nobs_good*1.10) From a31f60781a87bc68a31dac0ecaeba5ade6827b30 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 13 Nov 2023 17:36:14 -0500 Subject: [PATCH 214/328] Revised logic to only read presav2 file at synoptic hour. --- lis/metforcing/usaf/USAF_getpcpobs.F90 | 34 ++++++++++++++------------ 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/lis/metforcing/usaf/USAF_getpcpobs.F90 b/lis/metforcing/usaf/USAF_getpcpobs.F90 index 9046e5803..3a9679aa9 100644 --- a/lis/metforcing/usaf/USAF_getpcpobs.F90 +++ b/lis/metforcing/usaf/USAF_getpcpobs.F90 @@ -80,25 +80,27 @@ subroutine USAF_getpcpobs(n, j6hr, month, use_twelve, pcp_src, & ! If this is a synoptic time, read the presav2 file back in and ! populate the appropriate USAF_ObsData object. - write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & - trim(agrmet_struc(n)%analysisdir), '/presav2.03hr.', & - yr, mo, da, hr - inquire(file=presav_filename, exist=file_exists) - if (file_exists) then - write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & + if ( mod(j3hr, 6) == 0 ) then + write(presav_filename,'(A,A,i4.4,i2.2,i2.2,i2.2)') & + trim(agrmet_struc(n)%analysisdir), '/presav2.03hr.', & yr, mo, da, hr - call obscur%read_data(presav_filename, yyyymmddhh, alert_number) - if (.not. use_twelve) then - call obscur%copy_to_usaf_obsdata(6, & - agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & - precip6) - else - call obscur%copy_to_usaf_obsdata(12, & - agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & - precip12) + inquire(file=presav_filename, exist=file_exists) + if (file_exists) then + write(yyyymmddhh,'(i4.4,i2.2,i2.2,i2.2)') & + yr, mo, da, hr + call obscur%read_data(presav_filename, yyyymmddhh, & + alert_number) + if (use_twelve) then + call obscur%copy_to_usaf_obsdata(12, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip12) + else + call obscur%copy_to_usaf_obsdata(6, & + agrmet_struc(n)%bratseth_precip_gauge_sigma_o_sqr, & + precip6) + end if end if end if - k = k + 1 end do From bdc59933ac71e7bd6826c4bc26762fabf08fdd99 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:06:09 -0500 Subject: [PATCH 215/328] Tweaked output (character variable is now trimmed). --- lis/core/LIS_logMod.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/core/LIS_logMod.F90 b/lis/core/LIS_logMod.F90 index 5c763b624..bfda37a9a 100644 --- a/lis/core/LIS_logMod.F90 +++ b/lis/core/LIS_logMod.F90 @@ -390,7 +390,7 @@ subroutine LIS_warning(ierr,msg) if ( ierr /= 0 ) then write(LIS_logunit,*) '[WARN] ****************WARNING*********************' - write(LIS_logunit,*) '[WARN] ',msg + write(LIS_logunit,*) '[WARN] ', trim(msg) write(LIS_logunit,*) '[WARN] ****************WARNING*********************' endif From 5cabc0438f454655ece7c20fbed165da1ce21839 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:06:42 -0500 Subject: [PATCH 216/328] Warning message now marked with "[INFO]", which is more appropriate. --- lis/core/LIS_tbotAdjustMod.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/core/LIS_tbotAdjustMod.F90 b/lis/core/LIS_tbotAdjustMod.F90 index b99164e6a..c6610e358 100644 --- a/lis/core/LIS_tbotAdjustMod.F90 +++ b/lis/core/LIS_tbotAdjustMod.F90 @@ -454,9 +454,9 @@ subroutine LIS_readTmnUpdateRestart(n,ftn,wformat) real, allocatable :: tmptilen(:) if ( LIS_rc%tbot_update_lag == 0 ) then - write(LIS_logunit,*) '[WARN] dynamic deep soil temperature updating '//& + write(LIS_logunit,*) '[INFO] dynamic deep soil temperature updating '//& 'was disabled in lis.config file.' - write(LIS_logunit,*) '[WARN] returning from LIS_readTmnUpdateRestart' + write(LIS_logunit,*) '[INFO] returning from LIS_readTmnUpdateRestart' return endif From db3efb08e080ba58207d85ddfb4862eccb35d2a9 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:07:36 -0500 Subject: [PATCH 217/328] Added [INFO], [WARN], and [ERR] tags to write statements. --- lis/metforcing/usaf/AGRMET_cdfs2_est.F90 | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 b/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 index 0833ee06c..83634ba09 100644 --- a/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 +++ b/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 @@ -259,7 +259,7 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& agrmet_struc(n)%clouddir,agrmet_struc(n)%use_timestamp,hemi,& yr,mo,da,hr) - write(LIS_logunit,*)'- OPENING ', trim(ifil) + write(LIS_logunit,*)'[INFO] OPENING ', trim(ifil) open(9, file=trim(ifil), access='direct', & recl=icdfs2*jcdfs2*1, iostat=istat, status="old") @@ -268,7 +268,7 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& ! ------------------------------------------------------------------ if (istat /= 0) then - write(LIS_logunit,*)'- ERROR OPENING ',trim(ifil),istat + write(LIS_logunit,*)'[ERR] ERROR OPENING ',trim(ifil),istat error_flag = .true. cycle READ_DATA end if @@ -277,12 +277,12 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& ! bad read, cycle loop and try to use previous hour's data. ! ------------------------------------------------------------------ - write(LIS_logunit,*)'- READING ',trim(ifil) + write(LIS_logunit,*)'[INFO] READING ',trim(ifil) read(9, rec=1, iostat=istat) totalc(hemi,:,:) close(9) if (istat /= 0) then - write(LIS_logunit,*)'- ERROR READING ',trim(ifil) + write(LIS_logunit,*)'[ERR] ERROR READING ',trim(ifil) error_flag = .true. cycle READ_DATA end if @@ -294,7 +294,7 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& call agrmet_cdfs_pixltime_filename(ifil,agrmet_struc(n)%agrmetdir,& agrmet_struc(n)%clouddir,agrmet_struc(n)%use_timestamp,hemi,& yr,mo,da,hr) - write(LIS_logunit,*)'- OPENING ', trim(ifil) + write(LIS_logunit,*)'[INFO] OPENING ', trim(ifil) open(9, file=trim(ifil), access='direct', & recl=icdfs2*jcdfs2*4, iostat=istat, status="old") @@ -304,12 +304,12 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& ! ------------------------------------------------------------------ if (istat /= 0) then - write(LIS_logunit,*)'- ERROR OPENING ',trim(ifil) + write(LIS_logunit,*)'[ERR] Cannot open ',trim(ifil) error_flag = .true. cycle READ_DATA end if - write(LIS_logunit,*)'- READING ', trim(ifil) + write(LIS_logunit,*)'[INFO] READING ', trim(ifil) read(9, rec=1, iostat=istat) times(hemi, :,:) close(9) @@ -320,7 +320,7 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& ! ------------------------------------------------------------------ if (istat /= 0) then - write(LIS_logunit,*)'- ERROR READING ',trim(ifil) + write(LIS_logunit,*)'[ERR] ERROR READING ',trim(ifil) error_flag = .true. cycle READ_DATA else @@ -339,9 +339,9 @@ subroutine AGRMET_cdfs2_est( n,k, cliprc, clippd,& if (istat /= 0) then write(LIS_logunit,*) - write(LIS_logunit,*) '* IN ROUTINE AGRMET_CDFS2_EST: ERRORS WITH CDFS2 DATA.' - write(LIS_logunit,*) '* DATA IS CORRUPT OR DOES NOT EXIST.' - write(LIS_logunit,*) '* CDFS2 PRECIP ESTIMATE WILL NOT BE PERFORMED.' + write(LIS_logunit,*) '[WARN] IN ROUTINE AGRMET_CDFS2_EST: ERRORS WITH CDFS2 DATA.' + write(LIS_logunit,*) '[WARN] DATA IS CORRUPT OR DOES NOT EXIST.' + write(LIS_logunit,*) '[WARN] CDFS2 PRECIP ESTIMATE WILL NOT BE PERFORMED.' write(LIS_logunit,*) call AGRMET_julhr_date10 ( j3hr, date10 ) From 260cda645609bb963348a7274f3d0ca7a4c304f0 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:08:13 -0500 Subject: [PATCH 218/328] Added [INFO] tag to write statements. --- lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 b/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 index 43e717a43..41f51ac97 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 @@ -1127,7 +1127,7 @@ subroutine galwem_reset_interp_input(n, findex, gridDesci) agrmet_struc(n)%fg_galwem_interp = LIS_rc%met_interp(findex) - write(LIS_logunit,*) 'MSG: The GALWEM forcing resolution is coarser ' // & + write(LIS_logunit,*) '[INFO] The GALWEM forcing resolution is coarser ' // & 'than the running domain.' write(LIS_logunit,*) ' Interpolating with the ' // & trim(agrmet_struc(n)%fg_galwem_interp) // ' method.' @@ -1184,7 +1184,7 @@ subroutine galwem_reset_interp_input(n, findex, gridDesci) elseif ( howtoTransform == 'neighbor') then agrmet_struc(n)%fg_galwem_interp = 'neighbor' - write(LIS_logunit,*) 'MSG: The GALWEM forcing resolution is comparable ' // & + write(LIS_logunit,*) '[INFO] The GALWEM forcing resolution is comparable ' // & 'to the running domain.' write(LIS_logunit,*) ' Interpolating with the ' // & trim(agrmet_struc(n)%fg_galwem_interp) // ' method.' @@ -1195,7 +1195,7 @@ subroutine galwem_reset_interp_input(n, findex, gridDesci) elseif ( howtoTransform == 'upscale' ) then agrmet_struc(n)%fg_galwem_interp = LIS_rc%met_upscale(findex) - write(LIS_logunit,*) 'MSG: The GALWEM forcing resolution is finer ' // & + write(LIS_logunit,*) '[INFO] The GALWEM forcing resolution is finer ' // & 'than the running domain.' write(LIS_logunit,*) ' Upscaling with the ' // & trim(agrmet_struc(n)%fg_galwem_interp) // ' method.' From 33c2bea494caf2ba5fa82a8e984615fe6cfff698 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:08:40 -0500 Subject: [PATCH 219/328] Added [INFO] tag to write statements. --- lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 b/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 index 2667559f8..eb7704c16 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 @@ -1587,7 +1587,7 @@ subroutine gfs_reset_interp_input(n, findex, gridDesci) agrmet_struc(n)%fg_gfs_interp = LIS_rc%met_interp(findex) - write(LIS_logunit,*) 'MSG: The GFS forcing resolution is coarser ' // & + write(LIS_logunit,*) '[INFO] The GFS forcing resolution is coarser ' // & 'than the running domain.' write(LIS_logunit,*) ' Interpolating with the ' // & trim(agrmet_struc(n)%fg_gfs_interp) // ' method.' @@ -1644,7 +1644,7 @@ subroutine gfs_reset_interp_input(n, findex, gridDesci) elseif ( howtoTransform == 'neighbor') then agrmet_struc(n)%fg_gfs_interp = 'neighbor' - write(LIS_logunit,*) 'MSG: The GFS forcing resolution is comparable ' // & + write(LIS_logunit,*) '[INFO] The GFS forcing resolution is comparable ' // & 'to the running domain.' write(LIS_logunit,*) ' Interpolating with the ' // & trim(agrmet_struc(n)%fg_gfs_interp) // ' method.' @@ -1655,7 +1655,7 @@ subroutine gfs_reset_interp_input(n, findex, gridDesci) elseif ( howtoTransform == 'upscale' ) then agrmet_struc(n)%fg_gfs_interp = LIS_rc%met_upscale(findex) - write(LIS_logunit,*) 'MSG: The GFS forcing resolution is finer ' // & + write(LIS_logunit,*) '[INFO] The GFS forcing resolution is finer ' // & 'than the running domain.' write(LIS_logunit,*) ' Upscaling with the ' // & trim(agrmet_struc(n)%fg_gfs_interp) // ' method.' From 9116ce51e9bfb80eb43f602457cf9f5681eabdba Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:09:04 -0500 Subject: [PATCH 220/328] Added [INFO] tag to write statement. --- lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 b/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 index 6882775eb..c641846ac 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 @@ -550,7 +550,7 @@ subroutine AGRMET_fldbld_read_precip_galwem(fg_filename, ifguess, jfguess,& count_prec = 0 write(LIS_logunit,*)' ' - write(LIS_logunit,*)'[MSG] Reading first guess precip ', trim(fg_filename) + write(LIS_logunit,*)'[INFO] Reading first guess precip ', trim(fg_filename) call grib_count_in_file(ftn,nvars,ierr) call LIS_verify(ierr, 'error in grib_count_in_file in ' // & From 624349fe15381c6aa9be861d28964b738ea19cde Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:09:29 -0500 Subject: [PATCH 221/328] Added [INFO] tag to write statement. --- lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 b/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 index 474212953..9953b8622 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 @@ -635,7 +635,7 @@ subroutine AGRMET_fldbld_read_precip_gfs( fg_filename, ifguess, jfguess,& allocate ( dum1d (ifguess*jfguess) ) count_prec = 0 - write(LIS_logunit,*)'[MSG] Reading first guess precip ', trim(fg_filename) + write(LIS_logunit,*)'[INFO] Reading first guess precip ', trim(fg_filename) call grib_count_in_file(ftn,nvars,ierr) call LIS_verify(ierr, 'error in grib_count_in_file in AGRMET_fldbld_read') From 9975cdbbc32e04ac2fab133983d33bbc89c9fcbd Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:10:04 -0500 Subject: [PATCH 222/328] Added [INFO] and [WARN] tags to write statements. --- lis/metforcing/usaf/AGRMET_geoest.F90 | 28 +++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_geoest.F90 b/lis/metforcing/usaf/AGRMET_geoest.F90 index 1ffff203a..051726fc0 100644 --- a/lis/metforcing/usaf/AGRMET_geoest.F90 +++ b/lis/metforcing/usaf/AGRMET_geoest.F90 @@ -189,9 +189,9 @@ subroutine AGRMET_geoest( n, j3hr, land ,gest, grnk, quad9r, & inquire( file = trim(ifil), exist = exists) if ( .not. exists ) then - write(LIS_logunit,*) 'AGRMET_geoest/precip: error opening file ',trim(ifil) - write(LIS_logunit,*) ' file does not exist' - write(LIS_logunit,*) ' geo precip estimate will not be performed' + write(LIS_logunit,*) '[WARN] AGRMET_geoest/precip: error opening file ',trim(ifil) + write(LIS_logunit,*) '[WARN] file does not exist' + write(LIS_logunit,*) '[WARN] geo precip estimate will not be performed' message = ' ' message(1) = 'program: LIS' message(2) = ' routine: AGRMET_geoest' @@ -205,7 +205,7 @@ subroutine AGRMET_geoest( n, j3hr, land ,gest, grnk, quad9r, & endif return endif - write(LIS_logunit,*) '- READING ', trim(ifil) + write(LIS_logunit,*) '[INFO] READING ', trim(ifil) call LIS_putget( geoprc, 'r', ifil, routine_name, & imax, jmax ) @@ -235,14 +235,14 @@ subroutine AGRMET_geoest( n, j3hr, land ,gest, grnk, quad9r, & if ( exists ) then gdgeornk = .true. - write(LIS_logunit,*) '- READING RANK FILE', trim(ifil) + write(LIS_logunit,*) '[INFO] READING RANK FILE', trim(ifil) call LIS_putget( geornk, 'r', ifil, routine_name, & imax, jmax ) else - write(LIS_logunit,*)'AGRMET_GEOEST/PRECIP: ERROR OPENING FILE ',trim(ifil) - write(LIS_logunit,*)' FILE DOES NOT EXIST' - write(LIS_logunit,*)' DEFAULT VALUES OF 4 WILL BE USED FOR GEO RANKS' + write(LIS_logunit,*)'[WARN] AGRMET_GEOEST/PRECIP: ERROR OPENING FILE ',trim(ifil) + write(LIS_logunit,*)'[WARN] FILE DOES NOT EXIST' + write(LIS_logunit,*)'[WARN] DEFAULT VALUES OF 4 WILL BE USED FOR GEO RANKS' message = ' ' message(1)='program: LIS' message(2)=' routine: AGRMET_geoest' @@ -273,8 +273,8 @@ subroutine AGRMET_geoest( n, j3hr, land ,gest, grnk, quad9r, & ! of these cases. if ( is_geo_corrupted(geoprc, imax, jmax, mo, hemi) ) then - write(LIS_logunit,*) 'AGRMET_geoest/precip: data corrupted - ',trim(ifil) - write(LIS_logunit,*) ' geo precip estimate will not be performed' + write(LIS_logunit,*) '[WARN] AGRMET_geoest/precip: data corrupted - ',trim(ifil) + write(LIS_logunit,*) '[WARN] geo precip estimate will not be performed' message = ' ' message(1) = 'program: LIS' message(2) = ' routine: AGRMET_geoest' @@ -330,10 +330,10 @@ subroutine AGRMET_geoest( n, j3hr, land ,gest, grnk, quad9r, & grnk_tmp(hemi,i,j) = 4 write(LIS_logunit,*)' ' write(LIS_logunit,*)'--------------------------------------------' - write(LIS_logunit,*)'Bad geo precip rank value' - write(LIS_logunit,*)'This value will be set to a default of 4' - write(LIS_logunit,*)'geornk(',i,',',j,') = ',geornk(i,j) - write(LIS_logunit,*)'from file :' + write(LIS_logunit,*)'[WARN] Bad geo precip rank value' + write(LIS_logunit,*)'[WARN] This value will be set to a default of 4' + write(LIS_logunit,*)'[WARN] geornk(',i,',',j,') = ',geornk(i,j) + write(LIS_logunit,*)'[WARN] from file :' write(LIS_logunit,*) trim(ifil) write(LIS_logunit,*)'--------------------------------------------' write(LIS_logunit,*)' ' From 8ee2cfad505f705d04ba3987974f3aa9329e6c54 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:10:28 -0500 Subject: [PATCH 223/328] Added [INFO] tag to write statement. --- lis/metforcing/usaf/AGRMET_getcli.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/usaf/AGRMET_getcli.F90 b/lis/metforcing/usaf/AGRMET_getcli.F90 index 2e4c8e6d5..a9eb8d0a8 100644 --- a/lis/metforcing/usaf/AGRMET_getcli.F90 +++ b/lis/metforcing/usaf/AGRMET_getcli.F90 @@ -74,7 +74,7 @@ subroutine AGRMET_getcli(n, filename,rtn,clidat) inquire( file = trim(filename), exist = exists) if ( exists ) then - write(LIS_logunit,*) '- READING ', trim(filename) + write(LIS_logunit,*) '[INFO] READING ', trim(filename) ! ------------------------------------------------------------------ ! the rtneph climo files are real valued files, while the precip From d9d83a177fe41de7a5fd9e979133cc090fbcae5d Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:10:52 -0500 Subject: [PATCH 224/328] Tweaked write statement to indicate line from sfcobs file is skipped. --- lis/metforcing/usaf/AGRMET_getsfc.F90 | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index 075cf23a1..8a6eb9560 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -420,7 +420,8 @@ subroutine AGRMET_getsfc( n, julhr, t2mObs, rh2mObs, spd10mObs, & ! EMK Patch Skip report if problem occurred reading it if (ierr3 .ne. 0) then write(LIS_logunit,*) & - '[WARN] Problem reading report ', i, ' from file' + '[WARN] Problem reading report ', i, & + ' from sfcobs file, skipping line' skip(i) = .true. cycle end if From d647210706ec95d3999eddf2a42423112e390669 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:12:08 -0500 Subject: [PATCH 225/328] Added [INFO] and [WARN] tags to write statements. --- lis/metforcing/usaf/AGRMET_processobs.F90 | 44 +++++++++++------------ 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_processobs.F90 b/lis/metforcing/usaf/AGRMET_processobs.F90 index cfc048fad..eba6bf5e5 100644 --- a/lis/metforcing/usaf/AGRMET_processobs.F90 +++ b/lis/metforcing/usaf/AGRMET_processobs.F90 @@ -488,7 +488,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & if (sixyes) then - write(LIS_logunit,*)'- READING ', trim(filename_min6) + write(LIS_logunit,*)'[INFO] READING ', trim(filename_min6) iofunc = "OPEN " open(8, file=trim(filename_min6), iostat=istat, err=100) @@ -535,9 +535,9 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & write(LIS_logunit,*)' ' write(LIS_logunit,*)"******************************************************" - write(LIS_logunit,*)"* PRECIP SAVE FILE FROM 6 HOURS AGO DOES NOT EXIST." - write(LIS_logunit,*)"* FILE NAME IS ", trim(filename_min6) - write(LIS_logunit,*)"* OBSERVATION COUNT WILL BE REDUCED." + write(LIS_logunit,*)"[WARN] PRECIP SAVE FILE FROM 6 HOURS AGO DOES NOT EXIST." + write(LIS_logunit,*)"[WARN] FILE NAME IS ", trim(filename_min6) + write(LIS_logunit,*)"[WARN] OBSERVATION COUNT WILL BE REDUCED." write(LIS_logunit,*)"******************************************************" write(LIS_logunit,*)' ' @@ -556,9 +556,9 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & write(LIS_logunit,*)' ' write(LIS_logunit,*)"*******************************************************" - write(LIS_logunit,*)"* BAD ", trim(iofunc), " ON FILE ",trim(filename_min6) - write(LIS_logunit,*)"* ISTAT = ", istat - write(LIS_logunit,*)"* OBSERVATION COUNT WILL BE REDUCED." + write(LIS_logunit,*)"[WARN] BAD ", trim(iofunc), " ON FILE ",trim(filename_min6) + write(LIS_logunit,*)"[WARN] ISTAT = ", istat + write(LIS_logunit,*)"[WARN] OBSERVATION COUNT WILL BE REDUCED." write(LIS_logunit,*)"*******************************************************" write(LIS_logunit,*)' ' @@ -600,7 +600,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & iofunc = "OPEN " open(9, file=trim(filename_min12), iostat=istat, err=200) - write(LIS_logunit,*)'- READING ', trim(filename_min12) + write(LIS_logunit,*)'[INFO] READING ', trim(filename_min12) iofunc = "READ " read(9, *, iostat=istat, err=200, end=200) count12 @@ -645,9 +645,9 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & write(LIS_logunit,*)' ' write(LIS_logunit,*)"*******************************************************" - write(LIS_logunit,*)"* PRECIP SAVE FILE FROM 12 HOURS AGO DOES NOT EXIST." - write(LIS_logunit,*)"* FILE NAME IS ", trim(filename_min12) - write(LIS_logunit,*)"* OBSERVATION COUNT WILL BE REDUCED." + write(LIS_logunit,*)"[WARN] PRECIP SAVE FILE FROM 12 HOURS AGO DOES NOT EXIST." + write(LIS_logunit,*)"[WARN] FILE NAME IS ", trim(filename_min12) + write(LIS_logunit,*)"[WARN] OBSERVATION COUNT WILL BE REDUCED." write(LIS_logunit,*)"*******************************************************" write(LIS_logunit,*)' ' @@ -666,9 +666,9 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & write(LIS_logunit,*)' ' write(LIS_logunit,*)"*******************************************************" - write(LIS_logunit,*)"* BAD ", trim(iofunc), " ON FILE ",trim(filename_min12) - write(LIS_logunit,*)"* ISTAT = ", istat - write(LIS_logunit,*)"* OBSERVATION COUNT WILL BE REDUCED." + write(LIS_logunit,*)"[WARN] BAD ", trim(iofunc), " ON FILE ",trim(filename_min12) + write(LIS_logunit,*)"[WARN] ISTAT = ", istat + write(LIS_logunit,*)"[WARN] OBSERVATION COUNT WILL BE REDUCED." write(LIS_logunit,*)"*******************************************************" write(LIS_logunit,*)' ' @@ -700,7 +700,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & if (sixyes) then write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- MAKING 12 HRLY AMTS FROM PREVIOUS 6 HRLY AMTS' + write(LIS_logunit,*)'[INFO] MAKING 12 HRLY AMTS FROM PREVIOUS 6 HRLY AMTS' MAKE12_FROM_6 : do i = 1, fltrcnt @@ -759,7 +759,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & if (twelveyes) then - write(LIS_logunit,*)'- MAKING 12 HRLY AMTS FROM CURRENT 24 AND OLD 12 HRLY AM TS' + write(LIS_logunit,*)'[INFO] MAKING 12 HRLY AMTS FROM CURRENT 24 AND OLD 12 HRLY AM TS' MAKE12_FROM_24 : do i = 1, fltrcnt @@ -1048,7 +1048,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & open (11, file=trim(filename), iostat=istat, err=300) write(LIS_logunit,*)' ' - write(LIS_logunit,*)"- WRITING ",trim(filename) + write(LIS_logunit,*)"[INFO] WRITING ",trim(filename) iofunc = "WRITE" write(11,*, iostat=istat, err=300) fltrcnt @@ -1070,7 +1070,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & close (11) write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- NUMBER OF 12 AND 6 HOURLY OBS IS ',count12obs, count6obs + write(LIS_logunit,*)'[INFO] NUMBER OF 12 AND 6 HOURLY OBS IS ',count12obs, count6obs write(LIS_logunit,*)' ' 300 continue @@ -1082,8 +1082,8 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & write(LIS_logunit,*)' ' write(LIS_logunit,*)"*******************************************************" - write(LIS_logunit,*)"* BAD ", trim(iofunc), " ON FILE ",trim(filename) - write(LIS_logunit,*)"* ISTAT = ", istat + write(LIS_logunit,*)"[WARN] BAD ", trim(iofunc), " ON FILE ",trim(filename) + write(LIS_logunit,*)"[WARN] ISTAT = ", istat write(LIS_logunit,*)"*******************************************************" write(LIS_logunit,*)' ' @@ -1118,7 +1118,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & USE_6 : if ( .not. use_twelve ) then - write(LIS_logunit,*)"- PUTTING 6 HOURLY RAIN GAUGE OBSERVATIONS ON GRID." + write(LIS_logunit,*)"[INFO] PUTTING 6 HOURLY RAIN GAUGE OBSERVATIONS ON GRID." oldd = 999.0 @@ -1196,7 +1196,7 @@ subroutine AGRMET_processobs(n, obs, isize, stncnt, hemi, julhr, & USE_12 : if (use_twelve) then - write(LIS_logunit,*)"- PUTTING 12 HOURLY RAIN GAUGE OBSERVATIONS ON GRID." + write(LIS_logunit,*)"[INFO] PUTTING 12 HOURLY RAIN GAUGE OBSERVATIONS ON GRID." oldd = 999.0 From 331b98b2b7485777299fbc867a4a1a990582a2e0 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:12:51 -0500 Subject: [PATCH 226/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 b/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 index 0e6b488d8..b8700de71 100644 --- a/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 +++ b/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 @@ -56,8 +56,8 @@ subroutine AGRMET_read_sfcalccntm(n) inquire( file = trim(agrmet_struc(n)%sfcntmfile), exist = exists) if ( exists ) then - write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- READING ', trim(agrmet_struc(n)%sfcntmfile) + !write(LIS_logunit,*)' ' + write(LIS_logunit,*)'[INFO] READING ', trim(agrmet_struc(n)%sfcntmfile) ftn= LIS_getNextUnitNumber() open(ftn, file=trim(agrmet_struc(n)%sfcntmfile), access='direct',& status='old', form="unformatted", recl=LIS_rc%gnr(n)*LIS_rc%gnc(n)*4) @@ -73,10 +73,10 @@ subroutine AGRMET_read_sfcalccntm(n) else write(LIS_logunit,*) write(LIS_logunit,*) "*****************************************************" - write(LIS_logunit,*) "* LIS: ERROR OPENING FILE:" - write(LIS_logunit,*) "* ", trim(agrmet_struc(n)%sfcntmfile) - write(LIS_logunit,*) "* FILE DOES NOT EXIST." - write(LIS_logunit,*) "* LIS WILL ABORT." + write(LIS_logunit,*) "[ERR] LIS: ERROR OPENING FILE:" + write(LIS_logunit,*) "[ERR] ", trim(agrmet_struc(n)%sfcntmfile) + write(LIS_logunit,*) "[ERR] FILE DOES NOT EXIST." + write(LIS_logunit,*) "[ERR] LIS WILL ABORT." write(LIS_logunit,*) "*****************************************************" message = ' ' message(1) = 'program: LIS' From 7589950ec0b7a2bcf3aec563d208c4ad9ffdf1bb Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:13:29 -0500 Subject: [PATCH 227/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/AGRMET_readmask.F90 | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_readmask.F90 b/lis/metforcing/usaf/AGRMET_readmask.F90 index 380d2e7d4..63e3b18b7 100644 --- a/lis/metforcing/usaf/AGRMET_readmask.F90 +++ b/lis/metforcing/usaf/AGRMET_readmask.F90 @@ -75,8 +75,8 @@ subroutine AGRMET_readmask(n) endif inquire( file = trim(name), exist = exists) if ( exists ) then - write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- READING ', trim(name) + !write(LIS_logunit,*)' ' + write(LIS_logunit,*)'[INFO] READING ', trim(name) if(agrmet_struc(n)%global_or_hemi .eq. 0) then call LIS_putget( agrmet_struc(n)%land(:,:,hemi), 'r', name, routine_name, & agrmet_struc(n)%imax, agrmet_struc(n)%jmax ) @@ -87,10 +87,10 @@ subroutine AGRMET_readmask(n) else write(LIS_logunit,*) write(LIS_logunit,*) "*****************************************************" - write(LIS_logunit,*) "* LIS: ERROR OPENING FILE:" - write(LIS_logunit,*) "* ", trim(name) - write(LIS_logunit,*) "* FILE DOES NOT EXIST." - write(LIS_logunit,*) "* LIS WILL ABORT." + write(LIS_logunit,*) "[ERR] LIS: ERROR OPENING FILE:" + write(LIS_logunit,*) "[ERR] ", trim(name) + write(LIS_logunit,*) "[ERR] FILE DOES NOT EXIST." + write(LIS_logunit,*) "[ERR] LIS WILL ABORT." write(LIS_logunit,*) "*****************************************************" message = ' ' message(1) = 'program: LIS' From 66836375c964a0fc8948757a069b8e09a6ba2b3b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:14:07 -0500 Subject: [PATCH 228/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/AGRMET_readpcpcntm.F90 | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 b/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 index e450f2e4d..0ac8572e9 100644 --- a/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 +++ b/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 @@ -60,8 +60,8 @@ subroutine AGRMET_readpcpcntm(n) name = trim(agrmet_struc(n)%climodir)//'/pcp_spread_radii.1gd4r' inquire( file = trim(name) , exist = exists) if ( exists ) then - write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- READING ', trim(name) + !write(LIS_logunit,*)' ' + write(LIS_logunit,*)'[INFO] READING ', trim(name) ftn= LIS_getNextUnitNumber() open(ftn, file=trim(name), access='direct',& status='old', form="unformatted", recl=LIS_rc%gnr(n)*LIS_rc%gnc(n)*4) @@ -76,10 +76,10 @@ subroutine AGRMET_readpcpcntm(n) call LIS_releaseUnitNumber(ftn) else - write(LIS_logunit,*) 'LIS: error opening file ',trim(name) - write(LIS_logunit,*) ' file does not exist' - write(LIS_logunit,*) ' this could indicate serious data discrepancies' - write(LIS_logunit,*) ' LIS will be aborted' + write(LIS_logunit,*) '[ERR] LIS: error opening file ',trim(name) + write(LIS_logunit,*) '[ERR] file does not exist' + write(LIS_logunit,*) '[ERR] this could indicate serious data discrepancies' + write(LIS_logunit,*) '[ERR] LIS will be aborted' message(1) = 'program: LIS' message(2) = ' routine: AGRMET_readpcpcntm' message(3) = ' error opening file '//trim(name) From 6fd32bdf0b55ceb81a4ec4fd11a119cfcc5188f3 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:14:44 -0500 Subject: [PATCH 229/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/AGRMET_readterrain.F90 | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_readterrain.F90 b/lis/metforcing/usaf/AGRMET_readterrain.F90 index 859676106..358acc6d7 100644 --- a/lis/metforcing/usaf/AGRMET_readterrain.F90 +++ b/lis/metforcing/usaf/AGRMET_readterrain.F90 @@ -61,17 +61,17 @@ subroutine AGRMET_readterrain(n) call get_agrmetterrain_filename(name,agrmet_struc(n)%terrainfile,hemi) inquire( file = trim(name), exist = exists) if ( exists ) then - write(LIS_logunit,*)' ' - write(LIS_logunit,*)'- READING ', trim(name) + !write(LIS_logunit,*)' ' + write(LIS_logunit,*)'[INFO] READING ', trim(name) call LIS_putget( agrmet_struc(n)%alt(:,:,hemi), 'r', name, routine_name, & agrmet_struc(n)%imax, agrmet_struc(n)%jmax ) else write(LIS_logunit,*) write(LIS_logunit,*) "*****************************************************" - write(LIS_logunit,*) "* LIS: ERROR OPENING FILE:" - write(LIS_logunit,*) "* ", trim(name) - write(LIS_logunit,*) "* FILE DOES NOT EXIST." - write(LIS_logunit,*) "* LIS WILL ABORT." + write(LIS_logunit,*) "[ERR] LIS: ERROR OPENING FILE:" + write(LIS_logunit,*) "[ERR] ", trim(name) + write(LIS_logunit,*) "[ERR] FILE DOES NOT EXIST." + write(LIS_logunit,*) "[ERR] LIS WILL ABORT." write(LIS_logunit,*) "*****************************************************" message = ' ' message(1) = 'program: LIS' From 616046ba9142ebe3d42f082dcbc1368069c8fdd3 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:15:17 -0500 Subject: [PATCH 230/328] Added [INFO] tag to write statement. --- lis/metforcing/usaf/AGRMET_sfcalc.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/metforcing/usaf/AGRMET_sfcalc.F90 b/lis/metforcing/usaf/AGRMET_sfcalc.F90 index 4ac2ea02a..b79426223 100644 --- a/lis/metforcing/usaf/AGRMET_sfcalc.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcalc.F90 @@ -368,7 +368,7 @@ subroutine AGRMET_sfcalc(n) write(LIS_logunit,*)' ' write(LIS_logunit,*)'---------------------------- ' !write(LIS_logunit,*)'- PROCESSING-SFC JULHR ', julhr - write(LIS_logunit,*)'- PROCESSING-SFC YYYYMMDDHH ', yyyymmddhh + write(LIS_logunit,*)'[INFO] PROCESSING-SFC YYYYMMDDHH ', yyyymmddhh write(LIS_logunit,*)'---------------------------- ' ! ------------------------------------------------------------------ From a00da2f5a212b101462345098a56b12effff044f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:15:50 -0500 Subject: [PATCH 231/328] Added [INFO] and [WARN] tags to write statements. --- lis/metforcing/usaf/AGRMET_smiest.F90 | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_smiest.F90 b/lis/metforcing/usaf/AGRMET_smiest.F90 index 6fc4088d6..1879e3987 100644 --- a/lis/metforcing/usaf/AGRMET_smiest.F90 +++ b/lis/metforcing/usaf/AGRMET_smiest.F90 @@ -136,9 +136,9 @@ subroutine AGRMET_smiest( n,j3hr, quad9r, ra, razero,alert_number,imax,jmax) inquire(file = trim(ifil), exist = exists) if (.not. exists) then write(LIS_logunit,*) ' ' - write(LIS_logunit,*)'precip/smiedr: error opening file' - write(LIS_logunit,*)' SSMI data file ', trim(ifil),' does not exist.' - write(LIS_logunit,*)' SSMI estimates will not be used in ',& + write(LIS_logunit,*)'[WARN] precip/smiedr: error opening file' + write(LIS_logunit,*)'[WARN] SSMI data file ', trim(ifil),' does not exist.' + write(LIS_logunit,*)'[WARN] SSMI estimates will not be used in ',& 'precip analysis.' write(LIS_logunit,*) ' ' message =' ' @@ -153,7 +153,7 @@ subroutine AGRMET_smiest( n,j3hr, quad9r, ra, razero,alert_number,imax,jmax) ra_tmp(hemi,:,:) = udef else - write(LIS_logunit,*) '- READING ',trim(ifil) + write(LIS_logunit,*) '[INFO] READING ',trim(ifil) call LIS_putget( ra_tmp(hemi,:,:), 'r', ifil, routine_name, & imax, jmax) endif @@ -161,7 +161,7 @@ subroutine AGRMET_smiest( n,j3hr, quad9r, ra, razero,alert_number,imax,jmax) enddo if ( .not. use_zeros ) then - write(LIS_logunit,*)'- SSMI ZEROS NOT USED' + write(LIS_logunit,*)'[INFO] SSMI ZEROS NOT USED' where ( ra_tmp .eq. 0.0 ) ra_tmp = udef endif From fb38d503b1987ec8fe43b052e4f3e2a2f202cfbc Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:16:51 -0500 Subject: [PATCH 232/328] Added [INFO], [WARN], and [ERR] tags to write statements. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 48 ++++++++++++------------ 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 80f691b93..28eb3916c 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -657,8 +657,8 @@ subroutine USAF_addSSMIObsData(this,imax,jmax,ra_tmp,nest) continue else write(LIS_logunit,*)'[ERR] Invalid imax dimension for SSM/I!' - write(LIS_logunit,*)'Received ', imax - write(LIS_logunit,*)'Only support 512, 1024, or 1400' + write(LIS_logunit,*)'[ERR] Received ', imax + write(LIS_logunit,*)'[ERR] Only support 512, 1024, or 1400' flush(LIS_logunit) call LIS_endrun() end if @@ -725,7 +725,7 @@ subroutine USAF_addSSMIObsData(this,imax,jmax,ra_tmp,nest) if (imax .eq. 1440) then write(LIS_logunit,*)'[ERR] Lat/lon SSM/I data not supported yet!' - write(LIS_logunit,*)'Modify USAF_addSSMIObsData and recompile!' + write(LIS_logunit,*)'[ERR] Modify USAF_addSSMIObsData and recompile!' flush(LIS_logunit) call LIS_endrun() @@ -875,7 +875,7 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) call AGRMET_julhr_date10(j3hr, yyyymmddhh) write(LIS_logunit,*) & '[ERR] No NWP background precipitation found for ',yyyymmddhh - write(LIS_logunit,*) ' ABORTING!' + write(LIS_logunit,*) '[ERR] ABORTING!' flush(LIS_logunit) message(:) = '' message(1) = '[ERR] Program: LIS' @@ -1017,9 +1017,9 @@ subroutine USAF_getSSMIObsData(nest,j6hr,use_twelve,precip3,precip6, & write(LIS_logunit,*) ' ' write(LIS_logunit,*) & '[WARN] precip/smiedr: error opening file' - write(LIS_logunit,*)' SSMI data file ', trim(ifil), & + write(LIS_logunit,*)'[WARN] SSMI data file ', trim(ifil), & ' does not exist.' - write(LIS_logunit,*)' SSMI estimates will not be used ',& + write(LIS_logunit,*)'[WARN] SSMI estimates will not be used ',& 'in precip analysis.' write(LIS_logunit,*) ' ' message =' ' @@ -1036,7 +1036,7 @@ subroutine USAF_getSSMIObsData(nest,j6hr,use_twelve,precip3,precip6, & ra(hemi,:,:) = MISSING else - write(LIS_logunit,*) '- READING ',trim(ifil) + write(LIS_logunit,*) '[INFO] READING ',trim(ifil) call LIS_putget( ra(hemi,:,:), 'r', ifil, routine_name, & imax, jmax) end if ! .not. exists @@ -1044,7 +1044,7 @@ subroutine USAF_getSSMIObsData(nest,j6hr,use_twelve,precip3,precip6, & ! Honor option to reset SSMI zero precip values to missing if (.not. use_zeros) then - write(LIS_logunit,*)'- SSMI ZEROS NOT USED' + write(LIS_logunit,*)'[INFO] SSMI ZEROS NOT USED' where ( .not. ra(:,:,:) > 0.0 .and. & .not. ra(:,:,:) < 0) ra(:,:,:) = MISSING @@ -1189,7 +1189,7 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& else write(LIS_logunit,*) & '[ERR] Invalid dimension for GEO_PRECIP data!' - write(LIS_logunit,*)'Read ', agrmet_struc(nest)%imax + write(LIS_logunit,*)'[ERR] Read ', agrmet_struc(nest)%imax call LIS_endrun() end if end if @@ -1219,8 +1219,8 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& else write(LIS_logunit,*) & '[ERR] Invalid imax dimension for GEO_PRECIP!' - write(LIS_logunit,*)'Received ',imax - write(LIS_logunit,*)'Only support 512, 1024, or 4096!' + write(LIS_logunit,*)'[ERR] Received ',imax + write(LIS_logunit,*)'[ERR] Only support 512, 1024, or 4096!' flush(LIS_logunit) call LIS_endrun() end if @@ -1247,11 +1247,11 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& inquire( file = trim(ifil), exist = exists) if ( .not. exists ) then write(LIS_logunit,*) & - 'USAF_getGeoPrecipObsData: error opening file ', & + '[WARN] USAF_getGeoPrecipObsData: error opening file ', & trim(ifil) - write(LIS_logunit,*) ' file does not exist' + write(LIS_logunit,*) '[WARN] file does not exist' write(LIS_logunit,*) & - ' geo precip estimate will not be performed' + '[WARN] geo precip estimate will not be performed' message = ' ' message(1) = 'program: LIS' message(2) = ' routine: USAF_getGeoPrecipObsData' @@ -1266,7 +1266,7 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& TRACE_EXIT("bratseth_getGeopPrcp") return endif - write(LIS_logunit,*) '- READING ', trim(ifil) + write(LIS_logunit,*) '[INFO] READING ', trim(ifil) allocate(geoprc(imax,jmax)) @@ -1285,10 +1285,10 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& ! Check for anomalous geoprecip files if (is_geo_corrupted(geoprc, imax, jmax, mo, hemi)) then write(LIS_logunit,*) & - 'USAF_getGeoPrecipObsData: data corrupted - ', & + '[WARN] USAF_getGeoPrecipObsData: data corrupted - ', & trim(ifil) write(LIS_logunit,*) & - ' geo precip estimate will not be performed' + '[WARN] geo precip estimate will not be performed' message = ' ' message(1) = 'program: LIS' message(2) = ' routine: USAF_getGeoPrecipObsData' @@ -1426,7 +1426,7 @@ subroutine USAF_getGeoPrecipObsData(nest,j6hr,use_twelve,precip3,precip6,& write(LIS_logunit,*)& '[ERR] Lat/lon GEO_PRECIP data not supported yet!' write(LIS_logunit,*)& - 'Modify USAF_addGeoPrecipObsData and recompile!' + '[ERR] Modify USAF_addGeoPrecipObsData and recompile!' flush(LIS_logunit) call LIS_endrun() @@ -2565,7 +2565,7 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& if (nobs .ne. this%nobs) then write(LIS_logunit,*)'[ERR] Array size mismatch in calc_gridAnalysis!' - write(LIS_logunit,*)'nobs, this%nobs = ',nobs, this%nobs + write(LIS_logunit,*)'[ERR] nobs, this%nobs = ',nobs, this%nobs call LIS_endrun() end if @@ -4070,7 +4070,7 @@ subroutine reset_negative_values(nest,mrgp) if (ifix > 0) then write(LIS_logunit,6000) ifix 6000 format (/, 1x, 55('-'), & - /, 3x, 'routine reset_negative_values:',& + /, 3x, '[INFO] routine reset_negative_values:',& /, 5x, '# of pts to which negative values were set to zero = ', & i6, /, 1x, 55('-')) end if @@ -6436,9 +6436,9 @@ subroutine USAF_setBratsethPrecipStats(src,nest) write(LIS_logunit,*) & '[ERR] Unknown source of background precipitation!' write(LIS_logunit,*) & - 'Source is ',trim(src) + '[ERR] Source is ',trim(src) write(LIS_logunit, *) & - 'ABORTING....' + '[ERR] ABORTING....' flush(LIS_logunit) call LIS_endrun() end if @@ -6534,9 +6534,9 @@ subroutine USAF_setBratsethScreenStats(src,n) write(LIS_logunit,*) & '[ERR] Unknown source of background data!' write(LIS_logunit,*) & - 'Source is ',trim(src) + '[ERR] Source is ',trim(src) write(LIS_logunit, *) & - 'ABORTING....' + '[ERR] ABORTING....' flush(LIS_logunit) call LIS_endrun() end if From 8777cc10b7aa76dbcbb2f73a9322d4ea013674e8 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:17:21 -0500 Subject: [PATCH 233/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 b/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 index ac7d4352e..1b7c050c8 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 @@ -127,13 +127,13 @@ subroutine readagrmetpcpforcinganalysis(n,findex, order) //'.03hr.'//date10_03 endif - write(LIS_logunit,*)' - READING precip ',ifil + write(LIS_logunit,*)'[INFO] READING precip ',ifil inquire(file=ifil,exist=exists) if(exists) then call LIS_putget(gi(hemi,:,:), 'r', ifil, & routine_name, agrmet_struc(n)%imax, agrmet_struc(n)%jmax ) else - write(LIS_logunit,*) 'premrg file does not exist' + write(LIS_logunit,*) '[ERR] premrg file does not exist' write(LIS_logunit,*) ifil call LIS_endrun() endif From 360fc05512ef0cac29ea44c2d409d5fa813769d4 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:18:55 -0500 Subject: [PATCH 234/328] Added [INFO] and [ERR] tags to write statements. --- lis/metforcing/usaf/readcrd_agrmet.F90 | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 3a506f729..bc433b3e2 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -66,8 +66,8 @@ subroutine readcrd_agrmet() call ESMF_ConfigFindLabel(LIS_config,"AGRMET forcing directory:",rc=rc) do n=1,LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,agrmet_struc(n)%agrmetdir,rc=rc) - write(LIS_logunit,*)'Using AGRMET forcing' - write(LIS_logunit,*) 'AGRMET forcing directory :',agrmet_struc(n)%agrmetdir + write(LIS_logunit,*)'[INFO] Using AGRMET forcing' + write(LIS_logunit,*) '[INFO] AGRMET forcing directory: ', trim(agrmet_struc(n)%agrmetdir) enddo call ESMF_ConfigFindLabel(LIS_config,"AGRMET first guess source:",rc=rc) @@ -1185,7 +1185,7 @@ subroutine readcrd_agrmet() if (LIS_masterproc) then ios = LIS_create_subdirs(len_trim(c_string),trim(c_string)) if (ios .ne. 0) then - write(LIS_logunit,*)'ERR creating directory ', & + write(LIS_logunit,*)'[ERR] Cannot create directory ', & trim(agrmet_struc(n)%analysisdir) flush(LIS_logunit) end if From 971c6efc6d8c25e2999c116f77dcec410792e7ba Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:19:24 -0500 Subject: [PATCH 235/328] Added [INFO] tag and trimmed character variable in write statement. --- lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 b/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 index d5c716aa1..574f3a153 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 @@ -102,13 +102,13 @@ subroutine noah39_readrst() if(.not.file_exists) then write(LIS_logunit,*) '[ERR] Noah-3.9 restart file ', & - noah39_struc(n)%rfile,' does not exist ' + trim(noah39_struc(n)%rfile),' does not exist ' write(LIS_logunit,*) '[ERR] Program stopping ...' call LIS_endrun() endif write(LIS_logunit,*) & - '[INFO] Noah-3.9 restart file used: ',noah39_struc(n)%rfile + '[INFO] Noah-3.9 restart file used: ',trim(noah39_struc(n)%rfile) if(wformat.eq."binary") then ftn = LIS_getNextUnitNumber() From 4628f2eed127689b72c767288223a0813e8249b2 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 10:19:56 -0500 Subject: [PATCH 236/328] Added [INFO] tag to write statement. --- .../openwater/template/readtemplateOpenWatercrd.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 b/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 index f681712b4..051d60e60 100644 --- a/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 +++ b/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 @@ -47,6 +47,6 @@ subroutine readtemplateOpenWatercrd() call LIS_parseTimeString(time,templateOpenWater_struc(n)%ts) enddo - write(LIS_logunit,*)'Running Template Open water Option:' + write(LIS_logunit,*)'[INFO] Running Template Open water Option:' end subroutine readtemplateOpenWatercrd From 2cedc03f0d318f0ab2a6f40a767526a35687c43b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 15 Nov 2023 16:38:06 -0500 Subject: [PATCH 237/328] Removed -Wpedantic debug flag for gfortran. There are two reasons that chain together for this change. First, Intel MPI doesn't seem to export Fortran interfaces for MPI subroutines and functions, which causes gfortran to complain when argument types change between MPI calls. Second, the -Wpedantic flag elevates these mismatches to syntax errors with gfortran 11.2.0. (This may be a compiler bug, as there is a separate -pedantic-error that is supposed to do this.) Taken together, -Wpedantic will cause gfortran 11.2.0 to halt when it encounters MPI calls in code, when using Intel MPI. By removing the flag, the compiler will downgrade this to a warning -- this would allow a developer to still identify actual bugs with argument mismatches when using gfortran. (It *may* be worth adding explicit interfaces for MPI routines not provided by the MPI library. See https://www.scivision.dev/gfortran-type-mismatch-error/. But that's a lot of work.) --- ldt/arch/Config.pl | 2 +- lis/arch/Config.pl | 2 +- lvt/arch/Config.pl | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/ldt/arch/Config.pl b/ldt/arch/Config.pl index 65688a54a..2ddc9eee0 100755 --- a/ldt/arch/Config.pl +++ b/ldt/arch/Config.pl @@ -134,7 +134,7 @@ } elsif($sys_arch eq "Darwin_gfortran" || $sys_arch eq "linux_gfortran") { $sys_opt = "-g -Wall -Wcharacter-truncation"; - $sys_opt .= " -Wconversion-extra -Wextra -Wpedantic -Wrealloc-lhs"; + $sys_opt .= " -Wconversion-extra -Wextra -Wrealloc-lhs"; $sys_opt .= " -Wrealloc-lhs-all"; # Run-time options $sys_opt .= " -ffpe-trap=invalid,zero,overflow"; diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index 1d954cc1e..b4bed04b1 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -190,7 +190,7 @@ #print "Using '-g'\n"; #$sys_opt = "-g"; $sys_opt = "-g -Wall -Wcharacter-truncation"; - $sys_opt .= " -Wconversion-extra -Wextra -Wpedantic -Wrealloc-lhs"; + $sys_opt .= " -Wconversion-extra -Wextra -Wrealloc-lhs"; $sys_opt .= " -Wrealloc-lhs-all"; # Run-time options $sys_opt .= " -ffpe-trap=invalid,zero,overflow"; diff --git a/lvt/arch/Config.pl b/lvt/arch/Config.pl index 166737848..c912a9a3e 100755 --- a/lvt/arch/Config.pl +++ b/lvt/arch/Config.pl @@ -116,7 +116,7 @@ } elsif($sys_arch eq "Darwin_gfortran" || $sys_arch eq "linux_gfortran") { $sys_opt = "-g -Wall -Wcharacter-truncation"; - $sys_opt .= " -Wconversion-extra -Wextra -Wpedantic -Wrealloc-lhs"; + $sys_opt .= " -Wconversion-extra -Wextra -Wrealloc-lhs"; $sys_opt .= " -Wrealloc-lhs-all"; # Run-time options $sys_opt .= " -ffpe-trap=invalid,zero,overflow"; From ec3e91173eb76cb668a6c358ae655ce04ca20249 Mon Sep 17 00:00:00 2001 From: David Mocko Date: Mon, 20 Nov 2023 15:25:53 -0500 Subject: [PATCH 238/328] Fixing Noah-MP-4.0.1 LSM restart and model alarms for multiple nests in LIS This bug fix corrects the alarms for the Noah-MP-4.0.1 LSM in LIS when running multiple nests. The restart alarm and the model alarm are both corrected. Resolves: #1457 --- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 | 6 +++--- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 | 3 ++- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 | 4 +++- 3 files changed, 8 insertions(+), 5 deletions(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 index e1b94f570..cf1078f06 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 @@ -304,18 +304,18 @@ subroutine NoahMP401_ini() call LIS_update_timestep(LIS_rc, n, NOAHMP401_struc(n)%ts) - call LIS_registerAlarm("NoahMP401 model alarm",& + write(fnest,'(i3.3)') n + call LIS_registerAlarm("NoahMP401 model alarm "//trim(fnest),& NOAHMP401_struc(n)%ts, & NOAHMP401_struc(n)%ts) - call LIS_registerAlarm("NoahMP401 restart alarm", & + call LIS_registerAlarm("NoahMP401 restart alarm "//trim(fnest), & NOAHMP401_struc(n)%ts,& NOAHMP401_struc(n)%rstInterval) ! EMK Add alarm to reset tair_agl_min for RHMin. This should ! match the output interval, since that is used for calculating ! Tair_F_min. - write(fnest,'(i3.3)') n call LIS_registerAlarm("NoahMP401 RHMin alarm "//trim(fnest),& NOAHMP401_struc(n)%ts,& LIS_sfmodel_struc(n)%outInterval) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 index 87c42073b..dce98f1ea 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 @@ -272,7 +272,8 @@ subroutine NoahMP401_main(n) ! check NoahMP401 alarm. If alarm is ring, run model. - alarmCheck = LIS_isAlarmRinging(LIS_rc, "NoahMP401 model alarm") + write(fnest,'(i3.3)') n + alarmCheck = LIS_isAlarmRinging(LIS_rc, "NoahMP401 model alarm "//trim(fnest)) if (alarmCheck) Then do t = 1, LIS_rc%npatch(n, LIS_rc%lsm_index) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 index 5e0cd5a59..4b02f64db 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 @@ -60,9 +60,11 @@ subroutine NoahMP401_writerst(n) logical :: alarmCheck integer :: ftn integer :: status + character*3 :: fnest ! set restart alarm - alarmCheck = LIS_isAlarmRinging(LIS_rc, "NoahMP401 restart alarm") + write(fnest,'(i3.3)') n + alarmCheck = LIS_isAlarmRinging(LIS_rc, "NoahMP401 restart alarm "//trim(fnest)) ! set restart file format (read from LIS configration file_ wformat = trim(NOAHMP401_struc(n)%rformat) From 69a8aa40770e0d2db6920751ba99cb1954eb839e Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 21 Nov 2023 08:59:31 -0500 Subject: [PATCH 239/328] Remove extra "write(fnest)" --- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 | 1 - 1 file changed, 1 deletion(-) diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 index dce98f1ea..73579e51f 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 @@ -1434,7 +1434,6 @@ subroutine NoahMP401_main(n) ! EMK...See if noahmp401_struc(n)%noahmp401(t)%tair_agl_min needs to be ! reset for calculating RHMin. - write(fnest,'(i3.3)') n alarmCheck = LIS_isAlarmRinging(LIS_rc, & "NoahMP401 RHMin alarm "//trim(fnest)) if (alarmCheck) then From fd28b9c75775477492dd2f69267f1b35a51fcdc7 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 1 Dec 2023 12:15:44 -0500 Subject: [PATCH 240/328] First cut at including backQC/superstatQC flagged obs in OBA files. --- lis/metforcing/usaf/USAF_OBAMod.F90 | 67 ++++++-- lis/metforcing/usaf/USAF_bratsethMod.F90 | 189 ++++++++++++++++------- 2 files changed, 182 insertions(+), 74 deletions(-) diff --git a/lis/metforcing/usaf/USAF_OBAMod.F90 b/lis/metforcing/usaf/USAF_OBAMod.F90 index a3788ef57..a92f42685 100644 --- a/lis/metforcing/usaf/USAF_OBAMod.F90 +++ b/lis/metforcing/usaf/USAF_OBAMod.F90 @@ -13,6 +13,7 @@ ! REVISION HISTORY: ! 22 Jun 2017 Initial version.........................Eric Kemp/SSAI/NASA ! 07 Sep 2018 Changed EMK_ prefix to USAF_............Eric Kemp/SSAI/NASA +! 29 Nov 2023 Add QC flags............................Eric Kemp/SSAI/NASA ! ! DESCRIPTION: ! Contains data structure and methods for collecting observed, background, @@ -38,6 +39,7 @@ module USAF_OBAMod real, allocatable :: O(:) ! Observation values real, allocatable :: B(:) ! Background values real, allocatable :: A(:) ! Analysis values + integer, allocatable :: qc(:) ! QC code end type OBA public :: OBA @@ -54,6 +56,21 @@ module USAF_OBAMod public :: writeToFile public :: makeFilename + ! Public parameters + integer, parameter, public :: QC_UNKNOWN = 0 + integer, parameter, public :: QC_GOOD = 1 + integer, parameter, public :: QC_REJECT = 2 + integer, parameter, public :: QC_SUSPECT_BACKQC = 3 + integer, parameter, public :: QC_SUSPECT_SUPERSTATQC = 4 + + ! Private parameter + character(11), parameter :: qc_string(5) = (/ & + 'UNKNOWN ', & + 'GOOD ', & + 'REJECT ', & + 'BACKQC ', & + 'SUPERSTATQC'/) + contains !--------------------------------------------------------------------------- @@ -75,7 +92,7 @@ function newOBA(nest,maxobs) result(this) ! Local variables integer :: maxnobs - + if (present(maxobs)) then maxnobs = maxobs else @@ -91,14 +108,16 @@ function newOBA(nest,maxobs) result(this) allocate(this%O(maxnobs)) allocate(this%B(maxnobs)) allocate(this%A(maxnobs)) + allocate(this%qc(maxnobs)) - this%networks(:) = "NULL" - this%platforms(:) = "NULL" - this%latitudes(:) = 0 - this%longitudes(:) = 0 - this%O(:) = 0 - this%B(:) = 0 - this%A(:) = 0 + this%networks = "NULL" + this%platforms = "NULL" + this%latitudes = 0 + this%longitudes = 0 + this%O = 0 + this%B = 0 + this%A = 0 + this%qc = QC_UNKNOWN end function newOBA @@ -118,14 +137,16 @@ subroutine destroyOBA(this) deallocate(this%latitudes) deallocate(this%longitudes) deallocate(this%O) - deallocate(this%B) + deallocate(this%B) deallocate(this%A) + deallocate(this%qc) end subroutine destroyOBA !--------------------------------------------------------------------------- ! Add new diagnostics from one observation to the data structure. - subroutine assignOBA(this,network,platform,latitude,longitude,O,B,A) + subroutine assignOBA(this,network,platform,latitude,longitude,O,B,A, & + qc, set_qc_good) ! Imports use LIS_logmod, only : LIS_logunit @@ -142,10 +163,12 @@ subroutine assignOBA(this,network,platform,latitude,longitude,O,B,A) real, intent(in) :: O real, intent(in) :: B real, intent(in) :: A + integer, intent(in) :: qc + logical, optional, intent(in) :: set_qc_good ! Local variables integer :: nobs - + ! Sanity check. Since this is intended for an operational system, ! just print a warning and return if we see an array bounds problem. nobs = this%nobs @@ -165,7 +188,15 @@ subroutine assignOBA(this,network,platform,latitude,longitude,O,B,A) this%O(nobs) = O this%B(nobs) = B this%A(nobs) = A - + if (present(set_qc_good)) then + if (set_qc_good .and. qc == QC_UNKNOWN) then + this%qc(nobs) = QC_GOOD + else + this%qc(nobs) = qc + end if + else + this%qc(nobs) = qc + end if end subroutine assignOBA !--------------------------------------------------------------------------- @@ -200,12 +231,16 @@ subroutine writeToFile(this,filename) ! Write OBA information to file write(iunit, *, iostat=istat) & - '# Network Platform latitude longitude O B A' + '# Network Platform latitude longitude O B A QC' do j = 1, this%nobs + if (this%qc(j) == QC_REJECT) cycle + if (trim(this%networks(j)) == "SUPEROB") cycle + if (trim(this%networks(j)) == "SUPERGAGE") cycle write(iunit, 1000, iostat=istat) trim(this%networks(j)), & - trim(this%platforms(j)), this%latitudes(j), this%longitudes(j),& - this%O(j), this%B(j), this%A(j) - 1000 format(a10,1x,a10,1x,f8.3,1x,f8.3,1x,f8.3,1x,f8.3,1x,f8.3) + trim(this%platforms(j)), this%latitudes(j), & + this%longitudes(j),& + this%O(j), this%B(j), this%A(j), qc_string(this%qc(j)+1) +1000 format(a10,1x,a10,1x,f8.3,1x,f8.3,1x,f8.3,1x,f8.3,1x,f8.3,1x,a11) end do ! j ! Close file diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index b6dedf826..ff78c10ee 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -20,6 +20,8 @@ ! ........................................Eric Kemp/SSAI/NASA ! 03 Jun 2020 Removed Box-Cox transform in precipitation analysis ! ........................................Eric Kemp/SSAI/NASA +! 29 Nov 2023 Pass QC-rejected obs to OBA files.......Eric Kemp/SSAI/NASA +! ! ! DESCRIPTION: ! @@ -144,12 +146,6 @@ module USAF_bratsethMod ! Private constants real, parameter :: MISSING = -9999 - ! Quality control flags. Should these be public? - real, parameter :: QC_UNKNOWN = 0 - real, parameter :: QC_GOOD = 1 - real, parameter :: QC_SUSPECT = 2 - real, parameter :: QC_REJECT = 3 - contains !--------------------------------------------------------------------------- @@ -227,6 +223,9 @@ end subroutine USAF_destroyObsData ! FIXME: Merge with USAF_createObsData subroutine initObsData(this) + ! Imports + use USAF_OBAMod, only: QC_UNKNOWN + ! Defaults implicit none @@ -248,9 +247,10 @@ subroutine initObsData(this) end subroutine InitObsData !--------------------------------------------------------------------------- - ! Loops through contents of ObsData structure and counts all obs with - ! "good" quality control flag. + ! Loops through contents of ObsData structure and counts all obs + ! not flagged for rejection. function USAF_countGoodObs(this) result(goodObs) + use USAF_OBAMod, only: QC_REJECT implicit none type(USAF_ObsData), intent(in) :: this integer :: goodObs @@ -259,6 +259,7 @@ function USAF_countGoodObs(this) result(goodObs) goodObs = 0 do i = 1, this%nobs if (this%qc(i) .ne. QC_REJECT) then + ! QC_SUSPECT obs count as "good" so they are included in OBA goodObs = goodObs + 1 end if end do ! i @@ -270,10 +271,11 @@ end function USAF_countGoodObs ! background field at observation is optional (useful for adding ! "superobservations"). subroutine USAF_assignObsData(this,net,platform,ob,lat,lon,sigmaOSqr, & - oErrScaleLength,back) + oErrScaleLength,back,qc) ! Imports use LIS_logmod, only : LIS_logunit + use USAF_OBAmod, only: QC_UNKNOWN ! Defaults implicit none @@ -288,6 +290,7 @@ subroutine USAF_assignObsData(this,net,platform,ob,lat,lon,sigmaOSqr, & real, intent(in) :: sigmaOSqr real, intent(in) :: oErrScaleLength real, optional, intent(in) :: back + integer, optional, intent(in) :: qc ! Local variables integer :: nobs @@ -318,11 +321,16 @@ subroutine USAF_assignObsData(this,net,platform,ob,lat,lon,sigmaOSqr, & end if this%sigmaOSqr(nobs) = sigmaOSqr this%oErrScaleLength(nobs) = oErrScaleLength - this%qc(nobs) = QC_UNKNOWN this%nobs = nobs if (present(back)) then this%back(nobs) = back end if + if (present(qc)) then + this%qc(nobs) = qc + else + this%qc(nobs) = QC_UNKNOWN + end if + ! TRACE_EXIT("bratseth_assign") end subroutine USAF_assignObsData @@ -358,6 +366,7 @@ end subroutine USAF_multObsData subroutine USAF_split6hrGaugeObsData(this,nest,imax,jmax,back4,pcap,p3,p6) ! Imports + use USAF_OBAmod, only: QC_REJECT ! Defaults implicit none @@ -372,7 +381,7 @@ subroutine USAF_split6hrGaugeObsData(this,nest,imax,jmax,back4,pcap,p3,p6) type(USAF_ObsData),intent(out) :: p3 type(USAF_ObsData),intent(out) :: p6 - ! Local variables + ! Local variables integer :: nobs6 real :: tmp_back2(2) real :: tmp_obs2(2) @@ -444,7 +453,7 @@ subroutine USAF_split6hrGaugeObsData(this,nest,imax,jmax,back4,pcap,p3,p6) end if end do - ! Assign + ! Assign if (tmp_obs2(1) .ne. MISSING) then call USAF_assignObsData(p3, this%net(n), this%platform(n), & tmp_obs2(1), this%lat(n), this%lon(n), this%sigmaOSqr(n), & @@ -468,6 +477,7 @@ subroutine USAF_split12hrGaugeObsData(this,nest,imax,jmax,back4,pcap,p3,p6,& p9,p12) ! Imports + use USAF_OBAmod, only: QC_REJECT ! Defaults implicit none @@ -1547,7 +1557,7 @@ subroutine USAF_analyzePrecip(precipAll,nest,back,hourindex,mrgp,precipOBA) use LIS_coreMod, only: LIS_rc, LIS_ews_halo_ind, LIS_ewe_halo_ind, & LIS_nss_halo_ind, LIS_nse_halo_ind, LIS_localPet use LIS_logMod, only: LIS_logunit - use USAF_OBAMod, only: OBA, createOBA,assignOBA + use USAF_OBAMod, only: OBA, createOBA, assignOBA, QC_REJECT ! Defaults implicit none @@ -1605,7 +1615,7 @@ subroutine USAF_analyzePrecip(precipAll,nest,back,hourindex,mrgp,precipOBA) precipAll%net(j), precipAll%platform(j), & precipAll%lat(j), precipAll%lon(j), & precipAll%obs(j), precipAll%back(j), & - A=0.) + A=0., qc=precipAll%qc(j), set_qc_good=.true.) end do ! j call USAF_destroyObsData(precipAll) TRACE_EXIT("bratseth_analyzePrcp") @@ -1801,6 +1811,8 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & use LIS_coreMod, only: LIS_localPet, LIS_rc use LIS_logMod, only : LIS_logunit, LIS_endrun, LIS_endrun use LIS_mpiMod + use USAF_OBAmod, only: QC_REJECT, QC_SUSPECT_BACKQC, & + QC_SUSPECT_SUPERSTATQC ! Defaults implicit none @@ -1891,9 +1903,20 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & ! contributions from neighbors. do j = 1, nobs_cr job = jobs_cr_vector(j) + if (this%qc(job) .eq. QC_REJECT) cycle + ! QC_SUSPECT data not used in analysis, but saved for OBA + if (this%qc(job) .eq. QC_SUSPECT_BACKQC) cycle + if (this%qc(job) .eq. QC_SUSPECT_SUPERSTATQC) cycle + do i = 1, nobs_neighbors iob = iobs_neighbors_vector(i) + if (this%qc(iob) .eq. QC_REJECT) cycle + ! QC_SUSPECT data not used in analysis, but saved + ! for OBA + if (this%qc(iob) .eq. QC_SUSPECT_BACKQC) cycle + if (this%qc(iob) .eq. QC_SUSPECT_SUPERSTATQC) cycle + if (iob .eq. job) then dist = 0 else @@ -1964,6 +1987,9 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & do j = 1, nobs ! Skip bad data if ( this%qc(j) .eq. QC_REJECT) cycle + ! QC_SUSPECT data not used in analysis, but saved for OBA + if ( this%qc(j) .eq. QC_SUSPECT_BACKQC) cycle + if ( this%qc(j) .eq. QC_SUSPECT_SUPERSTATQC) cycle invDataDensities(j) = & invDataDensities(j)*(sigmaBSqr + this%sigmaOSqr(j)) invDataDensities(j) = 1. / invDataDensities(j) @@ -2006,7 +2032,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& use LIS_coreMod, only : LIS_localPet, LIS_rc use LIS_logMod, only : LIS_logunit, LIS_endrun use LIS_mpiMod - use USAF_OBAMod, only: OBA, createOBA, assignOBA + use USAF_OBAMod, only: OBA, createOBA, assignOBA, QC_REJECT, & + QC_SUSPECT_BACKQC, QC_SUSPECT_SUPERSTATQC ! Defaults implicit none @@ -2103,6 +2130,11 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& allocate(pprev_ana(nobs)) allocate(pprev_est(nobs)) + pnew_ana = 0 + pnew_ana_pet = 0 + pnew_est = 0 + pnew_est_pet = 0 + pprev_est(:) = this%back(:) ! First guess pprev_ana(:) = this%back(:) ! First guess sumObsEstimates(:) = 0 @@ -2158,15 +2190,23 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& do j = 1, nobs_cr job = jobs_cr_vector(j) - if (this%qc(job) .eq. QC_REJECT) then - sumObsEstimates_pet(j) = 0 + if (this%qc(job) .eq. QC_REJECT .or. & + this%qc(job) .eq. QC_SUSPECT_BACKQC .or. & + this%qc(job) .eq. QC_SUSPECT_SUPERSTATQC) then + !sumObsEstimates_pet(j) = 0 + sumObsEstimates_pet(job) = 0 ! EMK FIX 20231129 cycle endif + ! We will allow analysis to be calculated at points + ! being monitored, but these points will not contribute + ! observation data. do i = 1, nobs_neighbors iob = iobs_neighbors_vector(i) - if (this%qc(iob) .eq. QC_REJECT) then + if (this%qc(iob) .eq. QC_REJECT .or. & + this%qc(iob) .eq. QC_SUSPECT_BACKQC .or. & + this%qc(iob) .eq. QC_SUSPECT_SUPERSTATQC) then sumObsEstimates_pet(iob) = 0 cycle endif @@ -2274,7 +2314,9 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& do j = 1, nobs - if (this%qc(j) .eq. QC_REJECT) cycle + if (this%qc(j) .eq. QC_REJECT .or. & + this%qc(j) .eq. QC_SUSPECT_BACKQC .or. & + this%qc(j) .eq. QC_SUSPECT_SUPERSTATQC) cycle ! Check for convergence y_prev = pprev_ana(j) @@ -2287,7 +2329,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& done = .false. end if - ! Updates mean absolute differences against observed values + ! Updates mean absolute differences against observed + ! values if (verbose) then icount = icount + 1 y_est = pnew_est(j) @@ -2298,12 +2341,13 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& diff = y_ana - y_obs mad_ana = mad_ana + abs(diff) - ! A crude check for unusually high normalized deviations. - normdev = (y_obs - y_ana)*(y_obs - y_ana)/this%sigmaOSqr(j) + ! A crude check for unusually high normalized + ! deviations. + normdev = (y_obs - y_ana)*(y_obs - y_ana) / & + this%sigmaOSqr(j) if (normdev .gt. 9) then num_high_dev = num_high_dev + 1 end if - end if pprev_est(j) = pnew_est(j) @@ -2360,24 +2404,24 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& ! production, we will allow the program to continue instead of ! aborting. !if (npasses .eq. 100) then - if (npasses .eq. 5) then ! For Ops - - write(LIS_logunit,*) & - '[WARN] Bratseth failed to converge after ',npasses, & - ' iterations!' - write(LIS_logunit,*) & - '[WARN] Will stop iterating' - flush(LIS_logunit) - exit - end if + if (npasses .eq. 5) then ! For Ops + + write(LIS_logunit,*) & + '[WARN] Bratseth failed to converge after ',npasses, & + ' iterations!' + write(LIS_logunit,*) & + '[WARN] Will stop iterating' + flush(LIS_logunit) + exit + end if end do ! Iterate until convergence if (verbose) then if (done) then - write(LIS_logunit,*) & + write(LIS_logunit,*) & '[INFO] Bratseth analysis converged after ',npasses, & ' iterations' - endif + endif write(LIS_logunit,*) & '[INFO] Mean absolute difference against obs: ana: ',mad_ana, & ' est: ',mad_est @@ -2401,6 +2445,8 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& icount = 0 do j = 1, nobs if (this%qc(j) .eq. QC_REJECT) cycle + if (this%qc(j) .eq. QC_SUSPECT_BACKQC) cycle + if (this%qc(j) .eq. QC_SUSPECT_SUPERSTATQC) cycle if (present(skip)) then if (skip(j)) cycle @@ -2417,6 +2463,7 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& varOBA = createOBA(nest, maxobs=good_obs) do j = 1, nobs if (this%qc(j) .eq. QC_REJECT) cycle + ! Keep QC_SUSPECT obs for OBA if (present(skip)) then if (skip(j)) cycle end if @@ -2426,7 +2473,7 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& call assignOBA(varOBA, & this%net(j), this%platform(j), & this%lat(j), this%lon(j), & - O, B, A) + O, B, A, this%qc(j), set_qc_good=.true.) end do ! j end if @@ -2473,6 +2520,8 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& use LIS_logMod, only : LIS_logunit, LIS_endrun use LIS_LMLCMod, only: LIS_LMLC use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT, QC_SUSPECT_BACKQC, & + QC_SUSPECT_SUPERSTATQC ! Defaults implicit none @@ -2574,6 +2623,8 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& ! Skip bad observations. if (this%qc(job) .eq. QC_REJECT) cycle + if (this%qc(job) .eq. QC_SUSPECT_BACKQC) cycle + if (this%qc(job) .eq. QC_SUSPECT_SUPERSTATQC) cycle dist = great_circle_distance(locallat,locallon, & this%lat(job), this%lon(job)) @@ -3169,6 +3220,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) use LIS_coreMod, only: LIS_domain, LIS_rc, LIS_localPet use LIS_logMod, only: LIS_logunit, LIS_endrun use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT, QC_SUSPECT_BACKQC, & + QC_SUSPECT_SUPERSTATQC ! Defaults implicit none @@ -3293,6 +3346,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) ! Skip bad data if ( this%qc(j) .eq. QC_REJECT) cycle + if ( this%qc(j) .eq. QC_SUSPECT_BACKQC) cycle + if ( this%qc(j) .eq. QC_SUSPECT_SUPERSTATQC) cycle ! Screen by type if (present(network)) then @@ -3503,7 +3558,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) num_rejected_obs = 0 do j = 1, nobs if (actions(j) .eq. -1) then - this%qc(j) = QC_REJECT + !this%qc(j) = QC_REJECT + this%qc(j) = QC_SUSPECT_SUPERSTATQC ! Don't use, but save for OBA if (.not. silent_rejects_local) then write(LIS_logunit,*) & '[INFO] superstatQC rejection j: ',j, & @@ -3516,7 +3572,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) endif num_rejected_obs = num_rejected_obs + 1 else if (actions(j) .eq. 1) then - this%qc(j) = QC_REJECT ! Was merged into superob + !this%qc(j) = QC_REJECT ! Was merged into superob + this%qc(j) = QC_SUSPECT_SUPERSTATQC ! Don't use, but save for OBA num_merged_obs = num_merged_obs + 1 end if end do ! j @@ -3592,6 +3649,7 @@ subroutine USAF_dupQC(this) ! Imports use LIS_logMod, only: LIS_logunit use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT ! Defaults implicit none @@ -3987,6 +4045,8 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) ! Imports use LIS_logMod, only: LIS_logunit, LIS_endrun use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT, QC_SUSPECT_BACKQC, & + QC_SUSPECT_SUPERSTATQC ! Defaults implicit none @@ -4028,12 +4088,15 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) ! Skip bad data if ( this%qc(r) .eq. QC_REJECT) cycle + if ( this%qc(r) .eq. QC_SUSPECT_SUPERSTATQC) cycle + if ( this%qc(r) .eq. QC_SUSPECT_BACKQC) cycle errorThresh = 4*sqrt(sigmaBSqr + this%sigmaOSqr(r)) absDiff = abs(this%obs(r) - this%back(r)) if (absDiff .gt. errorThresh) then - this%qc(r) = QC_REJECT + !this%qc(r) = QC_REJECT + this%qc(r) = QC_SUSPECT_BACKQC ! Don't use, but save for OBA reject_count = reject_count + 1 @@ -4047,7 +4110,8 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) ' obs: ',this%obs(r), & ' back: ',this%back(r), & ' abs diff: ', abs(this%obs(r) - this%back(r)), & - ' errorThresh ', errorThresh + ' errorThresh ', errorThresh, & + ' qc: ', this%qc(r) end if end if @@ -4768,6 +4832,7 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) use LIS_coreMod, only: LIS_rc, LIS_domain, LIS_localPet use LIS_logMod, only: LIS_logunit use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT ! Defaults implicit none @@ -4914,7 +4979,7 @@ subroutine USAF_waterQC(this,nest,silent_rejects) use LIS_LMLCMod, only: LIS_LMLC use LIS_logMod, only: LIS_logunit use LIS_mpiMod - + use USAF_OBAmod, only: QC_REJECT ! Defaults implicit none @@ -5009,6 +5074,7 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) LIS_ews_ind, LIS_ewe_ind, LIS_nss_ind, LIS_nse_ind use LIS_logMod, only: LIS_logunit use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT ! Defaults implicit none @@ -5193,6 +5259,7 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) use LIS_logMod, only: LIS_logunit use LIS_snowMod, only: LIS_snow_struc use LIS_mpiMod + use USAF_OBAMod, only: QC_REJECT ! Defaults implicit none @@ -5418,7 +5485,7 @@ subroutine USAF_analyzeScreen(screenObs,nest,back,sigmaBSqr, & use LIS_coreMod, only: LIS_rc, LIS_ews_halo_ind, LIS_ewe_halo_ind, & LIS_nss_halo_ind, LIS_nse_halo_ind, LIS_localPet use LIS_logMod, only: LIS_logunit - use USAF_OBAMod, only: OBA, createOBA, assignOBA + use USAF_OBAMod, only: OBA, createOBA, assignOBA, QC_REJECT ! Defaults implicit none @@ -5471,6 +5538,19 @@ subroutine USAF_analyzeScreen(screenObs,nest,back,sigmaBSqr, & write(LIS_logunit,*)'[INFO] Running dupQC on surface observations' call USAF_dupQC(screenObs) + ! Compare with background field + write(LIS_logunit,*)'[INFO] Running backQC on surface observations' + call USAF_backQC(screenObs,sigmaBSqr) + + ! Create "superobservations" from close reports + ! FIXME: Pass network argument. + new_name = "SUPEROB" + write(LIS_logunit,*)'[INFO] Running superstatQC on surface observations' + call USAF_superstatQC(screenObs,nest,new_name) + type = new_name + call USAF_interpBackToTypeObsData(screenObs,nest, & + LIS_rc%gnc(nest),LIS_rc%gnr(nest),back,type) + ! EMK...Option 2 just captures O and B info, and skips the ! analysis. if (agrmet_struc(nest)%oba_switch .eq. 2) then @@ -5478,30 +5558,18 @@ subroutine USAF_analyzeScreen(screenObs,nest,back,sigmaBSqr, & screenOBA = createOBA(nest,maxobs=goodObs) do j = 1, screenObs%nobs if (screenObs%qc(j) .eq. QC_REJECT) cycle + ! Include the QC_SUSPECT obs in the OBA file call assignOBA(screenOBA, & screenObs%net(j), screenObs%platform(j), & screenObs%lat(j), screenObs%lon(j), & screenObs%obs(j), screenObs%back(j), & - A=0.) + A=0., qc=screenObs%qc(j), set_qc_good=.true.) end do ! j call USAF_destroyObsData(screenObs) TRACE_EXIT("bratseth_analyzeScrn") return ! EMK TEST for O-B end if - ! Compare with background field - write(LIS_logunit,*)'[INFO] Running backQC on surface observations' - call USAF_backQC(screenObs,sigmaBSqr) - - ! Create "superobservations" from close reports - ! FIXME: Pass network argument. - new_name = "SUPEROB" - write(LIS_logunit,*)'[INFO] Running superstatQC on surface observations' - call USAF_superstatQC(screenObs,nest,new_name) - type = new_name - call USAF_interpBackToTypeObsData(screenObs,nest, & - LIS_rc%gnc(nest),LIS_rc%gnr(nest),back,type) - ! At this point, QC is done. Copy the good obs into a new structure ! for the analysis (this will speed up analysis calculations by ! filtering bad obs from the arrays.) @@ -5550,6 +5618,9 @@ end subroutine USAF_analyzeScreen ! been flagged for rejection by quality control. subroutine USAF_filterObsData(this,obsData) + ! Imports + use USAF_OBAMod, only: QC_REJECT + ! Defaults implicit none @@ -5558,18 +5629,20 @@ subroutine USAF_filterObsData(this,obsData) type(USAF_ObsData), intent(in) :: obsData ! Local variables - integer :: j + integer :: j, qc if ( obsData%nobs .eq. 0) return do j = 1, obsData%nobs if (obsData%qc(j) .eq. QC_REJECT) cycle + qc = obsData%qc(j) ! Keep QC_SUSPECT obs for OBA call USAF_assignObsData(this, & obsData%net(j),obsData%platform(j), & obsData%obs(j),obsData%lat(j),obsData%lon(j), & obsData%sigmaOSqr(j), & obsData%oErrScaleLength(j), & - back = obsData%back(j)) + back=obsData%back(j), & + qc=qc) end do ! j end subroutine USAF_filterObsData From 94aac20570b6ea83ef0fbfd0e8b201c2e65489e3 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 11 Dec 2023 15:56:28 -0500 Subject: [PATCH 241/328] Tweaks to declaring SLEEP and MPI calls, to pacify GNU compiler. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 22 ---------------------- lis/metforcing/usaf/readcrd_agrmet.F90 | 5 +---- 2 files changed, 1 insertion(+), 26 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index cc4754641..883e79acf 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -777,8 +777,6 @@ subroutine USAF_getBackNWP(nest,back4,pcp_src, use_twelve, j6hr, findex) integer :: c, r external :: AGRMET_julhr_date10 - external :: MPI_Barrier - external :: sleep TRACE_ENTER("bratseth_getBackNWP") rc = 0 @@ -1872,8 +1870,6 @@ subroutine calc_invDataDensities(this,sigmaBSqr,nest,max_dist, & integer :: imax,jmax logical :: verbose - external :: MPI_Barrier, MPI_ALLREDUCE - verbose = .true. if (present(silent)) then if (silent) verbose = .false. @@ -2098,8 +2094,6 @@ subroutine calc_obsAnalysis(this,sigmaBSqr,nobs,invDataDensities,nest,& real :: O, A integer :: good_obs - external :: MPI_Barrier, MPI_ALLREDUCE - verbose = .true. if (present(silent)) then if (silent) verbose = .false. @@ -2551,8 +2545,6 @@ subroutine calc_gridAnalysis(this,nest,sigmaBSqr,nobs,invDataDensities,& integer :: r_local, c_local integer :: gindex - external :: MPI_Barrier, MPI_ALLREDUCE - ! Sanity checks if (nobs .eq. 0) return @@ -3254,8 +3246,6 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) double precision :: t1, t2 logical :: silent_rejects_local - external :: MPI_Barrier, MPI_Allreduce - ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -3670,8 +3660,6 @@ subroutine USAF_dupQC(this) integer :: ierr logical :: location_issue - external :: MPI_Barrier - nobs = this%nobs if (nobs .eq. 0) then write(LIS_logunit,*)& @@ -4061,8 +4049,6 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) double precision :: t1, t2 logical :: silent_rejects_local - external :: MPI_Barrier - nobs = this%nobs if (nobs .eq. 0) then write(LIS_logunit,*)& @@ -4839,8 +4825,6 @@ subroutine find_LIS_cols_rows(this,nest,cols,rows) integer :: j,r,c,gindex integer :: ierr - external :: MPI_Barrier, MPI_ALLREDUCE - nobs = this%nobs if (nobs .eq. 0) return @@ -4987,8 +4971,6 @@ subroutine USAF_waterQC(this,nest,silent_rejects) integer :: reject_count logical :: silent_rejects_local - external :: MPI_Barrier - ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -5091,8 +5073,6 @@ subroutine USAF_snowQC(this,nest,hourindex,threshold,silent_rejects) real :: threshold_local logical :: silent_rejects_local - external :: MPI_Barrier, MPI_ALLREDUCE - ! Sanity check nobs = this%nobs if (nobs .eq. 0) then @@ -5276,8 +5256,6 @@ subroutine USAF_snowDepthQC(this,nest,silent_rejects) integer :: rglb,cglb integer :: gid - external :: MPI_Barrier, MPI_ALLREDUCE - ! Sanity check nobs = this%nobs if (nobs .eq. 0) then diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 819905484..47635b67f 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -40,7 +40,7 @@ subroutine readcrd_agrmet() use LIS_logMod, only : LIS_logunit, LIS_verify, LIS_abort, & LIS_endrun #if (defined SPMD) - use LIS_mpiMod, only: LIS_MPI_COMM + use LIS_mpiMod #endif use LIS_pluginIndices, only : LIS_agrmetrunId use AGRMET_forcingMod, only : agrmet_struc @@ -64,9 +64,6 @@ subroutine readcrd_agrmet() integer :: ierr logical :: use_nrt_bias_files ! EMK - external :: MPI_Barrier - external :: sleep - call ESMF_ConfigFindLabel(LIS_config,"AGRMET forcing directory:",rc=rc) do n=1,LIS_rc%nnest call ESMF_ConfigGetAttribute(LIS_config,agrmet_struc(n)%agrmetdir,rc=rc) From 0b2b0727218f37a61398f2a9592e8f4441d540c1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 11 Dec 2023 16:45:53 -0500 Subject: [PATCH 242/328] Updated character string lengths to use LIS_CONST_PATH_LEN. --- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index ad1f1f809..220ca1563 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -302,7 +302,9 @@ module AGRMET_forcingMod ! contains the previous and next forcing values, respectively ! \end{description} ! -! !USES: +! !USES: + use LIS_constantsMod, only : LIS_CONST_PATH_LEN + implicit none PRIVATE @@ -721,8 +723,8 @@ module AGRMET_forcingMod real, allocatable :: pcp_back_bias_ratio(:,:) ! EMK Add NRT bias correction toward IMERG-Final Run ! (back_bias_corr == 2) - character(255) :: gfs_nrt_bias_ratio_file - character(255) :: galwem_nrt_bias_ratio_file + character(LIS_CONST_PATH_LEN) :: gfs_nrt_bias_ratio_file + character(LIS_CONST_PATH_LEN) :: galwem_nrt_bias_ratio_file real, allocatable :: gfs_nrt_bias_ratio(:,:) real, allocatable :: galwem_nrt_bias_ratio(:,:) integer :: pcp_back_bias_ratio_month From 2ede759b06787178693527f55a2276847992af7e Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 12 Dec 2023 12:25:04 -0500 Subject: [PATCH 243/328] Add missing "use LIS_masterproc" statement --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 1 + 1 file changed, 1 insertion(+) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 048e40835..46421128a 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -3080,6 +3080,7 @@ subroutine check_grib_file(gribfile,yr1,mo1,da1,hr1,found, & #if (defined USE_GRIBAPI) use grib_api #endif + use LIS_coreMod, only: LIS_masterproc use LIS_logMod, only : LIS_logunit, LIS_abort, LIS_alert, & LIS_verify, LIS_endrun use LIS_mpiMod From 4f27ce02c7052125862d14576f1fc6f27cfbde25 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 10:31:26 -0500 Subject: [PATCH 244/328] Added touch 'done' file at end of batch scripts. Also updated paths in discover batch script for more recent work. --- .../retune_bratseth/scripts/run_autotune_discover.sh | 12 +++++++----- .../retune_bratseth/scripts/run_autotune_hpc11.sh | 1 + 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/lis/utils/usaf/retune_bratseth/scripts/run_autotune_discover.sh b/lis/utils/usaf/retune_bratseth/scripts/run_autotune_discover.sh index 27d104c9e..d342045e9 100644 --- a/lis/utils/usaf/retune_bratseth/scripts/run_autotune_discover.sh +++ b/lis/utils/usaf/retune_bratseth/scripts/run_autotune_discover.sh @@ -1,6 +1,6 @@ #!/bin/sh #SBATCH --job-name=autotune -#SBATCH --time=1:00:00 +#SBATCH --time=0:30:00 #SBATCH --account s1189 #SBATCH --output autotune.slurm.out #Adjust node, core, and hardware constraints here @@ -9,7 +9,7 @@ #Substitute your e-mail here #SBATCH --mail-type=ALL #Set quality of service, if needed. -#SBATCH --qos=debug +##SBATCH --qos=debug #------------------------------------------------------------------------------ # # SCRIPT: run_autotune_discover.sh @@ -50,9 +50,9 @@ NWPVARS=(gage rh2m spd10m t2m) SATVARS=(imerg) # Paths on local system -SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis74_oba_runs/build/LISF/lis/utils/usaf/retune_bratseth/scripts -CFGDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis74_oba_runs/build/LISF/lis/utils/usaf/retune_bratseth/cfgs -BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis74_oba_runs/build/LISF/lis/utils/usaf/retune_bratseth/src +SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/scripts +CFGDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/cfgs +BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/bin # Get the command line arguments to specify the training period. if [ -z "$1" ] ; then @@ -155,6 +155,7 @@ fi i=0 for varname in "${SATVARS[@]}" ; do echo "INFO, Task $i: Calling procOBA_Sat for $varname at `date`" + echo `ls` if [ ! -e procOBA_Sat.$varname.config ] ; then echo "ERROR, procOBA_Sat.$varname.config does not exist!" && exit 1 fi @@ -371,4 +372,5 @@ srun --ntasks=1 --nodes=1 --exclusive --kill-on-bad-exit=1 \ # The end echo "INFO, Completed autotuning at `date`" +touch autotune.job.done exit 0 diff --git a/lis/utils/usaf/retune_bratseth/scripts/run_autotune_hpc11.sh b/lis/utils/usaf/retune_bratseth/scripts/run_autotune_hpc11.sh index 2f81e961d..22418556f 100644 --- a/lis/utils/usaf/retune_bratseth/scripts/run_autotune_hpc11.sh +++ b/lis/utils/usaf/retune_bratseth/scripts/run_autotune_hpc11.sh @@ -362,4 +362,5 @@ srun --ntasks=1 --nodes=1 --exclusive --kill-on-bad-exit=1 \ # The end echo "INFO, Completed autotuning at `date`" +touch autotune.job.done exit 0 From fb8b4adcd4d07d289003c8232bb960bdbfe69197 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 10:35:06 -0500 Subject: [PATCH 245/328] Updated cfg files for recent use on Discover. --- lis/utils/usaf/retune_bratseth/cfgs/autotune.cfg | 10 +++++----- .../retune_bratseth/cfgs/procOBA_NWP.gage.config | 14 +++++++------- .../retune_bratseth/cfgs/procOBA_NWP.rh2m.config | 14 +++++++------- .../retune_bratseth/cfgs/procOBA_NWP.spd10m.config | 14 +++++++------- .../retune_bratseth/cfgs/procOBA_NWP.t2m.config | 14 +++++++------- .../retune_bratseth/cfgs/procOBA_Sat.imerg.config | 14 +++++++------- 6 files changed, 40 insertions(+), 40 deletions(-) diff --git a/lis/utils/usaf/retune_bratseth/cfgs/autotune.cfg b/lis/utils/usaf/retune_bratseth/cfgs/autotune.cfg index a0f0b8212..a42c03905 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/autotune.cfg +++ b/lis/utils/usaf/retune_bratseth/cfgs/autotune.cfg @@ -3,15 +3,15 @@ # [Input] -workdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis75_retune_gfs/work +workdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch -scriptdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis75_retune_gfs/LISF/lis/utils/usaf/retune_bratseth/scripts +scriptdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/scripts -cfgdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis75_retune_gfs/LISF/lis/utils/usaf/retune_bratseth/cfgs +cfgdir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/cfgs -bindir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis75_retune_gfs/LISF/lis/utils/usaf/retune_bratseth/src +bindir: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_master/bin -lis_cfg_template: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis75_retune_gfs/work/lis.config.tmpl +lis_cfg_template: /discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_debug_retune/work_oba_patch/lis.config.new varlist: rh2m,spd10m,t2m,gage,imerg diff --git a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.gage.config b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.gage.config index 0041d7997..96a323a21 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.gage.config +++ b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.gage.config @@ -6,14 +6,14 @@ obtype: Gage use_blacklist: true blacklist_file: blacklist_precip.txt -startyear: 2020 -startmonth: 02 -startday: 02 -starthour: 12 +startyear: 2023 +startmonth: 07 +startday: 04 +starthour: 00 -endyear: 2020 -endmonth: 03 -endday: 07 +endyear: 2023 +endmonth: 08 +endday: 01 endhour: 00 intervalyear: 0 diff --git a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.rh2m.config b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.rh2m.config index 982a002fe..42d1b8f4e 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.rh2m.config +++ b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.rh2m.config @@ -6,14 +6,14 @@ obtype: RH2M use_blacklist: true blacklist_file: blacklist_rh2m.txt -startyear: 2020 -startmonth: 02 -startday: 02 -starthour: 12 +startyear: 2023 +startmonth: 07 +startday: 04 +starthour: 00 -endyear: 2020 -endmonth: 03 -endday: 07 +endyear: 2023 +endmonth: 08 +endday: 01 endhour: 00 intervalyear: 0 diff --git a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.spd10m.config b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.spd10m.config index cdbd268c7..ea59a6753 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.spd10m.config +++ b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.spd10m.config @@ -6,14 +6,14 @@ obtype: SPD10M use_blacklist: true blacklist_file: blacklist_spd10m.txt -startyear: 2020 -startmonth: 02 -startday: 02 -starthour: 12 +startyear: 2023 +startmonth: 07 +startday: 04 +starthour: 00 -endyear: 2020 -endmonth: 03 -endday: 07 +endyear: 2023 +endmonth: 08 +endday: 01 endhour: 00 intervalyear: 0 diff --git a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.t2m.config b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.t2m.config index 81cd070ec..4b51c8dbc 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.t2m.config +++ b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_NWP.t2m.config @@ -6,14 +6,14 @@ obtype: T2M use_blacklist: true blacklist_file: blacklist_t2m.txt -startyear: 2020 -startmonth: 02 -startday: 02 -starthour: 12 +startyear: 2023 +startmonth: 07 +startday: 04 +starthour: 00 -endyear: 2020 -endmonth: 03 -endday: 07 +endyear: 2023 +endmonth: 08 +endday: 01 endhour: 00 intervalyear: 0 diff --git a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_Sat.imerg.config b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_Sat.imerg.config index d4589f014..f69296546 100644 --- a/lis/utils/usaf/retune_bratseth/cfgs/procOBA_Sat.imerg.config +++ b/lis/utils/usaf/retune_bratseth/cfgs/procOBA_Sat.imerg.config @@ -13,14 +13,14 @@ dlon: 1.0 dlat: 1.0 dist_thresh: 25000. -startyear: 2020 -startmonth: 02 -startday: 02 -starthour: 12 +startyear: 2023 +startmonth: 07 +startday: 04 +starthour: 00 -endyear: 2020 -endmonth: 03 -endday: 07 +endyear: 2023 +endmonth: 08 +endday: 01 endhour: 00 intervalyear: 0 From 33b4a37c21144c4378dd02f7adaff66b00330f59 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 10:35:32 -0500 Subject: [PATCH 246/328] Fixed precision for end month, day, and hour. --- lis/utils/usaf/retune_bratseth/scripts/autotune.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/utils/usaf/retune_bratseth/scripts/autotune.py b/lis/utils/usaf/retune_bratseth/scripts/autotune.py index 6cf405b98..f669caefe 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/autotune.py +++ b/lis/utils/usaf/retune_bratseth/scripts/autotune.py @@ -160,9 +160,9 @@ def customize_procoba_nwp(self): "startday: " : f"startday: {self.startdt.day:02d}\n", "starthour: " : f"starthour: {self.startdt.hour:02d}\n", "endyear: " : f"endyear: {self.enddt.year:04d}\n", - "endmonth: " : f"endmonth: {self.enddt.month:04d}\n", - "endday: " : f"endday: {self.enddt.day:04d}\n", - "endhour: " : f"endhour: {self.enddt.hour:04d}\n", + "endmonth: " : f"endmonth: {self.enddt.month:02d}\n", + "endday: " : f"endday: {self.enddt.day:02d}\n", + "endhour: " : f"endhour: {self.enddt.hour:02d}\n", "blacklist_file:" : f"blacklist_file: blacklist_{self.varname}.txt" } with open(cfgfile, "w", encoding="ascii") as file: From e6e3d461199b33e26581535d09201d067887b159 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 10:35:57 -0500 Subject: [PATCH 247/328] Fixed f-string. --- lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py b/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py index 2f6a3bfce..7817199cf 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py +++ b/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py @@ -141,7 +141,7 @@ def create_blacklist(cfgfile, blacklistfilename, yyyymmddhh, dayrange): f"{count_thresh} observations\n" outfile.write(txt) txt = "# Rejecting stations with absolute mean OMB beyond " + \ - "{omb_thresh}\n" + f"{omb_thresh}\n" outfile.write(txt) platforms = list(data.keys()) From 267931c611857cfd56be72ed68bc442e973126e1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 17:05:16 -0500 Subject: [PATCH 248/328] Removed unnecessary include file. --- lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 | 1 - 1 file changed, 1 deletion(-) diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 index 27c1b45a8..ee45b14d1 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 @@ -8,7 +8,6 @@ ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LIS_misc.h" -#include "LIS_NetCDF_inc.h" !BOP ! !ROUTINE: read_SMAPEOPLsm ! \label{read_SMAPEOPLsm} From d9bdf015b06bb0358ff242b7cd33b1bf96a99aa9 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 17:09:24 -0500 Subject: [PATCH 249/328] Removed dead code. --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 50 +----------------------------- 1 file changed, 1 insertion(+), 49 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 86de1e21a..d084ba0ac 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -153,8 +153,6 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & call ESMF_TimeGet(thirdtime, yy=thirdUTCyr, mm=thirdUTCmo, dd=thirdUTCdy, & h=thirdUTChr) -! DO i=1,nrow !ROW LON -! DO j=1,mcol !COL LAT DO j=1,mcol !COL LAT DO i=1,nrow !ROW LON @@ -190,45 +188,10 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & end if if (TS_A > 0 .and. TS_B > 0) then TS = ((wgt)*TS_A) + ((1. - wgt)*TS_B) - ! write(LDT_logunit,*) & - ! 'EMK: i,j,UTChr,firstUTChr,secondUTChr,thirdUTChr,wgt:', & - ! i,j,UTChr(i,j),firstUTChr,secondUTChr,thirdUTChr,wgt else cycle end if -! if(UTChr(i,j).ge.0) then -! !utc_check = UTChr(i,j) - floor(UTChr(i,j)) -! !if(utc_check.le.0.5) then -! ! Ts = ARFS_TS_01(i,j) -! ! else -! ! Ts = ARFS_TS_02(i,j) -! ! endif - -! ! EMK Use linear interpolation between two time periods -! if (firstUTChr == 21 .and. (UTChr(i,j) > 21)) then -! deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 -! wgt = (10800. - deltasec) / 10800. -! else if (UTChr(i,j) < (firstUTChr + 3)) then -! deltasec = ( UTChr(i,j) - firstUTChr ) * 3600 -! wgt = (10800. - deltasec) / 10800. -! ! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, deltasec, wgt = ', & -! ! i,j,firstUTChr,UTChr(i,j),deltasec,wgt - -! else -! wgt = 0 -! write(LDT_logunit,*)'EMK: i,j, firstUTChr, UTChr, wgt = ', & -! i,j,firstUTChr,UTChr(i,j),wgt - -! end if -! if (ARFS_TS_01(i,j) > 0 .and. ARFS_TS_02(i,j) > 0) then -! TS = ((wgt)*ARFS_TS_01(i,j)) + ((1. - wgt)*ARFS_TS_02(i,j)) -! else -! TS = -9999 -! end if - -! endif - IF (tbv.GT.0.0.AND.Ts.GT.0.AND.ARFS_SNOW(i,j).LE.SMAPeOPL%SD_thold.AND.ARFS_BD(i,j).NE.-9999.AND.ARFS_LC(i,j).NE.0.AND.& UTChr(i,j).GE.0) THEN bulkdensity = ARFS_BD(i,j) @@ -241,11 +204,8 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & CALL algo_vpol(real(i),real(j),sm_retrieval, tau_return, retrieval_flag) ARFS_SM(i,j)=sm_retrieval ARFS_SM_FLAG(i,j)=retrieval_flag - ELSE - !PRINT*,i, j, "NO RETRIEVAL" + END IF -! END DO !jj=1,mcol !COL LAT -! END DO !ii=1,nrow !ROW LON END DO !ii=1,nrow !ROW LON END DO !jj=1,mcol !COL LAT @@ -254,15 +214,11 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & L1B_fname_len = len_trim(SMAPFILE) if(SMAPeOPL%L1Btype.eq.1) then !NRT - !retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& - ! trim(SMAPFILE(L1B_dir_len+18:L1B_fname_len-3))//".dat" retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& trim(SMAPFILE(L1B_dir_len+18:L1B_fname_len-3))//".nc" yyyymmdd = trim(SMAPFILE(L1B_fname_len-28:L1B_fname_len-20)) hhmmss = trim(SMAPFILE(L1B_fname_len-19:L1B_fname_len-13)) elseif(SMAPeOPL%L1Btype.eq.2) then !Historical - !retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& - ! trim(SMAPFILE(L1B_dir_len+14:L1B_fname_len-3))//".dat" retrieval_fname = trim(SMAPeOPL%SMoutdir)//"/"//"ARFS_SM_V_"//& trim(SMAPFILE(L1B_dir_len+14:L1B_fname_len-3))//".nc" yyyymmdd = trim(SMAPFILE(L1B_fname_len-28:L1B_fname_len-20)) @@ -270,10 +226,6 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & endif write (LDT_logunit,*) '[INFO] Writing soil moisture retrieval file ', trim(retrieval_fname) -! OPEN(UNIT=151, FILE=retrieval_fname,FORM='UNFORMATTED',ACCESS='DIRECT', RECL=nrow*mcol*4) -! WRITE(UNIT=151, REC = 1) ARFS_SM -! CLOSE(151) - ! NOTE: nrow is actually number of columns, mcol is actually number of ! rows From 547414fea7079ccb5a6798bf4ac7770e7e127ebf Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 13 Dec 2023 17:12:46 -0500 Subject: [PATCH 250/328] Removed dead code. --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 85 ---------------------------- 1 file changed, 85 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 1a6b73372..f9e92965c 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -335,7 +335,6 @@ subroutine LDT_smap_e_oplRun(n) write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) ! EMK...Process subset of fields. - !call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) call SMAPL1BRESAMPLE_subset(smap_L1B_filename(i), & SMAPeOPL%L1Bdir, Orbit, TIMEsec, rc) @@ -349,7 +348,6 @@ subroutine LDT_smap_e_oplRun(n) write (LDT_logunit,*) '[INFO] Resampling ', trim(smap_L1B_filename(i)) allocate(SMAPeOPL%ARFS_TBV_COR(LDT_rc%lnc(n),LDT_rc%lnr(n))) !EMK Process subset of fields. - !call SMAPL1BRESAMPLE(smap_L1B_filename(i),SMAPeOPL%L1Bdir,Orbit,TIMEsec,rc) call SMAPL1BRESAMPLE_subset(smap_L1B_filename(i), & SMAPeOPL%L1Bdir, Orbit, TIMEsec, rc) @@ -414,44 +412,11 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeGet(firsttime, yy=yr_pre, mm=mo_pre, dd=da_pre, & h=hh_pre) - ! yr_pre = yr - ! mo_pre = mo - ! da_pre = da - 1 - ! if(da_pre.eq.0) then - ! mo_pre = mo - 1 - - ! if(mo_pre.eq.0) then - ! yr_pre = yr - 1 - ! mo_pre = 12 - ! da_pre = 31 - ! else - ! if(mo_pre.eq.1.or.& - ! mo_pre.eq.3.or.& - ! mo_pre.eq.5.or.& - ! mo_pre.eq.7.or.& - ! mo_pre.eq.8.or.& - ! mo_pre.eq.10.or.& - ! mo_pre.eq.12) then - ! da_pre = 31 - ! elseif(mo_pre.eq.2) then - ! if(mod(yr,4).eq.0) then - ! da_pre = 29 - ! else - ! da_pre = 28 - ! endif - ! else - ! da_pre = 30 - ! endif - ! endif - ! endif - write(unit=yyyy_01, fmt='(i4.4)') yr_pre write(unit=mm_01, fmt='(i2.2)') mo_pre write(unit=dd_01, fmt='(i2.2)') da_pre yyyymmdd_01 = trim(yyyy_01)//trim(mm_01)//trim(dd_01) write(unit=hh_01, fmt='(i2.2)') hh_pre - !hh_01 = hh - !call readLIS_Teff(n,yyyymmdd_01,hh_01,Orbit,teff_01) call readLIS_Teff_usaf(n, yyyymmdd_01, hh_01, Orbit, teff_01, rc) if (rc .ne. 0) then write(LDT_logunit,*)'[WARN] No Teff data available...' @@ -461,57 +426,11 @@ subroutine LDT_smap_e_oplRun(n) call ESMF_TimeGet(secondtime, yy=yr_02, mm=mo_02, dd=da_02, & h=hr_02) - ! yr_02 = yr_pre - ! mo_02 = mo_pre - ! da_02 = da_pre - ! hr_02 = hr + 1 - - ! if(hr_02.eq.24) then - ! hr_02 = 0 - ! da_02 = da_pre + 1 - - ! if(mo_pre.eq.1.or.& - ! mo_pre.eq.3.or.& - ! mo_pre.eq.5.or.& - ! mo_pre.eq.7.or.& - ! mo_pre.eq.8.or.& - ! mo_pre.eq.10.or.& - ! mo_pre.eq.12) then - ! if(da_02.gt.31) then - ! da_02 = 1 - ! mo_02 = mo_pre + 1 - ! endif - ! elseif(mo_pre.eq.2) then - ! if(mod(yr_02,4).eq.0) then - ! if(da_02.gt.29) then - ! da_02 = 1 - ! mo_02 = mo_pre + 1 - ! endif - ! else - ! if(da_02.gt.28) then - ! da_02 = 1 - ! mo_02 = mo_pre + 1 - ! endif - ! endif - ! else - ! if(da_02.gt.30) then - ! da_02 = 1 - ! mo_02 = mo_pre + 1 - ! endif - ! endif - - ! if(mo_02.gt.12) then - ! mo_02 = 1 - ! yr_02 = yr_pre + 1 - ! endif - ! endif - write(unit=yyyy_02, fmt='(i4.4)') yr_02 write(unit=mm_02, fmt='(i2.2)') mo_02 write(unit=dd_02, fmt='(i2.2)') da_02 write(unit=hh_02, fmt='(i2.2)') hr_02 yyyymmdd_02 = trim(yyyy_02)//trim(mm_02)//trim(dd_02) - !call readLIS_Teff(n,yyyymmdd_02,hh_02,Orbit,teff_02) call readLIS_Teff_usaf(n, yyyymmdd_02, hh_02, Orbit, teff_02, rc) if (rc .ne. 0) then write(LDT_logunit,*)'[WARN] No Teff data available...' @@ -526,7 +445,6 @@ subroutine LDT_smap_e_oplRun(n) write(unit=dd_03, fmt='(i2.2)') da_03 write(unit=hh_03, fmt='(i2.2)') hr_03 yyyymmdd_03 = trim(yyyy_03)//trim(mm_03)//trim(dd_03) - !call readLIS_Teff(n,yyyymmdd_03,hh_03,Orbit,teff_03) call readLIS_Teff_usaf(n, yyyymmdd_03, hh_03, Orbit, teff_03, rc) if (rc .ne. 0) then write(LDT_logunit,*)'[WARN] No Teff data available...' @@ -572,7 +490,6 @@ subroutine LDT_smap_e_oplRun(n) read_L1Bdata = .false. ! Get snow information from LIS outputs - !call readLIS_snow(n,yyyymmdd,hh,SnowDepth) call readUSAFSI(n, yyyymmdd, hh, SnowDepth, rc) if (rc .ne. 0) then write(LDT_logunit,*)'[WARN] No USAFSI data available!' @@ -621,12 +538,10 @@ subroutine search_SMAPL1B_files(ndir,date_curr,L1Btype,suffix) list_files = 'ls '//trim(ndir)//'/SMAP_L1B_TB_NRT_*'//& trim(yyyymmdd)//'T'//trim(hh) & //'*.h5 > SMAP_L1B_filelist_'//trim(tmp)//'.dat' -! //"*.h5 > SMAP_L1B_filelist.dat" elseif(L1Btype.eq.2) then !Historical list_files = 'ls '//trim(ndir)//'/SMAP_L1B_TB_*'//& trim(yyyymmdd)//'T'//trim(hh) & //'*.h5 > SMAP_L1B_filelist_'//trim(tmp)//'.dat' -! //"*.h5 > SMAP_L1B_filelist.dat" endif call system(trim(list_files)) From 83e1b4b2e17f0bb4f868c273d4486485b1927a25 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 14 Dec 2023 13:08:23 -0500 Subject: [PATCH 251/328] Removed dead code. --- ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 55 +------------------ 1 file changed, 1 insertion(+), 54 deletions(-) diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index ea4d50d92..a61fcdf03 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -112,41 +112,12 @@ end subroutine create_lsm_teff_output_filename write(LDT_logunit,*) '[ERR] DA preprocessing on the binary format is not ' write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' call LDT_endrun() - -#if 0 - ftn = LDT_getNextUnitNumber() - open(ftn,file=trim(fname), form='unformatted') - if(file_exists) then - do index=1,LDT_MOC_COUNT - call LDT_readLISSingleBinaryVar(n,ftn,LDT_DAobsDataPtr(n,index)%dataEntryPtr) - enddo - else - print*, 'LSM file ',trim(fname),' does not exist' - print*, 'Program stopping.. ' - stop - endif - call LDT_releaseUnitNumber(ftn) -#endif + elseif(lsmteffobs%format.eq."grib1") then write(LDT_logunit,*) '[ERR] DA preprocessing on the grib1 format is not ' write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' call LDT_endrun() -#if 0 - ftn = LDT_getNextUnitNumber() - open(ftn,file=trim(fname), form='unformatted') - if(file_exists) then - do index=1,LDT_MOC_COUNT - call LDT_readLISSingleBinaryVar(n,ftn,LDT_DAobsDataPtr(n,index)%dataEntryPtr) - enddo - else - print*, 'LSM file ',trim(fname),' does not exist' - print*, 'Program stopping.. ' - stop - endif - call LDT_releaseUnitNumber(ftn) -#endif - elseif(lsmteffobs%format.eq."netcdf") then #if(defined USE_NETCDF3 || defined USE_NETCDF4) @@ -164,20 +135,6 @@ end subroutine create_lsm_teff_output_filename iret = nf90_close(ftn) call LDT_verify(iret,'Error in nf90_close') - !if(lsmteffobs%datares.eq.LDT_rc%gridDesc(n,10)) then - ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - ! 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) - ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - ! 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) - !else - ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - ! 1,lsmteffobs%nc, lsmteffobs%nr, Tsoil01value2d) - ! call LDT_readLISSingleNetcdfVar(n,ftn, vname,& - ! 2,lsmteffobs%nc, lsmteffobs%nr, Tsoil02value2d) - !endif - !iret = nf90_close(ftn) - !call LDT_verify(iret,'Error in nf90_close') - if ((LDT_rc%lnc(n) .ne. lsmteffobs%nc) .or. & (LDT_rc%lnr(n) .ne. lsmteffobs%nr)) then write(LDT_logunit,*)'[ERR] Dimension mismatch for LIS data!' @@ -499,7 +456,6 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & elseif(map_proj.eq."lambert") then fproj = 'L' print *,"fres ",run_dd(6) -! write(unit=fres, fmt='(f2.0)') run_dd(6) write(unit=fres, fmt='(f3.0)') run_dd(6) if (run_dd(6) .ge. 10.) then write(unit=fres, fmt='(i2)') nint(run_dd(6)) @@ -535,15 +491,6 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & fres2 = trim(fres2)//'DEG' endif - ! out_fname = trim(odir)//'/'//& - ! '/PS.AFWA_SC.'//trim(security_class)//& - ! '_DI.'//trim(distribution_class)//& - ! '_DC.'//trim(data_category)//& - ! '_GP.LIS_GR.'//& - ! trim(fproj)//trim(fres2)//& - ! '_AR.'//trim(area_of_data)//& - ! '_PA.'//trim(write_interval)//'-HR-SUM_DD.'//& - ! trim(cdate1)//'_DT.'//trim(cdate)//'_DF.GR1' out_fname = trim(odir)//'/'//& '/PS.AFWA_SC.'//trim(security_class)//& '_DI.'//trim(distribution_class)//& From 47d66d8453895f5f13cbc2f662aca538a70f9db8 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 14 Dec 2023 13:30:51 -0500 Subject: [PATCH 252/328] Some more code cleanup. --- ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 168 +++++++++--------- 1 file changed, 84 insertions(+), 84 deletions(-) diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index a61fcdf03..d24976fa8 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -9,11 +9,11 @@ !-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP -! +! ! !ROUTINE: readLISlsmTEFFobs ! \label{readLISlsmTEFFobs} ! -! !INTERFACE: +! !INTERFACE: subroutine readLISlsmTEFFobs(n) ! !USES: #if(defined USE_NETCDF3 || defined USE_NETCDF4) @@ -29,19 +29,19 @@ subroutine readLISlsmTEFFobs(n) use LISlsmTEFF_obsMod, only : lsmteffobs use LDT_timeMgrMod ! -! !DESCRIPTION: -! This routine reads the soil temperature fields from a LIS model -! simulation. +! !DESCRIPTION: +! This routine reads the soil temperature fields from a LIS model +! simulation. ! !EOP implicit none integer, intent(in) :: n - character*200 :: fname + character*200 :: fname logical :: file_exists real :: teff_data(LDT_rc%lnc(n),LDT_rc%lnr(n)) - + integer :: t, index integer :: ftn integer :: iret @@ -106,35 +106,35 @@ end subroutine create_lsm_teff_output_filename inquire(file=trim(fname),exist=file_exists) - if(file_exists) then + if(file_exists) then write(LDT_logunit,*) '[INFO] reading LSM output ',trim(fname) - if(lsmteffobs%format.eq."binary") then + if(lsmteffobs%format.eq."binary") then write(LDT_logunit,*) '[ERR] DA preprocessing on the binary format is not ' write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' call LDT_endrun() - elseif(lsmteffobs%format.eq."grib1") then + elseif(lsmteffobs%format.eq."grib1") then write(LDT_logunit,*) '[ERR] DA preprocessing on the grib1 format is not ' write(LDT_logunit,*) '[ERR] currently supported. Program stopping....' call LDT_endrun() - elseif(lsmteffobs%format.eq."netcdf") then -#if(defined USE_NETCDF3 || defined USE_NETCDF4) - + elseif(lsmteffobs%format.eq."netcdf") then +#if(defined USE_NETCDF3 || defined USE_NETCDF4) + iret = nf90_open(path=trim(fname),mode=nf90_nowrite, ncid=ftn) call LDT_verify(iret, 'Error opening file '//trim(fname)) - -! The code looks for instantaneous variables. If it doesn't exist, -! the time averaged data fields will be read in. + +! The code looks for instantaneous variables. If it doesn't exist, +! the time averaged data fields will be read in. iret = nf90_inq_varid(ftn, 'SoilTemp_inst', varid) vname = 'SoilTemp_inst' - if(iret.ne.0) then + if(iret.ne.0) then vname = 'SoilTemp_tavg' endif iret = nf90_close(ftn) call LDT_verify(iret,'Error in nf90_close') - + if ((LDT_rc%lnc(n) .ne. lsmteffobs%nc) .or. & (LDT_rc%lnr(n) .ne. lsmteffobs%nr)) then write(LDT_logunit,*)'[ERR] Dimension mismatch for LIS data!' @@ -231,7 +231,7 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & use LDT_coreMod, only : LDT_rc use LDT_logMod - implicit none + implicit none ! !ARGUMENTS: integer, intent(IN) :: n character(len=*) :: fname @@ -246,11 +246,11 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & character(len=*), optional :: data_category character(len=*), optional :: area_of_data character(len=*), optional :: write_interval -! -! !DESCRIPTION: +! +! !DESCRIPTION: ! Create the file name for the output data files. It creates both the GSWP ! style of output filenames and the standard LIS style. The convention used -! in LIS creates a filename in a hierarchical style (output directory, +! in LIS creates a filename in a hierarchical style (output directory, ! model name, date, file extention) ! ! 2 level hierarchy @@ -285,15 +285,15 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & ! DD = date \newline ! DT = data time \newline ! DF = data format \newline -! -! The arguments are: +! +! The arguments are: ! \begin{description} ! \item [n] ! index of the domain or nest ! \item [fname] -! the created file name. +! the created file name. ! \item [model\_name] -! string describing the name of the model +! string describing the name of the model ! \item [writeint] ! output writing interval of the model ! \item [style] @@ -304,7 +304,7 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & character(len=10) :: time character(len=5) :: zone integer, dimension(8) :: values - character(len=20) :: mname + character(len=20) :: mname character(len=10) :: cdate character(len=14) :: cdate1 character(len=2) :: fint @@ -319,32 +319,32 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & integer :: i, c mname = 'SURFACEMODEL' - if(wstyle.eq."4 level hierarchy") then + if(wstyle.eq."4 level hierarchy") then write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & LDT_rc%yr, LDT_rc%mo, & LDT_rc%da, LDT_rc%hr,LDT_rc%mn - + dname = trim(odir)//'/' dname = trim(dname)//trim(mname)//'/' - + write(unit=cdate, fmt='(i4.4)') LDT_rc%yr dname = trim(dname)//trim(cdate)//'/' - + write(unit=cdate, fmt='(i4.4, i2.2, i2.2)') LDT_rc%yr, LDT_rc%mo, LDT_rc%da dname = trim(dname)//trim(cdate) - + out_fname = trim(dname)//'/LIS_HIST_'//trim(cdate1) - - write(unit=cdate, fmt='(a2,i2.2)') '.d',n + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n out_fname = trim(out_fname)//trim(cdate) - + select case ( form ) case ( "binary" ) - if(wopt.eq."1d tilespace") then + if(wopt.eq."1d tilespace") then out_fname = trim(out_fname)//'.ts4r' - elseif(wopt.eq."2d gridspace") then + elseif(wopt.eq."2d gridspace") then out_fname = trim(out_fname)//'.gs4r' - elseif(wopt.eq."1d gridspace") then + elseif(wopt.eq."1d gridspace") then out_fname = trim(out_fname)//'.gs4r' endif case ("grib1") @@ -356,31 +356,31 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & case default call ldt_log_msg('ERR: create_lsm_teff_output_filename -- '// & 'Unrecognized output format') - call LDT_endrun + call LDT_endrun endselect elseif(wstyle.eq."3 level hierarchy") then write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & LDT_rc%yr, LDT_rc%mo, & LDT_rc%da, LDT_rc%hr,LDT_rc%mn - + dname = trim(odir)//'/' dname = trim(dname)//trim(mname)//'/' - + write(unit=cdate, fmt='(i4.4, i2.2)') LDT_rc%yr, LDT_rc%mo dname = trim(dname)//trim(cdate)//'/' out_fname = trim(dname)//'LIS_HIST_'//trim(cdate1) - - write(unit=cdate, fmt='(a2,i2.2)') '.d',n + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n out_fname = trim(out_fname)//trim(cdate) - + select case ( form ) case ("binary") - if(wopt.eq."1d tilespace") then + if(wopt.eq."1d tilespace") then out_fname = trim(out_fname)//'.ts4r' - elseif(wopt.eq."2d gridspace") then + elseif(wopt.eq."2d gridspace") then out_fname = trim(out_fname)//'.gs4r' - elseif(wopt.eq."1d gridspace") then + elseif(wopt.eq."1d gridspace") then out_fname = trim(out_fname)//'.gs4r' endif case ("grib1") @@ -392,28 +392,28 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & case default call ldt_log_msg('ERR: create_lsm_teff_output_filename -- '// & 'Unrecognized form value') - call LDT_endrun + call LDT_endrun endselect elseif(wstyle.eq."2 level hierarchy") then write(unit=cdate1, fmt='(i4.4, i2.2, i2.2, i2.2, i2.2)') & LDT_rc%yr, LDT_rc%mo, & LDT_rc%da, LDT_rc%hr,LDT_rc%mn - + dname = trim(odir)//'/' dname = trim(dname)//trim(mname)//'/' - + out_fname = trim(dname)//'LIS_HIST_'//trim(cdate1) - - write(unit=cdate, fmt='(a2,i2.2)') '.d',n + + write(unit=cdate, fmt='(a2,i2.2)') '.d',n out_fname = trim(out_fname)//trim(cdate) - + select case ( form ) case ("binary") - if(wopt.eq."1d tilespace") then + if(wopt.eq."1d tilespace") then out_fname = trim(out_fname)//'.ts4r' - elseif(wopt.eq."2d gridspace") then + elseif(wopt.eq."2d gridspace") then out_fname = trim(out_fname)//'.gs4r' - elseif(wopt.eq."1d gridspace") then + elseif(wopt.eq."1d gridspace") then out_fname = trim(out_fname)//'.gs4r' endif case ("grib1") @@ -425,9 +425,9 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & case default call ldt_log_msg('ERR: create_lsm_teff_output_filename -- '// & 'Unrecognized form value') - call LDT_endrun + call LDT_endrun endselect - elseif(wstyle.eq."WMO convention") then + elseif(wstyle.eq."WMO convention") then if ( .not. present(run_dd) .or. & .not. present(security_class) .or. & .not. present(distribution_class) .or. & @@ -436,15 +436,15 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & .not. present(write_interval) ) then call ldt_log_msg('ERR: create_lsm_teff_output_filename -- '// & 'missing WMO convention identifiers') - call LDT_endrun + call LDT_endrun endif write(unit=cdate1, fmt='(i4.4, i2.2, i2.2)') & LDT_rc%yr, LDT_rc%mo, LDT_rc%da - + write(unit=cdate, fmt='(i2.2, i2.2)') LDT_rc%hr, LDT_rc%mn - - if(map_proj.eq."polar") then + + if(map_proj.eq."polar") then fproj = 'P' print *,"fres ",run_dd(6) if (run_dd(6) .ge. 10.) then @@ -453,7 +453,7 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & write(unit=fres, fmt='(i1)') nint(run_dd(6)) endif fres2 = trim(fres)//'KM' - elseif(map_proj.eq."lambert") then + elseif(map_proj.eq."lambert") then fproj = 'L' print *,"fres ",run_dd(6) write(unit=fres, fmt='(f3.0)') run_dd(6) @@ -463,19 +463,19 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & write(unit=fres, fmt='(i1)') nint(run_dd(6)) endif fres2 = trim(fres)//'KM' - elseif(map_proj.eq."mercator") then + elseif(map_proj.eq."mercator") then fproj = 'M' write(unit=fres, fmt='(i2.2)') run_dd(6) fres = trim(fres)//'KM' - elseif(map_proj.eq."gaussian") then + elseif(map_proj.eq."gaussian") then fproj = 'G' - write(unit=fres, fmt='(i2.2)') run_dd(5)*100 + write(unit=fres, fmt='(i2.2)') run_dd(5)*100 fres2 = '0P'//trim(fres)//'DEG' else fproj = 'C' write(unit=fres, fmt='(i10)') nint(run_dd(6)*100) read(unit=fres,fmt='(10a1)') (fres1(i),i=1,10) - c = 0 + c = 0 do i=1,10 if(fres1(i).ne.' '.and.c==0) c = i enddo @@ -516,27 +516,27 @@ subroutine create_lsm_teff_output_filename(n, form, fname, odir, wstyle, wopt, & end subroutine create_lsm_teff_output_filename !BOP -! +! ! !ROUTINE: transformDataToLDTgrid_teff ! \label{transformDataToLDTgrid_teff} ! -! !INTERFACE: +! !INTERFACE: subroutine transformDataToLDTgrid_teff(n, teff_inp, teff_out) -! !USES: +! !USES: use LDT_coreMod use LISlsmTEFF_obsMod implicit none -! !ARGUMENTS: - integer :: n +! !ARGUMENTS: + integer :: n real :: teff_inp(lsmteffobs%nc*lsmteffobs%nr) real :: teff_out(LDT_rc%lnc(n),LDT_rc%lnr(n)) ! -! !DESCRIPTION: -! This routine interpolates or upscales the input data to +! !DESCRIPTION: +! This routine interpolates or upscales the input data to ! the LDT grid. If the input data is finer than the LDT ! grid, the input data is upscaled. If the input data is -! coarser, then it is interpolated to the LDT grid. +! coarser, then it is interpolated to the LDT grid. ! !EOP integer :: ios @@ -547,23 +547,23 @@ subroutine transformDataToLDTgrid_teff(n, teff_inp, teff_out) do r=1,lsmteffobs%nr do c=1, lsmteffobs%nc - if(teff_inp(c+(r-1)*lsmteffobs%nc).ne.LDT_rc%udef) then - teff_data_b(c+(r-1)*lsmteffobs%nc) = .true. + if(teff_inp(c+(r-1)*lsmteffobs%nc).ne.LDT_rc%udef) then + teff_data_b(c+(r-1)*lsmteffobs%nc) = .true. else teff_data_b(c+(r-1)*lsmteffobs%nc) = .false. endif - if(teff_inp(c+(r-1)*lsmteffobs%nc).lt.0) then + if(teff_inp(c+(r-1)*lsmteffobs%nc).lt.0) then teff_inp(c+(r-1)*lsmteffobs%nc) = LDT_rc%udef teff_data_b(c+(r-1)*lsmteffobs%nc) = .false. endif enddo enddo - if(LDT_isLDTatAfinerResolution(n,lsmteffobs%datares)) then + if(LDT_isLDTatAfinerResolution(n,lsmteffobs%datares)) then !-------------------------------------------------------------------------- ! Interpolate to the LDT running domain -!-------------------------------------------------------------------------- +!-------------------------------------------------------------------------- call bilinear_interp(LDT_rc%gridDesc(n,:),& teff_data_b, teff_inp, teffobs_b_ip, teffobs_ip, & lsmteffobs%nc*lsmteffobs%nr, & @@ -586,17 +586,17 @@ subroutine transformDataToLDTgrid_teff(n, teff_inp, teff_out) lsmteffobs%nc*lsmteffobs%nr,& LDT_rc%lnc(n)*LDT_rc%lnr(n),LDT_rc%udef, & lsmteffobs%n11,teff_data_b, teff_inp, teffobs_b_ip,teffobs_ip) - + endif - + do r=1,LDT_rc%lnr(n) do c=1,LDT_rc%lnc(n) - if(teffobs_b_ip(c+(r-1)*LDT_rc%lnc(n))) then + if(teffobs_b_ip(c+(r-1)*LDT_rc%lnc(n))) then teff_out(c,r) = teffobs_ip(c+(r-1)*LDT_rc%lnc(n)) else teff_out(c,r) = LDT_rc%udef endif enddo enddo - + end subroutine transformDataToLDTgrid_teff From e306ae4f19842e22bdb0fc2bcdfca18533b041e2 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 14 Dec 2023 15:28:01 -0500 Subject: [PATCH 253/328] Clean up whitespace --- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 2 +- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 10 +-- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 2 +- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 76 ++++++++++----------- ldt/SMAP_E_OPL/invdist_temp2smap.F90 | 10 +-- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 10 +-- 6 files changed, 55 insertions(+), 55 deletions(-) diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index d084ba0ac..3edef91d9 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -32,7 +32,7 @@ subroutine ARFSSMRETRIEVAL(SMAPFILE, & use LDT_ARFSSM_netcdfMod, only: LDT_ARFSSM_write_netcdf use LDT_logMod, only: LDT_logunit USE LDT_smap_e_oplMod - + IMPLICIT NONE ! !ARGUMENTS: CHARACTER (len=100) :: SMAPFILE diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index f9e92965c..f20b9ed67 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -18,10 +18,10 @@ ! 06 Feb 2023: Eric Kemp, now process subset of SMAP fields. ! 14 Feb 2023: Eric Kemp, now uses USAFSI and USAF LIS output. ! 22 Feb 2023: Eric Kemp, ensemble size now in ldt.config file. -! 01 Jul 2023: Mahdi Navari,This edit generates a separate SMAP_filelist -! for each LDT job based on user input. -! Now we can run several LDT jobs in the same directory. -! +! 01 Jul 2023: Mahdi Navari,This edit generates a separate SMAP_filelist +! for each LDT job based on user input. +! Now we can run several LDT jobs in the same directory. +! #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" @@ -111,7 +111,7 @@ subroutine LDT_smap_e_oplInit() call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%L1BresampWriteOpt, rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") - cfg_entry = "SMAP_E_OPL filelist suffix number:" + cfg_entry = "SMAP_E_OPL filelist suffix number:" call ESMF_ConfigFindLabel(LDT_config, trim(cfg_entry), rc=rc) call LDT_verify(rc, trim(cfg_entry)//" not specified") call ESMF_ConfigGetAttribute(LDT_config, SMAPeOPL%SMAPfilelistSuffixNumber, rc=rc) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index 8f00d7d36..d48796bdf 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -55,7 +55,7 @@ subroutine SMAPL1BRESAMPLE_SUBSET(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) ARFS_LAT = LAT(arfs_geo_lat_lo,arfs_geo_lat_up,-arfs_lat_space) ARFS_LON = LON(arfs_geo_lon_lf,arfs_geo_lon_rt,arfs_lon_space) - !Input (Path/filename, datatypes, lat, lon) Return(DATA,LAT,LON,length of row and col) + !Input (Path/filename, datatypes, lat, lon) Return(DATA,LAT,LON,length of row and col) ! READ SMAP_L1B DATA FROM HDF5 ! EMK...Try fault tolerant NRT version. diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 11110d890..717c82a17 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -17,7 +17,7 @@ MODULE invdist_l1b2arfs IMPLICIT NONE CONTAINS - SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, & + SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat_v_l1b, surwat_h_l1b, & netd_v_l1b, netd_h_l1b, lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & ref_lat, ref_lon, arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, & arfs_surwatv, arfs_surwath, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_samplenumv, arfs_samplenumh) @@ -32,34 +32,34 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag - REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon + REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor, arfs_tbh_cor, arfs_tbv, arfs_tbh, arfs_nedtv, arfs_nedth, arfs_surwatv, arfs_surwath REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv, arfs_wt_cor_tbh, arfs_wt_tbv, arfs_wt_tbh, arfs_wt_nedtv, arfs_wt_nedth, arfs_wt_surwatv, arfs_wt_surwath INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv, arfs_samplenumh - + !ALLOCATE(zerodistflag(size(ref_lat),size(ref_lon))) ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) !INITIAL THE OUTPUT VARIABLES arfs_tim=0.0 arfs_tbv_cor=0.0 - arfs_tbh_cor=0.0 + arfs_tbh_cor=0.0 arfs_tbv=0.0 arfs_tbh=0.0 arfs_nedtv=0.0 arfs_nedth=0.0 arfs_surwatv=0.0 arfs_surwath=0.0 - arfs_wt_tim=0.0 + arfs_wt_tim=0.0 arfs_wt_cor_tbv=0.0 - arfs_wt_cor_tbh=0.0 - arfs_wt_tbv=0.0 - arfs_wt_tbh=0.0 - arfs_wt_nedtv=0.0 - arfs_wt_nedth=0.0 - arfs_wt_surwatv=0.0 + arfs_wt_cor_tbh=0.0 + arfs_wt_tbv=0.0 + arfs_wt_tbh=0.0 + arfs_wt_nedtv=0.0 + arfs_wt_nedth=0.0 + arfs_wt_surwatv=0.0 arfs_wt_surwath=0.0 - arfs_samplenumv=0.0 - + arfs_samplenumv=0.0 + DO ii = 1,ncols_l1btb IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN DO jj = 1,nrows_l1btb @@ -85,7 +85,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat else gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) endif - + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center zerodistflag (rr,cc) = 1 @@ -121,29 +121,29 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat END IF ELSE IF (zerodistflag (rr,cc).EQ.0) THEN - + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) + arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (surwat_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwatv(rr,cc) = arfs_surwatv(rr,cc) + surwat_v_l1b(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_surwatv(rr,cc) = arfs_wt_surwatv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_surwatv(rr,cc) = arfs_surwatv(rr,cc) + surwat_v_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_wt_surwatv(rr,cc) = arfs_wt_surwatv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (surwat_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_surwath(rr,cc) = arfs_surwath(rr,cc) + surwat_h_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_surwath(rr,cc) = arfs_surwath(rr,cc) + surwat_h_l1b(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_surwath(rr,cc) = arfs_wt_surwath(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (netd_v_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedtv(rr,cc) = arfs_nedtv(rr,cc) + netd_v_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_nedtv(rr,cc) = arfs_nedtv(rr,cc) + netd_v_l1b(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_nedtv(rr,cc) = arfs_wt_nedtv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (netd_h_l1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_nedth(rr,cc) = arfs_nedth(rr,cc) + netd_h_l1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_nedth(rr,cc) = arfs_nedth(rr,cc) + netd_h_l1b(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_nedth(rr,cc) = arfs_wt_nedth(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) + arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb k=k+1; @@ -154,11 +154,11 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat arfs_samplenumh(rr,cc)=arfs_samplenumh(rr,cc)+1.0 !Sample number only calculate for correct tb END IF IF ((ABS (tbvl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbv(rr,cc) = arfs_tbv(rr,cc) + tbvl1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_tbv(rr,cc) = arfs_tbv(rr,cc) + tbvl1b(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_tbv(rr,cc) = arfs_wt_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF IF ((ABS (tbhl1b(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tbh(rr,cc) = arfs_tbh(rr,cc) + tbhl1b(jj,ii) / SNGL (gcdist*gcdist) + arfs_tbh(rr,cc) = arfs_tbh(rr,cc) + tbhl1b(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_tbh(rr,cc) = arfs_wt_tbh(rr,cc) + 1.0 / SNGL (gcdist*gcdist) END IF END IF !(zerodistflag (rr,cc) = 0) @@ -171,7 +171,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat END DO !jj=1,2 END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) END DO !ii=1,2 - + !APPLY WEIGHTING FUNCTION FOR RESAMPLING WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) arfs_tim = arfs_tim / arfs_wt_tim @@ -200,15 +200,15 @@ SUBROUTINE L1BTB2ARFS_INVDIS(tim, tbvl1b_cor, tbhl1b_cor, tbvl1b, tbhl1b, surwat WHERE(arfs_tbh.NE.0.0.AND.arfs_wt_tbh.NE.0.0) arfs_tbh = arfs_tbh / arfs_wt_tbh END WHERE - + END SUBROUTINE L1BTB2ARFS_INVDIS - + ! EMK...Only process subset of SMAP L1B fields for NRT operations. SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & lat_l1b, lon_l1b, tbv_qual_flag, tbh_qual_flag, & sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & ref_lat, ref_lon, arfs_tim, arfs_tbv_cor) - + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb INTEGER(4), PARAMETER :: qualitybit = 0 REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 @@ -222,7 +222,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv - + ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) !INITIAL THE OUTPUT VARIABLES arfs_tim=0.0 @@ -230,7 +230,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & arfs_wt_tim=0.0 arfs_wt_cor_tbv=0.0 arfs_samplenumv=0.0 - + DO ii = 1,ncols_l1btb IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN DO jj = 1,nrows_l1btb @@ -253,13 +253,13 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & lat2 = DBLE (ref_lat(cc)*d2r) DO rr = rmin,rmax !Lon direction lon2 = DBLE (ref_lon(rr)*d2r) - + if(lat1.eq.lat2.and.lon1.eq.lon2) then gcdist = 0. else gcdist = RE_KM * DACOS ( DSIN (lat1) * DSIN (lat2) + DCOS (lat1) * DCOS (lat2) * DCOS (lon1-lon2) ) endif - + IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center zerodistflag (rr,cc) = 1 @@ -273,7 +273,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & END IF ELSE IF (zerodistflag (rr,cc).EQ.0) THEN - + IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) @@ -284,7 +284,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb k=k+1; END IF - + END IF !(zerodistflag (rr,cc) = 0) END IF !(gcdist < 0.0001D0)! END IF !(gcdist < search_radius) @@ -292,13 +292,13 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & ! END DO !rr = rmin,rmax END DO !rr = rmin,rmax END DO !cc =cmin,cmax - + END IF !(IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(ii,jj),qualitybit,1) == 0) END IF !(ABS (antenna_scan_angle(ii,jj)) <= 360.00) END DO !jj=1,2 END IF !(ABS (sc_nadir_angle(ii)) <= 2.0) END DO !ii=1,2 - + !APPLY WEIGHTING FUNCTION FOR RESAMPLING WHERE(arfs_tim.NE.0.0.AND.arfs_wt_tim.NE.0.0) arfs_tim = arfs_tim / arfs_wt_tim @@ -306,8 +306,8 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & WHERE(arfs_tbv_cor.NE.0.0.AND.arfs_wt_cor_tbv.NE.0.0) arfs_tbv_cor = arfs_tbv_cor / arfs_wt_cor_tbv END WHERE - + deallocate(zerodistflag) ! EMK cleanup memory END SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET - + END MODULE invdist_l1b2arfs diff --git a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 index 9bb418404..e94b24072 100644 --- a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 +++ b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 @@ -23,10 +23,10 @@ SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon, !INITIAL THE OUTPUT VARIABLES zerodistflag=0 - zerodistflag_fine=0 - arfs_smap_temp=0 + zerodistflag_fine=0 + arfs_smap_temp=0 arfs_wt=0 - arfs_fine_temp=0 + arfs_fine_temp=0 arfs_fine_wt=0 !DISAGGREGATE ARFS TEMP TO FINEER GRID (~3km) DO ii=1,1920 @@ -61,7 +61,7 @@ SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon, endif !---------------------------------------kyh !PRINT*, lat1, lon1, lat2, lon2, gcdist - !PRINT*, arfs_temp(ii,jj) + !PRINT*, arfs_temp(ii,jj) IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE !PRINT*,'HERE 0' IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center @@ -74,7 +74,7 @@ SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon, ELSE IF (zerodistflag_fine(rr,cc).EQ.0) THEN !To maintain the corresponding pixel has the same value IF ((ABS (arfs_temp(jj,ii)-(-9999.000)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(0) - arfs_fine_temp(rr,cc) = arfs_fine_temp(rr,cc)+arfs_temp(jj,ii) / SNGL(gcdist) + arfs_fine_temp(rr,cc) = arfs_fine_temp(rr,cc)+arfs_temp(jj,ii) / SNGL(gcdist) arfs_fine_wt(rr,cc) = arfs_fine_wt(rr,cc) + 1.0 / SNGL(gcdist) !PRINT*,'Here 2' ENDIF diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index cf4c8a8b7..b26bb0c39 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -18,11 +18,11 @@ ! ! !REVISION HISTORY: ! 14 FEB 2023: Eric Kemp, Initial Specification -! 1 July 2023: Mahdi Navari, Modified the code to read the unperturbed -! ensemble. This is a temporary fix to overcome the bias in +! 1 July 2023: Mahdi Navari, Modified the code to read the unperturbed +! ensemble. This is a temporary fix to overcome the bias in ! soil temperature from a bug in SMAP soil moisture DA ! PR#1385 -! +! ! !INTERFACE: subroutine readLIS_Teff_usaf(n, yyyymmdd, hh, Orbit, teff, rc) ! !USES: @@ -265,7 +265,7 @@ subroutine read_LIStsoil_data_usaf(n, ntiles, str_tind, ntiles_pergrid, nens, & nens, & SoilTemp_inst_tiles(:,k), & SoilTemp_inst_ensmean_1layer) ! Note to minimize the code chnage: SoilTemp_inst_ensmean_1layer is actually - ! SoilTemp_inst_lastens_1layer (ens #12) + ! SoilTemp_inst_lastens_1layer (ens #12) do r = 1, LDT_rc%lnr(n) do c = 1, LDT_rc%lnc(n) @@ -364,7 +364,7 @@ subroutine calc_gridded_lastens_1layer(n, ntiles, str_tind, ntiles_pergrid, & gid = c + ((r-1) * LDT_rc%gnc(n)) stid = str_tind(gid) if (ntiles_pergrid(gid) > 0) then - m = nens + m = nens tid = stid + m - 1 gvar(c,r) = gvar_tile(tid) end if From 346d0a7ad9ec962a8233ed584d1fe6a8e43c84ef Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 14 Dec 2023 16:19:51 -0500 Subject: [PATCH 254/328] Correct comments --- ldt/SMAP_E_OPL/invdist_temp2smap.F90 | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 index e94b24072..b7283fd46 100644 --- a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 +++ b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 @@ -81,8 +81,6 @@ SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon, ENDIF !(zerodistflag_fine(rr,cc).NE.0) ENDIF !IF (gcdist < 0.0001D0) ENDIF !(gcdist < search_radius) - ! ENDDO !cc=cmin,cmax - ! ENDDO !rr=rmin,rmax ENDDO !rr=rmin,rmax ENDDO !cc=cmin,cmax ENDDO !jj=1:2560 @@ -99,15 +97,13 @@ SUBROUTINE RESAMPLETEMP(arfs_temp,arfs_lat,arfs_lon,arfs_fine_lat,arfs_fine_lon, r=3*jj-1 !3x3 FINE GRID EQ TO A ARFS GRID rmin=r-5 ; IF (rmin < 1) rmin=1 rmax=r+5 ; IF (rmax > size(arfs_fine_lon)) rmax=size(arfs_fine_lon) - ! DO rr=rmin,rmax - ! DO cc=cmin,cmax DO cc=cmin,cmax DO rr=rmin,rmax IF (abs(arfs_fine_temp(rr,cc)).GT.1.0D-7) THEN !DO WHEN T ~0 (change to fillvalue) arfs_smap_temp(jj,ii)=arfs_smap_temp(jj,ii)+arfs_fine_temp(rr,cc); arfs_wt(jj,ii)=arfs_wt(jj,ii)+1.0 !Weight the point 1 ENDIF - ENDDO !cc=cmin,cmax - ENDDO !rr=rmin,rmax + ENDDO !rr=rmin,rmax + ENDDO !cc=cmin,cmax ENDDO !jj=1:2560 ENDDO !ii=1:1920 WHERE(arfs_smap_temp.NE.0.0.AND.arfs_wt.NE.0.0) From 3b34476ba98ef74e6c8d0f4fa76dc1d01bb93941 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 14 Dec 2023 16:26:50 -0500 Subject: [PATCH 255/328] Correct copyright notice --- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index d48796bdf..6cb1d5b15 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA GSFC Land Data Toolkit (LDT) +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! SUBROUTINE: SMAPL1BRESAMPLE From 12dac600758fb60a65fd49babacdf01a980e4375 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 2 Jan 2024 13:04:28 -0500 Subject: [PATCH 256/328] Update copyright notice on LDT files for LISF 7.5.0 public release --- ldt/ANNdata/GCOMW_AMSR2_TB/GCOMWAMSR2TB_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/GCOMW_AMSR2_TB/readGCOMWAMSR2TbANNdata.F90 | 4 ++-- ldt/ANNdata/GHCNsnwd/GHCN_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/GHCNsnwd/readGHCNANNdata.F90 | 4 ++-- ldt/ANNdata/LISlsmSM/LISlsmSM_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/LISlsmSM/readLISlsmSMANNdata.F90 | 4 ++-- ldt/ANNdata/LPRM_AMSREsm/LPRM_AMSREsm_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/LPRM_AMSREsm/readLPRM_AMSRE_ANNdata.F90 | 4 ++-- ldt/ANNdata/MOD10A1/MOD10A1_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/MOD10A1/readMOD10A1ANNdata.F90 | 4 ++-- ldt/ANNdata/MODIS_LST/MODISlst_ANNdataMod.F90 | 4 ++-- ldt/ANNdata/MODIS_LST/readMODISlstANNdata.F90 | 4 ++-- ldt/ANNdata/synthetic_sm/readsyntheticsmANNdata.F90 | 4 ++-- ldt/ANNdata/synthetic_sm/syntheticsm_ANNdataMod.F90 | 4 ++-- ldt/DAobs/ANSA_SNWD/ANSASNWDsnow_obsMod.F90 | 4 ++-- ldt/DAobs/ANSA_SNWD/readANSASNWDsnowObs.F90 | 4 ++-- ldt/DAobs/ASCAT_TUW/ASCATTUWsm_obsMod.F90 | 4 ++-- ldt/DAobs/ASCAT_TUW/readASCATTUWsmObs.F90 | 4 ++-- ldt/DAobs/Aquarius_L2sm/AquariusL2sm_obsMod.F90 | 4 ++-- ldt/DAobs/Aquarius_L2sm/readAquariusL2smObs.F90 | 4 ++-- ldt/DAobs/CDFS_GVF/CDFS_GVF_obsMod.F90 | 2 +- ldt/DAobs/CDFS_GVF/readCDFS_GVFObs.F90 | 2 +- ldt/DAobs/ESACCI_sm/ESACCIsm_obsMod.F90 | 4 ++-- ldt/DAobs/ESACCI_sm/readESACCIsmObs.F90 | 4 ++-- ldt/DAobs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 | 4 ++-- ldt/DAobs/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 | 4 ++-- ldt/DAobs/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 | 4 ++-- ldt/DAobs/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 | 4 ++-- ldt/DAobs/GEOS_FP_TEFFobs/GEOSTEFF_obsMod.F90 | 2 +- ldt/DAobs/GEOS_FP_TEFFobs/readGEOSTEFFObs.F90 | 4 ++-- ldt/DAobs/GLASSlai/GLASSlai_obsMod.F90 | 4 ++-- ldt/DAobs/GLASSlai/readGLASSlaiObs.F90 | 4 ++-- ldt/DAobs/GRACEQL_tws/GRACEQLtws_obsMod.F90 | 4 ++-- ldt/DAobs/GRACEQL_tws/readGRACEQLtwsObs.F90 | 4 ++-- ldt/DAobs/GRACE_tws/GRACEtws_obsMod.F90 | 4 ++-- ldt/DAobs/GRACE_tws/readGRACEtwsObs.F90 | 4 ++-- ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 | 4 ++-- ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 | 4 ++-- ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 | 4 ++-- ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 | 4 ++-- ldt/DAobs/LISlsmSMobs/LISlsmSM_obsMod.F90 | 4 ++-- ldt/DAobs/LISlsmSMobs/readLISlsmSMObs.F90 | 4 ++-- ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 | 2 +- ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 | 2 +- ldt/DAobs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 | 4 ++-- ldt/DAobs/LPRM_AMSREsm/readLPRM_AMSREsmObs.F90 | 4 ++-- ldt/DAobs/LPRMvod/LPRMvod_obsMod.F90 | 4 ++-- ldt/DAobs/LPRMvod/readLPRMvodObs.F90 | 4 ++-- ldt/DAobs/MCD15A2H_LAI/MCD15A2Hlai_obsMod.F90 | 4 ++-- ldt/DAobs/MCD15A2H_LAI/readMCD15A2HlaiObs.F90 | 4 ++-- ldt/DAobs/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 | 4 ++-- ldt/DAobs/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 | 4 ++-- ldt/DAobs/NASA_SMAPsm/NASASMAPsm_obsMod.F90 | 4 ++-- ldt/DAobs/NASA_SMAPsm/readNASASMAPsmObs.F90 | 4 ++-- ldt/DAobs/NASA_SMAPvod/NASASMAPvod_obsMod.F90 | 4 ++-- ldt/DAobs/NASA_SMAPvod/readNASASMAPvodObs.F90 | 4 ++-- ldt/DAobs/SMAP_E_OPLsm/SMAPEOPL_SM_obsMod.F90 | 2 +- ldt/DAobs/SMAP_E_OPLsm/readSMAPEOPL_SMObs.F90 | 2 +- ldt/DAobs/SMMR_SNWD/SMMRSNWDsnow_obsMod.F90 | 4 ++-- ldt/DAobs/SMMR_SNWD/readSMMRSNWDsnowObs.F90 | 4 ++-- ldt/DAobs/SMOPS/SMOPSsm_obsMod.F90 | 4 ++-- ldt/DAobs/SMOPS/readSMOPSsmObs.F90 | 4 ++-- ldt/DAobs/SMOS_L2sm/SMOSL2sm_obsMod.F90 | 4 ++-- ldt/DAobs/SMOS_L2sm/readSMOSL2smObs.F90 | 4 ++-- ldt/DAobs/SMOS_NESDIS/SMOSNESDISsm_obsMod.F90 | 4 ++-- ldt/DAobs/SMOS_NESDIS/readSMOSNESDISsmObs.F90 | 4 ++-- ldt/DAobs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_obsMod.F90 | 4 ++-- ldt/DAobs/SMOS_NRTNN_L2sm/readSMOSNRTNNL2smObs.F90 | 4 ++-- ldt/DAobs/SMOS_NRTNN_L2sm/write_lookup_table.F90 | 4 ++-- ldt/DAobs/SSMI_SNWD/SSMISNWDsnow_obsMod.F90 | 4 ++-- ldt/DAobs/SSMI_SNWD/readSSMISNWDsnowObs.F90 | 4 ++-- ldt/DAobs/THySM/THySM_obsMod.F90 | 4 ++-- ldt/DAobs/THySM/readTHySMobs.F90 | 4 ++-- ldt/DAobs/VIIRS_GVF/VIIRS_GVF_obsMod.F90 | 2 +- ldt/DAobs/VIIRS_GVF/readVIIRS_GVFObs.F90 | 2 +- ldt/DAobs/WindSat_sm/WindSatsm_obsMod.F90 | 4 ++-- ldt/DAobs/WindSat_sm/readWindSatsmObs.F90 | 4 ++-- ldt/DAobs/simGRACE_JPL/readsimGRACEJPLObs.F90 | 4 ++-- ldt/DAobs/simGRACE_JPL/simGRACEJPL_obsMod.F90 | 4 ++-- ldt/DAobs/synthetic_sm/readsyntheticsmObs.F90 | 4 ++-- ldt/DAobs/synthetic_sm/syntheticsm_obsMod.F90 | 4 ++-- ldt/MetforcScale/LDT_SimpleWeight_TdscaleMod.F90 | 4 ++-- ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 | 8 +++++++- ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 | 4 ++-- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 2 +- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 | 8 +++++++- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 2 +- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 8 +++++++- ldt/SMAP_E_OPL/readLISTeff.F90 | 4 ++-- ldt/SMAP_E_OPL/readLISTeff_usaf.F90 | 4 ++-- ldt/SMAP_E_OPL/readLISsnow.F90 | 4 ++-- ldt/SMAP_E_OPL/readUSAFSI.F90 | 4 ++-- ldt/SMAP_E_OPL/read_DailyTeffStats.F90 | 4 ++-- ldt/SMAP_E_OPL/scale_teff.F90 | 4 ++-- ldt/USAFSI/LDT_bratsethMod.F90 | 4 ++-- ldt/USAFSI/LDT_usafsiMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_amsr2Mod.F90 | 4 ++-- ldt/USAFSI/USAFSI_analysisMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_arraysMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_binary.F90 | 4 ++-- ldt/USAFSI/USAFSI_galwemMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_gofsMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_lisMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_netcdfMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_paramsMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_run.F90 | 4 ++-- ldt/USAFSI/USAFSI_ssmisMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_utilMod.F90 | 4 ++-- ldt/USAFSI/USAFSI_xcalgmiMod.F90 | 4 ++-- ldt/arch/Config.pl | 4 ++-- ldt/compile | 4 ++-- ldt/configure | 4 ++-- ldt/core/LDT_ANNMod.F90 | 4 ++-- ldt/core/LDT_ANNdata_FTable.c | 4 ++-- ldt/core/LDT_CDFMod.F90 | 4 ++-- ldt/core/LDT_DAmetricsDataMod.F90 | 4 ++-- ldt/core/LDT_DAmetricsMod.F90 | 4 ++-- ldt/core/LDT_DAobsDataMod.F90 | 4 ++-- ldt/core/LDT_DAobs_FTable.c | 4 ++-- ldt/core/LDT_DAobservationsMod.F90 | 4 ++-- ldt/core/LDT_DApreprocMod.F90 | 4 ++-- ldt/core/LDT_DrangeMod.F90 | 4 ++-- ldt/core/LDT_FORC_AttributesMod.F90 | 4 ++-- ldt/core/LDT_LMLCMod.F90 | 4 ++-- ldt/core/LDT_LSMCropModifier_Mod.F90 | 4 ++-- ldt/core/LDT_LSMparamProcMod.F90 | 4 ++-- ldt/core/LDT_LSMparams_FTable.c | 4 ++-- ldt/core/LDT_MuMod.F90 | 4 ++-- ldt/core/LDT_NUWRFprocMod.F90 | 4 ++-- ldt/core/LDT_NatRunData_FTable.c | 4 ++-- ldt/core/LDT_OPTUEMod.F90 | 4 ++-- ldt/core/LDT_OSSEmaskData_FTable.c | 4 ++-- ldt/core/LDT_PRIV_gridMod.F90 | 4 ++-- ldt/core/LDT_PRIV_rcMod.F90 | 4 ++-- ldt/core/LDT_PRIV_tileMod.F90 | 4 ++-- ldt/core/LDT_SigmaMod.F90 | 4 ++-- ldt/core/LDT_SurfaceTypeMod.F90 | 4 ++-- ldt/core/LDT_albedoMod.F90 | 4 ++-- ldt/core/LDT_albedo_FTable.c | 4 ++-- ldt/core/LDT_binaryIOlayer_module.F90 | 4 ++-- ldt/core/LDT_climateParmsMod.F90 | 4 ++-- ldt/core/LDT_climoRstProcMod.F90 | 4 ++-- ldt/core/LDT_climparms_FTable.c | 4 ++-- ldt/core/LDT_constantsMod.F90 | 4 ++-- ldt/core/LDT_coreMod.F90 | 4 ++-- ldt/core/LDT_create_subdirs.c | 4 ++-- ldt/core/LDT_domainMod.F90 | 4 ++-- ldt/core/LDT_domain_FTable.c | 4 ++-- ldt/core/LDT_ensRstMod.F90 | 4 ++-- ldt/core/LDT_fileIOMod.F90 | 4 ++-- ldt/core/LDT_forcingparms_Ftable.c | 4 ++-- ldt/core/LDT_gfracMod.F90 | 4 ++-- ldt/core/LDT_gfrac_FTable.c | 4 ++-- ldt/core/LDT_glacierFractionMod.F90 | 4 ++-- ldt/core/LDT_glacierMod.F90 | 4 ++-- ldt/core/LDT_glacier_FTable.c | 4 ++-- ldt/core/LDT_gridmappingMod.F90 | 4 ++-- ldt/core/LDT_historyMod.F90 | 4 ++-- ldt/core/LDT_irrig_Ftable.c | 4 ++-- ldt/core/LDT_irrigationMod.F90 | 4 ++-- ldt/core/LDT_laisaiMod.F90 | 4 ++-- ldt/core/LDT_laisai_FTable.c | 4 ++-- ldt/core/LDT_lakeParamProcMod.F90 | 4 ++-- ldt/core/LDT_lakeparams_FTable.c | 4 ++-- ldt/core/LDT_landcover_FTable.c | 4 ++-- ldt/core/LDT_logMod.F90 | 4 ++-- ldt/core/LDT_mapSurfaceModelType.F90 | 4 ++-- ldt/core/LDT_mask_FTable.c | 4 ++-- ldt/core/LDT_metforcDscaleMod.F90 | 4 ++-- ldt/core/LDT_metforcdscale_FTable.c | 4 ++-- ldt/core/LDT_metforcingMod.F90 | 4 ++-- ldt/core/LDT_metforcingParmsMod.F90 | 4 ++-- ldt/core/LDT_metforcing_FTable.c | 4 ++-- ldt/core/LDT_mpDecomp.c | 4 ++-- ldt/core/LDT_mpiMod.F90 | 4 ++-- ldt/core/LDT_noahparms_FTable.c | 4 ++-- ldt/core/LDT_numericalMethodsMod.F90 | 4 ++-- ldt/core/LDT_obsSimMod.F90 | 4 ++-- ldt/core/LDT_openwaterMod.F90 | 4 ++-- ldt/core/LDT_paramDataMod.F90 | 4 ++-- ldt/core/LDT_paramMaskCheckMod.F90 | 4 ++-- ldt/core/LDT_paramOptCheckMod.F90 | 4 ++-- ldt/core/LDT_paramProcMod.F90 | 4 ++-- ldt/core/LDT_paramTileInputMod.F90 | 4 ++-- ldt/core/LDT_ran2_gasdev.F90 | 4 ++-- ldt/core/LDT_readConfig.F90 | 4 ++-- ldt/core/LDT_routingParamProcMod.F90 | 4 ++-- ldt/core/LDT_routingparams_FTable.c | 4 ++-- ldt/core/LDT_rstTransformProcMod.F90 | 4 ++-- ldt/core/LDT_runmode_FTable.c | 4 ++-- ldt/core/LDT_soilsMod.F90 | 4 ++-- ldt/core/LDT_soils_FTable.c | 4 ++-- ldt/core/LDT_spatialDownscalingMod.F90 | 4 ++-- ldt/core/LDT_statDscaleMod.F90 | 4 ++-- ldt/core/LDT_statdscale_FTable.c | 4 ++-- ldt/core/LDT_timeMgrMod.F90 | 4 ++-- ldt/core/LDT_topoMod.F90 | 4 ++-- ldt/core/LDT_topo_FTable.c | 4 ++-- ldt/core/LDT_vegdataMod.F90 | 4 ++-- ldt/core/readzipf.c | 4 ++-- ldt/domains/UTM/readinput_UTM.F90 | 4 ++-- ldt/domains/easev2/readinput_easev2.F90 | 4 ++-- ldt/domains/gaussian/gaussian_quadrature.F90 | 4 ++-- ldt/domains/gaussian/readinput_gaussian.F90 | 4 ++-- ldt/domains/hrap/readinput_hrap.F90 | 4 ++-- ldt/domains/lambert/readinput_lambert.F90 | 4 ++-- ldt/domains/latlon/readinput_latlon.F90 | 4 ++-- ldt/domains/merc/readinput_merc.F90 | 4 ++-- ldt/domains/polar/readinput_polar.F90 | 4 ++-- ldt/interp/UTM_utils.F90 | 4 ++-- ldt/interp/bilinear_interp.F90 | 4 ++-- ldt/interp/bilinear_interp_input.F90 | 4 ++-- ldt/interp/bilinear_interp_input_withgrid.F90 | 4 ++-- ldt/interp/breakpt_module.F90 | 4 ++-- ldt/interp/compute_earth_coord.F90 | 4 ++-- ldt/interp/compute_earth_coord_UTM.F90 | 4 ++-- ldt/interp/compute_earth_coord_ease.F90 | 4 ++-- ldt/interp/compute_earth_coord_gauss.F90 | 4 ++-- ldt/interp/compute_earth_coord_hrap.F90 | 4 ++-- ldt/interp/compute_earth_coord_lambert.F90 | 4 ++-- ldt/interp/compute_earth_coord_latlon.F90 | 4 ++-- ldt/interp/compute_earth_coord_latlon_ll.F90 | 4 ++-- ldt/interp/compute_earth_coord_latlon_ur.F90 | 4 ++-- ldt/interp/compute_earth_coord_ll.F90 | 4 ++-- ldt/interp/compute_earth_coord_merc.F90 | 4 ++-- ldt/interp/compute_earth_coord_polar.F90 | 4 ++-- ldt/interp/compute_earth_coord_ur.F90 | 4 ++-- ldt/interp/compute_grid_coord.F90 | 4 ++-- ldt/interp/compute_grid_coord_ease.F90 | 4 ++-- ldt/interp/compute_grid_coord_gauss.F90 | 4 ++-- ldt/interp/compute_grid_coord_hrap.F90 | 4 ++-- ldt/interp/compute_grid_coord_lambert.F90 | 4 ++-- ldt/interp/compute_grid_coord_latlon.F90 | 4 ++-- ldt/interp/compute_grid_coord_merc.F90 | 4 ++-- ldt/interp/compute_grid_coord_polar.F90 | 4 ++-- ldt/interp/compute_stnwts.F90 | 4 ++-- ldt/interp/compute_vinterp_weights.F90 | 4 ++-- ldt/interp/conserv_interp.F90 | 4 ++-- ldt/interp/conserv_interp_input.F90 | 4 ++-- ldt/interp/conserv_interp_input_withgrid.F90 | 4 ++-- ldt/interp/diff_lon.F90 | 4 ++-- ldt/interp/ezlh_convert.F90 | 4 ++-- ldt/interp/ezlh_inverse.F90 | 4 ++-- ldt/interp/gaussian_mod.F90.keep | 4 ++-- ldt/interp/gaussian_routines.F90 | 4 ++-- ldt/interp/gausslat.F90 | 4 ++-- ldt/interp/get_fieldpos.F90 | 4 ++-- ldt/interp/hrapToLatLon.F90 | 4 ++-- ldt/interp/idw_module.F90 | 4 ++-- ldt/interp/interp_stndata.F90 | 4 ++-- ldt/interp/latlonTohrap.F90 | 4 ++-- ldt/interp/latlonTopolar.F90 | 4 ++-- ldt/interp/lltops.F90 | 4 ++-- ldt/interp/map_utils.F90 | 4 ++-- ldt/interp/mqb_module.F90 | 4 ++-- ldt/interp/neighbor_interp.F90 | 4 ++-- ldt/interp/neighbor_interp_input.F90 | 4 ++-- ldt/interp/neighbor_interp_input_withgrid.F90 | 4 ++-- ldt/interp/normalize_stnwts.F90 | 4 ++-- ldt/interp/polarToLatLon.F90 | 4 ++-- ldt/interp/polfixs.F90 | 4 ++-- ldt/interp/pstoll.F90 | 4 ++-- ldt/interp/stninterp_module.F90 | 4 ++-- ldt/interp/upscaleByAveraging.F90 | 4 ++-- ldt/interp/upscaleByAveraging_input.F90 | 4 ++-- ldt/interp/upscaleByCnt.F90 | 4 ++-- ldt/interp/upscaleByMode.F90 | 4 ++-- ldt/interp/vinterp.F90 | 4 ++-- ldt/interp/zterp.F90 | 4 ++-- ldt/lib/xmrg/LDT_xmrg_reader.F90 | 4 ++-- ldt/main/LDTmain.F90 | 4 ++-- ldt/make/makedep.py | 4 ++-- ldt/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 | 4 ++-- ldt/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 | 4 ++-- ldt/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 | 4 ++-- ldt/metforcing/3B42V6/finalize_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V6/get_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V6/interp_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V6/read_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 | 4 ++-- ldt/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 | 4 ++-- ldt/metforcing/3B42V7/finalize_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/3B42V7/get_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/3B42V7/interp_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/3B42V7/read_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 | 4 ++-- ldt/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 | 4 ++-- ldt/metforcing/RFE2Daily/finalize_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/get_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/reproject_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/reset_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 | 4 ++-- ldt/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 | 4 ++-- ldt/metforcing/RFE2gdas/finalize_RFE2gdas.F90 | 4 ++-- ldt/metforcing/RFE2gdas/get_RFE2gdas.F90 | 4 ++-- ldt/metforcing/RFE2gdas/readRFE2gdascrd.F90 | 4 ++-- ldt/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 | 4 ++-- ldt/metforcing/RFE2gdas/reproject_RFE2gdas.F90 | 4 ++-- ldt/metforcing/RFE2gdas/reset_RFE2gdas.F90 | 4 ++-- ldt/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 | 4 ++-- ldt/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 | 4 ++-- ldt/metforcing/WRFAKdom/read_WRFAK_elev.F90 | 4 ++-- ldt/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 | 4 ++-- ldt/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 | 4 ++-- ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 | 4 ++-- ldt/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 | 4 ++-- ldt/metforcing/agrradps/agrradps_forcingMod.F90 | 4 ++-- ldt/metforcing/chirps2/chirps2_forcingMod.F90 | 4 ++-- ldt/metforcing/chirps2/finalize_chirps2.F90 | 4 ++-- ldt/metforcing/chirps2/get_chirps2.F90 | 4 ++-- ldt/metforcing/chirps2/read_chirps2.F90 | 4 ++-- ldt/metforcing/chirps2/readconfig_chirps2.F90 | 4 ++-- ldt/metforcing/chirps2/reset_chirps2.F90 | 4 ++-- ldt/metforcing/chirps2/timeinterp_chirps2.F90 | 4 ++-- ldt/metforcing/cmap/cmap_forcingMod.F90 | 4 ++-- ldt/metforcing/cmap/finalize_cmap.F90 | 4 ++-- ldt/metforcing/cmap/get_cmap.F90 | 4 ++-- ldt/metforcing/cmap/interp_cmap.F90 | 4 ++-- ldt/metforcing/cmap/read_cmap.F90 | 4 ++-- ldt/metforcing/cmap/readcrd_cmap.F90 | 4 ++-- ldt/metforcing/cmap/reset_cmap.F90 | 4 ++-- ldt/metforcing/cmap/timeinterp_cmap.F90 | 4 ++-- ldt/metforcing/cmorph/cm_readzipf.c | 4 ++-- ldt/metforcing/cmorph/cmorph_forcingMod.F90 | 4 ++-- ldt/metforcing/cmorph/finalize_cmorph.F90 | 4 ++-- ldt/metforcing/cmorph/get_cmorph.F90 | 4 ++-- ldt/metforcing/cmorph/interp_cmorph.F90 | 4 ++-- ldt/metforcing/cmorph/read_cmorph.F90 | 4 ++-- ldt/metforcing/cmorph/readcrd_cmorph.F90 | 4 ++-- ldt/metforcing/cmorph/timeinterp_cmorph.F90 | 4 ++-- ldt/metforcing/ecmwf/ecmwf_forcingMod.F90 | 4 ++-- ldt/metforcing/ecmwf/finalize_ecmwf.F90 | 4 ++-- ldt/metforcing/ecmwf/get_ecmwf.F90 | 4 ++-- ldt/metforcing/ecmwf/read_ecmwf.F90 | 4 ++-- ldt/metforcing/ecmwf/read_ecmwf_elev.F90 | 4 ++-- ldt/metforcing/ecmwf/read_ecmwfelev_ldtproc.F90 | 4 ++-- ldt/metforcing/ecmwf/readcrd_ecmwf.F90 | 4 ++-- ldt/metforcing/ecmwf/reset_ecmwf.F90 | 4 ++-- ldt/metforcing/ecmwf/timeinterp_ecmwf.F90 | 4 ++-- ldt/metforcing/era5/era5_forcingMod.F90 | 4 ++-- ldt/metforcing/era5/finalize_era5.F90 | 4 ++-- ldt/metforcing/era5/get_era5.F90 | 4 ++-- ldt/metforcing/era5/read_era5.F90 | 4 ++-- ldt/metforcing/era5/read_era5_elev.F90 | 4 ++-- ldt/metforcing/era5/readcrd_era5.F90 | 4 ++-- ldt/metforcing/era5/reset_era5.F90 | 4 ++-- ldt/metforcing/era5/timeinterp_era5.F90 | 4 ++-- ldt/metforcing/gdas/create_gdasf9_filename.F90 | 4 ++-- ldt/metforcing/gdas/create_gdasfilename.F90 | 4 ++-- ldt/metforcing/gdas/finalize_gdas.F90 | 4 ++-- ldt/metforcing/gdas/gdas_forcingMod.F90 | 4 ++-- ldt/metforcing/gdas/get_gdas.F90 | 4 ++-- ldt/metforcing/gdas/read_gdas.F90 | 4 ++-- ldt/metforcing/gdas/read_gdas_elev.F90 | 4 ++-- ldt/metforcing/gdas/read_gdaselev_ldtproc.F90 | 4 ++-- ldt/metforcing/gdas/readcrd_gdas.F90 | 4 ++-- ldt/metforcing/gdas/reset_gdas.F90 | 4 ++-- ldt/metforcing/gdas/timeinterp_gdas.F90 | 4 ++-- ldt/metforcing/geos5fcst/finalize_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/geos5fcst_forcingMod.F90 | 4 ++-- ldt/metforcing/geos5fcst/get_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/interp_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/read_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/readcrd_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/reset_geos5fcst.F90 | 4 ++-- ldt/metforcing/geos5fcst/timeinterp_geos5fcst.F90 | 4 ++-- ldt/metforcing/gfs/create_gfs_f0backup_filename.F90 | 4 ++-- ldt/metforcing/gfs/create_gfsfilename.F90 | 4 ++-- ldt/metforcing/gfs/finalize_gfs.F90 | 4 ++-- ldt/metforcing/gfs/get_gfs.F90 | 4 ++-- ldt/metforcing/gfs/gfs_forcingMod.F90 | 4 ++-- ldt/metforcing/gfs/read_gfs.F90 | 4 ++-- ldt/metforcing/gfs/read_gfs_elev.F90 | 4 ++-- ldt/metforcing/gfs/readcrd_gfs.F90 | 4 ++-- ldt/metforcing/gfs/timeinterp_gfs.F90 | 4 ++-- ldt/metforcing/gldas/gldas_forcingMod.F90 | 4 ++-- ldt/metforcing/gswp1/gswp1_forcingMod.F90 | 4 ++-- ldt/metforcing/gswp2/gswp2_forcingMod.F90 | 4 ++-- ldt/metforcing/merra2/finalize_merra2.F90 | 4 ++-- ldt/metforcing/merra2/get_merra2.F90 | 4 ++-- ldt/metforcing/merra2/merra2_forcingMod.F90 | 4 ++-- ldt/metforcing/merra2/read_merra2.F90 | 4 ++-- ldt/metforcing/merra2/read_merra2_elev.F90 | 4 ++-- ldt/metforcing/merra2/readcrd_merra2.F90 | 4 ++-- ldt/metforcing/merra2/reset_merra2.F90 | 4 ++-- ldt/metforcing/merra2/timeinterp_merra2.F90 | 4 ++-- ldt/metforcing/nam242/create_nam242f9_filename.F90 | 4 ++-- ldt/metforcing/nam242/create_nam242filename.F90 | 4 ++-- ldt/metforcing/nam242/finalize_nam242.F90 | 4 ++-- ldt/metforcing/nam242/get_nam242.F90 | 4 ++-- ldt/metforcing/nam242/nam242_forcingMod.F90 | 4 ++-- ldt/metforcing/nam242/read_nam242.F90 | 4 ++-- ldt/metforcing/nam242/read_nam242_elev.F90 | 4 ++-- ldt/metforcing/nam242/readcrd_nam242.F90 | 4 ++-- ldt/metforcing/nam242/reset_nam242.F90 | 4 ++-- ldt/metforcing/nam242/timeinterp_nam242.F90 | 4 ++-- ldt/metforcing/narr/narr_forcingMod.F90 | 4 ++-- ldt/metforcing/nldas2/finalize_nldas2.F90 | 4 ++-- ldt/metforcing/nldas2/get_gesdisc_filenames.F90 | 4 ++-- ldt/metforcing/nldas2/get_ncep_filenames.F90 | 4 ++-- ldt/metforcing/nldas2/get_nldas2.F90 | 4 ++-- ldt/metforcing/nldas2/nldas2_ec_removal.F90 | 4 ++-- ldt/metforcing/nldas2/nldas2_forcingMod.F90 | 4 ++-- ldt/metforcing/nldas2/read_nldas2_elev.F90 | 4 ++-- ldt/metforcing/nldas2/read_nldas2a.F90 | 4 ++-- ldt/metforcing/nldas2/read_nldas2b.F90 | 4 ++-- ldt/metforcing/nldas2/readcrd_nldas2.F90 | 4 ++-- ldt/metforcing/nldas2/reset_nldas2.F90 | 4 ++-- ldt/metforcing/nldas2/timeinterp_nldas2.F90 | 4 ++-- ldt/metforcing/princeton/finalize_princeton.F90 | 4 ++-- ldt/metforcing/princeton/get_princeton.F90 | 4 ++-- ldt/metforcing/princeton/princeton_forcingMod.F90 | 4 ++-- ldt/metforcing/princeton/read_princeton.F90 | 4 ++-- ldt/metforcing/princeton/read_princeton_elev.F90 | 4 ++-- ldt/metforcing/princeton/readcrd_princeton.F90 | 4 ++-- ldt/metforcing/princeton/reset_princeton.F90 | 4 ++-- ldt/metforcing/princeton/timeinterp_princeton.F90 | 4 ++-- ldt/metforcing/stg2/finalize_stg2.F90 | 4 ++-- ldt/metforcing/stg2/get_stg2.F90 | 4 ++-- ldt/metforcing/stg2/interp_stg2.F90 | 4 ++-- ldt/metforcing/stg2/read_stg2.F90 | 4 ++-- ldt/metforcing/stg2/readcrd_stg2.F90 | 4 ++-- ldt/metforcing/stg2/stg2_forcingMod.F90 | 4 ++-- ldt/metforcing/stg2/stg2file.F90 | 4 ++-- ldt/metforcing/stg2/timeinterp_stg2.F90 | 4 ++-- ldt/metforcing/stg4/finalize_stg4.F90 | 4 ++-- ldt/metforcing/stg4/get_stg4.F90 | 4 ++-- ldt/metforcing/stg4/interp_stg4.F90 | 4 ++-- ldt/metforcing/stg4/read_stg4.F90 | 4 ++-- ldt/metforcing/stg4/readcrd_stg4.F90 | 4 ++-- ldt/metforcing/stg4/reset_stg4.F90 | 4 ++-- ldt/metforcing/stg4/stg4_forcingMod.F90 | 4 ++-- ldt/metforcing/stg4/stg4file.F90 | 4 ++-- ldt/metforcing/stg4/timeinterp_stg4.F90 | 4 ++-- ldt/obsSim/NatureRun/LISout/LISoutNatureRun_Mod.F90 | 4 ++-- ldt/obsSim/NatureRun/LISout/readLISoutNatureRun.F90 | 4 ++-- ldt/obsSim/OSSEmask/AMSR2/AMSR2OSSEmask_Mod.F90 | 4 ++-- ldt/obsSim/OSSEmask/AMSR2/readAMSR2OSSEmask.F90 | 4 ++-- ldt/obsSim/OSSEmask/LISout/LISoutOSSEmask_Mod.F90 | 4 ++-- ldt/obsSim/OSSEmask/LISout/readLISoutOSSEmask.F90 | 4 ++-- ldt/obsSim/OSSEmask/MODIS/MODISOSSEmask_Mod.F90 | 4 ++-- ldt/obsSim/OSSEmask/MODIS/readMODISOSSEmask.F90 | 4 ++-- ldt/obsSim/OSSEmask/Sentinel1A/Sentinel1AOSSEmask_Mod.F90 | 4 ++-- ldt/obsSim/OSSEmask/Sentinel1A/readSentinel1AOSSEmask.F90 | 4 ++-- ldt/obsSim/OSSEmask/TSMM/TSMMOSSEmask_Mod.F90 | 4 ++-- ldt/obsSim/OSSEmask/TSMM/readTSMMOSSEmask.F90 | 4 ++-- ldt/params/CLM2/CLM2_parmsMod.F90 | 4 ++-- ldt/params/CLM45/CLM45_parmsMod.F90 | 4 ++-- ldt/params/CLM45/read_netcdf_4d.F90 | 4 ++-- ldt/params/Crocus/Crocus_parmsMod.F90 | 4 ++-- ldt/params/Crocus/read_CONSTANT_slopetype_cro.F90 | 4 ++-- ldt/params/Crocus/read_CONSTANT_tbot_cro.F90 | 4 ++-- ldt/params/Crocus/read_ISLSCP1_cro_tbot.F90 | 4 ++-- ldt/params/Crocus/read_NCEP_GFS_cro_tbot.F90 | 4 ++-- ldt/params/Crocus/read_NCEP_cro_tbot.F90 | 4 ++-- ldt/params/FLAKE/FLAKE_parmsMod.F90 | 4 ++-- ldt/params/FLAKE/read_GLWD_inlandwatertype.F90 | 4 ++-- ldt/params/GeoWRSI/GeoWRSI_parmsMod.F90 | 4 ++-- ldt/params/GeoWRSI/geowrsi2_arraymgmt_module.F90 | 4 ++-- ldt/params/GeoWRSI/geowrsi2_set_gcoords.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_landmask.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_lgp.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_sos.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_sosanom.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_sosclim.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_whc.F90 | 4 ++-- ldt/params/GeoWRSI/read_GeoWRSI2_wrsiclim.F90 | 4 ++-- ldt/params/HYMAP/HYMAP_parmsMod.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_baseflow_delay.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_baseflow_dwi_ratio.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_basin.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_basin_mask.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_drain_area.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_fld_height.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_fld_z.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_flow_dir_x.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_flow_dir_y.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_flow_type.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_grid_area.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_grid_dist.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_grid_elev.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_refq.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_river_height.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_river_length.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_river_width.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_river_z.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_runoff_delay.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_runoff_delaym.F90 | 4 ++-- ldt/params/HYMAP/read_HYMAP_runoff_dwi_ratio.F90 | 4 ++-- ldt/params/JULES/JULES50_parmsMod.F90 | 4 ++-- ldt/params/JULES/create_soil_albedo_from_whs.F90 | 4 ++-- ldt/params/JULES/create_soil_params_from_cap.F90 | 4 ++-- ldt/params/JULES/read_um_soil_params.F90 | 4 ++-- ldt/params/LAISAI/read_AVHRR_lai.F90 | 4 ++-- ldt/params/LAISAI/read_AVHRR_sai.F90 | 4 ++-- ldt/params/LAISAI/read_CLSMF25_lai.F90 | 4 ++-- ldt/params/LAISAI/read_CLSMF25_laimax.F90 | 4 ++-- ldt/params/LAISAI/read_CLSMF25_laimin.F90 | 4 ++-- ldt/params/LAISAI/read_CONSTANT_lai.F90 | 4 ++-- ldt/params/LAISAI/read_CONSTANT_sai.F90 | 4 ++-- ldt/params/LAISAI/setLAISAIParmsFullnames.F90 | 4 ++-- ldt/params/LAISAI/set_AVHRR_lai_attribs.F90 | 4 ++-- ldt/params/LAISAI/set_CLSMF25_lai_attribs.F90 | 4 ++-- ldt/params/Mosaic/Mosaic_parmsMod.F90 | 4 ++-- ldt/params/Noah/Noah_parmsMod.F90 | 4 ++-- ldt/params/Noah/module_MMF_groundwater.F90 | 4 ++-- ldt/params/Noah/read_CONSTANT_slopetype.F90 | 4 ++-- ldt/params/Noah/read_CONSTANT_tbot.F90 | 4 ++-- ldt/params/Noah/read_GFS_slopetype.F90 | 4 ++-- ldt/params/Noah/read_ISLSCP1_tbot.F90 | 4 ++-- ldt/params/Noah/read_NCEPNative_slopetype.F90 | 4 ++-- ldt/params/Noah/read_NCEP_GFS_tbot.F90 | 4 ++-- ldt/params/Noah/read_NCEP_slopetype.F90 | 4 ++-- ldt/params/Noah/read_NCEP_tbot.F90 | 4 ++-- ldt/params/RDHM/RDHM_parmsMod.F90 | 4 ++-- ldt/params/RUC/RUC_parmsMod.F90 | 4 ++-- ldt/params/RUC/read_RUC_ISLSCP1tbot.F90 | 4 ++-- ldt/params/RUC/read_RUC_NCEPLIS_slopetype.F90 | 4 ++-- ldt/params/RUC/read_RUC_NCEPLIS_tbot.F90 | 4 ++-- ldt/params/RUC/read_RUC_NCEPslopetype.F90 | 4 ++-- ldt/params/SACHTET/SACHTET_parmsMod.F90 | 4 ++-- ldt/params/SACHTET/create_SACsoilparms_Korenv1.F90 | 4 ++-- ldt/params/SACHTET/read_SACHTET356_pet.F90 | 4 ++-- ldt/params/SACHTET/read_SACHTET356_petadj.F90 | 4 ++-- ldt/params/SACHTET/read_SACHTET356_tbot.F90 | 4 ++-- ldt/params/SiB2/SiB2_parmsMod.F90 | 4 ++-- ldt/params/SiB2/read_SiB2_parms.F90 | 4 ++-- ldt/params/Snow17/Snow17_parmsMod.F90 | 4 ++-- ldt/params/SnowModel/SnowModel_parmsMod.F90 | 4 ++-- ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 | 4 ++-- ldt/params/VIC/LDT_vic412rstMod.F90 | 4 ++-- ldt/params/VIC/VIC_parmsMod.F90 | 4 ++-- ldt/params/albedo/read_BarlageNative_maxsnoalb.F90 | 4 ++-- ldt/params/albedo/read_BrieglebNative_monalbedo.F90 | 4 ++-- ldt/params/albedo/read_BrieglebNative_qtralbedo.F90 | 4 ++-- ldt/params/albedo/read_Briegleb_albedo.F90 | 4 ++-- ldt/params/albedo/read_CONSTANT_albedo.F90 | 4 ++-- ldt/params/albedo/read_CONSTANT_mxsnoalb.F90 | 4 ++-- ldt/params/albedo/read_GFS_maxsnoalb.F90 | 4 ++-- ldt/params/albedo/read_RobinsonKuklaNative_mxsnoalb.F90 | 4 ++-- ldt/params/albedo/read_RobinsonKukla_mxsnoalb.F90 | 4 ++-- ldt/params/albedo/read_SACHTET356_mxsnoalb.F90 | 4 ++-- ldt/params/albedo/setAlbedoParmsFullnames.F90 | 4 ++-- ldt/params/albedo/set_albedo_attribs.F90 | 4 ++-- ldt/params/catchment/CLSMF25_parmsMod.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_albnir.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_albvis.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_araparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_arsparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_arwparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_bedrockdepth.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_bexp.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_bfparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_gnuparam.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_ksat.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_psisat.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_tauparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_tsparams.F90 | 4 ++-- ldt/params/catchment/read_CLSMF25_wpwet.F90 | 4 ++-- ldt/params/catchment/set_CLSMF25_gfrac_attribs.F90 | 4 ++-- ldt/params/climateparms/LDT_NAFPA_back_climpptMod.F90 | 4 ++-- ldt/params/climateparms/read_NLDAS_climppt.F90 | 4 ++-- ldt/params/climateparms/read_PRISM_climppt.F90 | 4 ++-- ldt/params/climateparms/read_WorldClim_climppt.F90 | 4 ++-- ldt/params/climateparms/setClimateParmsFullnames.F90 | 4 ++-- ldt/params/crop_parms/Monfredaetal08_crops_module.F90 | 4 ++-- ldt/params/crop_parms/assigncroptype.F90 | 4 ++-- ldt/params/crop_parms/read_UMDCROPMAP_croptype.F90 | 4 ++-- ldt/params/crop_parms/readcropinventory.F90 | 4 ++-- ldt/params/crop_parms/setCropParmsFullnames.F90 | 4 ++-- ldt/params/gfrac/read_AVHRRNative_gfrac.F90 | 4 ++-- ldt/params/gfrac/read_AVHRR_gfrac.F90 | 4 ++-- ldt/params/gfrac/read_CLSMF25_gfrac.F90 | 4 ++-- ldt/params/gfrac/read_CLSMF25_gfracmax.F90 | 4 ++-- ldt/params/gfrac/read_CLSMF25_gfracmin.F90 | 4 ++-- ldt/params/gfrac/read_CONSTANT_gfrac.F90 | 4 ++-- ldt/params/gfrac/read_CONSTANT_gfracmax.F90 | 4 ++-- ldt/params/gfrac/read_CONSTANT_gfracmin.F90 | 4 ++-- ldt/params/gfrac/read_NCEPNative_shdmax.F90 | 4 ++-- ldt/params/gfrac/read_NCEPNative_shdmin.F90 | 4 ++-- ldt/params/gfrac/read_NCEP_shdmax.F90 | 4 ++-- ldt/params/gfrac/read_NCEP_shdmin.F90 | 4 ++-- ldt/params/gfrac/read_SACHTET356_gfrac.F90 | 4 ++-- ldt/params/gfrac/setGfracParmsFullnames.F90 | 4 ++-- ldt/params/gfrac/set_gfrac_attribs.F90 | 4 ++-- ldt/params/glacier/read_GLIMS_glacierfraction.F90 | 4 ++-- ldt/params/glacier/read_GLIMS_glaciermask.F90 | 4 ++-- ldt/params/glacier/setGlacierFracParmsFullnames.F90 | 4 ++-- ldt/params/glacier/set_glacierfraction_attribs.F90 | 4 ++-- ldt/params/irrigation/read_GRIPC_irrigfrac.F90 | 4 ++-- ldt/params/irrigation/read_GRIPC_irrigtype.F90 | 4 ++-- ldt/params/irrigation/read_OzdoganGutman_irrigfrac.F90 | 4 ++-- ldt/params/irrigation/read_USGSNative_irriggwratio.F90 | 4 ++-- ldt/params/irrigation/read_UserDerived_irrigfrac.F90 | 4 ++-- ldt/params/irrigation/setIrrigParmsFullnames.F90 | 4 ++-- ldt/params/irrigation/set_irrigation_attribs.F90 | 4 ++-- ldt/params/irrigation/set_irriggwratio_attribs.F90 | 4 ++-- ldt/params/landcover/read_ALMIPII_droot.F90 | 4 ++-- ldt/params/landcover/read_ALMIPII_lc.F90 | 4 ++-- ldt/params/landcover/read_AVHRR_GFS_lc.F90 | 4 ++-- ldt/params/landcover/read_AVHRR_lc.F90 | 4 ++-- ldt/params/landcover/read_CLM45_lc.F90 | 4 ++-- ldt/params/landcover/read_CLSMF25_lc.F90 | 4 ++-- ldt/params/landcover/read_CONSTANT_lc.F90 | 4 ++-- ldt/params/landcover/read_ISA_lc.F90 | 4 ++-- ldt/params/landcover/read_MCD12Q1_lc.F90 | 4 ++-- ldt/params/landcover/read_MODISNative_PFT.F90 | 4 ++-- ldt/params/landcover/read_MODISNative_lc.F90 | 4 ++-- ldt/params/landcover/read_MODIS_lc.F90 | 4 ++-- ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 | 4 ++-- ldt/params/landcover/read_NALCMS_SM_lc.F90 | 4 ++-- ldt/params/landcover/read_SACHTET356_lc.F90 | 4 ++-- ldt/params/landcover/read_UKMO_IGBP_PFT.F90 | 4 ++-- ldt/params/landcover/read_UKMO_IGBP_PFT.F90.binary | 4 ++-- ldt/params/landcover/read_UKMO_IGBP_PFT.F90.nc | 4 ++-- ldt/params/landcover/read_UM_ancillary.F90 | 4 ++-- ldt/params/landcover/read_USGSNative_lc.F90 | 4 ++-- ldt/params/landcover/read_USGS_lc.F90 | 4 ++-- ldt/params/landcover/read_VIC411_lc.F90 | 4 ++-- ldt/params/landcover/read_VIC412_lc.F90 | 4 ++-- ldt/params/mask/create_maskfile.F90 | 4 ++-- ldt/params/mask/read_ISA_maskfile.F90 | 4 ++-- ldt/params/mask/read_maskfile.F90 | 4 ++-- ldt/params/mask/read_maskfile_MCD12Q1.F90 | 4 ++-- ldt/params/mask/read_maskfile_UKMO_CAP_Netcdf.F90 | 4 ++-- ldt/params/mask/read_maskfile_UKMO_IGBP_Native_PFT.F90 | 4 ++-- ldt/params/mask/read_regmask_gis.F90 | 4 ++-- ldt/params/mask/read_regmask_mask.F90 | 4 ++-- ldt/params/mask/read_regmask_wrsi.F90 | 4 ++-- ldt/params/soils/read_ALMIPII_dsoil.F90 | 4 ++-- ldt/params/soils/read_ALMIPII_soilfractions.F90 | 4 ++-- ldt/params/soils/read_CLSMF25_porosity.F90 | 4 ++-- ldt/params/soils/read_CONSTANT_porosity.F90 | 4 ++-- ldt/params/soils/read_CONSTANT_soilfractions.F90 | 4 ++-- ldt/params/soils/read_CONSTANT_texture.F90 | 4 ++-- ldt/params/soils/read_FAO_color.F90 | 4 ++-- ldt/params/soils/read_FAO_porosity.F90 | 4 ++-- ldt/params/soils/read_FAO_soilfractions.F90 | 4 ++-- ldt/params/soils/read_FAO_texture.F90 | 4 ++-- ldt/params/soils/read_ISRIC_soilfractions.F90 | 4 ++-- ldt/params/soils/read_ISRIC_texture.F90 | 4 ++-- ldt/params/soils/read_STATSGOFAO_Native_texture.F90 | 4 ++-- ldt/params/soils/read_STATSGOFAO_texture.F90 | 4 ++-- ldt/params/soils/read_STATSGOv1_hydrosoilgroup.F90 | 4 ++-- ldt/params/soils/read_STATSGOv1_soilfractions.F90 | 4 ++-- ldt/params/soils/read_STATSGOv1_texture.F90 | 4 ++-- ldt/params/soils/read_Special_soilfractions.F90 | 4 ++-- ldt/params/soils/read_Special_texture.F90 | 4 ++-- ldt/params/soils/read_ZOBLER_GFS_texture.F90 | 4 ++-- ldt/params/soils/set_CONSTANT_texture_attribs.F90 | 4 ++-- ldt/params/soils/set_ISRIC_texture_attribs.F90 | 4 ++-- ldt/params/soils/set_STATSGOFAO_LIS_texture_attribs.F90 | 4 ++-- .../soils/set_STATSGOFAO_Native_texture_attribs.F90 | 4 ++-- ldt/params/soils/set_STATSGOv1_hsg_attribs.F90 | 4 ++-- ldt/params/soils/set_STATSGOv1_texture_attribs.F90 | 4 ++-- ldt/params/soils/set_Special_texture_attribs.F90 | 4 ++-- ldt/params/soils/set_ZOBLER_GFS_texture_attribs.F90 | 4 ++-- ldt/params/topo/calc_SlopeAspect_module.F90 | 4 ++-- ldt/params/topo/read_CONSTANT_aspect.F90 | 4 ++-- ldt/params/topo/read_CONSTANT_elev.F90 | 4 ++-- ldt/params/topo/read_CONSTANT_slope.F90 | 4 ++-- ldt/params/topo/read_GTOPO30Native_elev.F90 | 4 ++-- ldt/params/topo/read_GTOPO30_GFS_elev.F90 | 4 ++-- ldt/params/topo/read_GTOPO30_aspect.F90 | 4 ++-- ldt/params/topo/read_GTOPO30_curv.F90 | 4 ++-- ldt/params/topo/read_GTOPO30_elev.F90 | 4 ++-- ldt/params/topo/read_GTOPO30_slope.F90 | 4 ++-- ldt/params/topo/read_MERIT1K_aspect.F90 | 4 ++-- ldt/params/topo/read_MERIT1K_elev.F90 | 4 ++-- ldt/params/topo/read_MERIT1K_slope.F90 | 4 ++-- ldt/params/topo/read_NED_SM_aspect.F90 | 8 +++++++- ldt/params/topo/read_NED_SM_curvature.F90 | 8 +++++++- ldt/params/topo/read_NED_SM_elev.F90 | 8 +++++++- ldt/params/topo/read_NED_SM_slope.F90 | 8 +++++++- ldt/params/topo/read_SRTM_Native_aspect.F90 | 4 ++-- ldt/params/topo/read_SRTM_Native_elev.F90 | 4 ++-- ldt/params/topo/read_SRTM_Native_slope.F90 | 4 ++-- ldt/params/topo/read_SRTM_aspect.F90 | 4 ++-- ldt/params/topo/read_SRTM_elev.F90 | 4 ++-- ldt/params/topo/read_SRTM_slope.F90 | 4 ++-- ldt/params/topo/setTopoParmsFullnames.F90 | 4 ++-- ldt/plugins/LDT_ANNdata_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_DAobs_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_NatureRunData_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_OSSEmaskData_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_domain_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_metforcScale_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_metforcing_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_param_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_pluginIndices.F90 | 4 ++-- ldt/plugins/LDT_runmode_pluginMod.F90 | 4 ++-- ldt/plugins/LDT_statDscale_pluginMod.F90 | 4 ++-- ldt/runmodes/ANNproc/LDT_init_ANNproc.F90 | 4 ++-- ldt/runmodes/ANNproc/LDT_run_ANNproc.F90 | 4 ++-- ldt/runmodes/DApreproc/LDT_init_DApreproc.F90 | 4 ++-- ldt/runmodes/DApreproc/LDT_run_DApreproc.F90 | 4 ++-- ldt/runmodes/EnsRstpreproc/LDT_init_EnsRstpreproc.F90 | 4 ++-- ldt/runmodes/EnsRstpreproc/LDT_run_EnsRstpreproc.F90 | 4 ++-- ldt/runmodes/LISHydropreproc/LDT_init_LISHydropreproc.F90 | 4 ++-- ldt/runmodes/LISHydropreproc/LDT_run_LISHydropreproc.F90 | 4 ++-- ldt/runmodes/LSMparamproc/LDT_init_LSMparamproc.F90 | 4 ++-- ldt/runmodes/LSMparamproc/LDT_run_LSMparamproc.F90 | 4 ++-- ldt/runmodes/MetTimeDScale/LDT_init_MetTimeDScale.F90 | 4 ++-- ldt/runmodes/MetTimeDScale/LDT_run_MetTimeDScale.F90 | 4 ++-- ldt/runmodes/Metforcproc/LDT_final_MetforcProc.F90 | 4 ++-- ldt/runmodes/Metforcproc/LDT_init_MetforcProc.F90 | 4 ++-- ldt/runmodes/Metforcproc/LDT_run_MetforcProc.F90 | 4 ++-- ldt/runmodes/NUWRFpreproc/LDT_init_NUWRFpreproc.F90 | 4 ++-- ldt/runmodes/NUWRFpreproc/LDT_run_NUWRFpreproc.F90 | 4 ++-- ldt/runmodes/OPTUEproc/LDT_init_OPTUEparamproc.F90 | 4 ++-- ldt/runmodes/OPTUEproc/LDT_run_OPTUEparamproc.F90 | 4 ++-- ldt/runmodes/SMAP_E_OPL/LDT_init_smap_e_opl.F90 | 2 +- ldt/runmodes/SMAP_E_OPL/LDT_run_smap_e_opl.F90 | 2 +- .../StatDscaleMetForc/LDT_init_StatDscaleMetForc.F90 | 4 ++-- .../StatDscaleMetForc/LDT_run_StatDscaleMetForc.F90 | 4 ++-- ldt/runmodes/USAFSI/LDT_init_usafsi.F90 | 4 ++-- ldt/runmodes/USAFSI/LDT_run_usafsi.F90 | 4 ++-- ldt/runmodes/climoRstproc/LDT_init_climoRstproc.F90 | 4 ++-- ldt/runmodes/climoRstproc/LDT_run_climoRstproc.F90 | 4 ++-- ldt/runmodes/obsSim/LDT_init_obsSim.F90 | 4 ++-- ldt/runmodes/obsSim/LDT_run_obsSim.F90 | 4 ++-- .../rstTransformProc/LDT_init_rstTransformProc.F90 | 4 ++-- .../rstTransformProc/LDT_run_rstTransformProc.F90 | 4 ++-- ldt/statDscale/BayesianMerging/BayesianMergingMod.F90 | 4 ++-- ldt/statDscale/Climo/forcingClimoMod.F90 | 4 ++-- 734 files changed, 1490 insertions(+), 1448 deletions(-) diff --git a/ldt/ANNdata/GCOMW_AMSR2_TB/GCOMWAMSR2TB_ANNdataMod.F90 b/ldt/ANNdata/GCOMW_AMSR2_TB/GCOMWAMSR2TB_ANNdataMod.F90 index 33bcc6cc5..2379c0f0f 100644 --- a/ldt/ANNdata/GCOMW_AMSR2_TB/GCOMWAMSR2TB_ANNdataMod.F90 +++ b/ldt/ANNdata/GCOMW_AMSR2_TB/GCOMWAMSR2TB_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/GCOMW_AMSR2_TB/readGCOMWAMSR2TbANNdata.F90 b/ldt/ANNdata/GCOMW_AMSR2_TB/readGCOMWAMSR2TbANNdata.F90 index 0da8d96c1..13a756126 100644 --- a/ldt/ANNdata/GCOMW_AMSR2_TB/readGCOMWAMSR2TbANNdata.F90 +++ b/ldt/ANNdata/GCOMW_AMSR2_TB/readGCOMWAMSR2TbANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/GHCNsnwd/GHCN_ANNdataMod.F90 b/ldt/ANNdata/GHCNsnwd/GHCN_ANNdataMod.F90 index 35373b18c..c51b5d418 100644 --- a/ldt/ANNdata/GHCNsnwd/GHCN_ANNdataMod.F90 +++ b/ldt/ANNdata/GHCNsnwd/GHCN_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/GHCNsnwd/readGHCNANNdata.F90 b/ldt/ANNdata/GHCNsnwd/readGHCNANNdata.F90 index 5b7986f3a..38e89220f 100644 --- a/ldt/ANNdata/GHCNsnwd/readGHCNANNdata.F90 +++ b/ldt/ANNdata/GHCNsnwd/readGHCNANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/LISlsmSM/LISlsmSM_ANNdataMod.F90 b/ldt/ANNdata/LISlsmSM/LISlsmSM_ANNdataMod.F90 index e5c5b1205..3c2f9a113 100644 --- a/ldt/ANNdata/LISlsmSM/LISlsmSM_ANNdataMod.F90 +++ b/ldt/ANNdata/LISlsmSM/LISlsmSM_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/LISlsmSM/readLISlsmSMANNdata.F90 b/ldt/ANNdata/LISlsmSM/readLISlsmSMANNdata.F90 index ae35c7c65..bc9b1f3ea 100644 --- a/ldt/ANNdata/LISlsmSM/readLISlsmSMANNdata.F90 +++ b/ldt/ANNdata/LISlsmSM/readLISlsmSMANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/LPRM_AMSREsm/LPRM_AMSREsm_ANNdataMod.F90 b/ldt/ANNdata/LPRM_AMSREsm/LPRM_AMSREsm_ANNdataMod.F90 index a0b967a2e..907f46570 100644 --- a/ldt/ANNdata/LPRM_AMSREsm/LPRM_AMSREsm_ANNdataMod.F90 +++ b/ldt/ANNdata/LPRM_AMSREsm/LPRM_AMSREsm_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/LPRM_AMSREsm/readLPRM_AMSRE_ANNdata.F90 b/ldt/ANNdata/LPRM_AMSREsm/readLPRM_AMSRE_ANNdata.F90 index ab46126ea..21f137cb6 100644 --- a/ldt/ANNdata/LPRM_AMSREsm/readLPRM_AMSRE_ANNdata.F90 +++ b/ldt/ANNdata/LPRM_AMSREsm/readLPRM_AMSRE_ANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/MOD10A1/MOD10A1_ANNdataMod.F90 b/ldt/ANNdata/MOD10A1/MOD10A1_ANNdataMod.F90 index dc84c639b..d8220701f 100644 --- a/ldt/ANNdata/MOD10A1/MOD10A1_ANNdataMod.F90 +++ b/ldt/ANNdata/MOD10A1/MOD10A1_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/MOD10A1/readMOD10A1ANNdata.F90 b/ldt/ANNdata/MOD10A1/readMOD10A1ANNdata.F90 index 8b1d2d07d..dd29ccd77 100644 --- a/ldt/ANNdata/MOD10A1/readMOD10A1ANNdata.F90 +++ b/ldt/ANNdata/MOD10A1/readMOD10A1ANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/MODIS_LST/MODISlst_ANNdataMod.F90 b/ldt/ANNdata/MODIS_LST/MODISlst_ANNdataMod.F90 index 0469a5372..03a166c95 100644 --- a/ldt/ANNdata/MODIS_LST/MODISlst_ANNdataMod.F90 +++ b/ldt/ANNdata/MODIS_LST/MODISlst_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/MODIS_LST/readMODISlstANNdata.F90 b/ldt/ANNdata/MODIS_LST/readMODISlstANNdata.F90 index 6034d2098..bebaec9fb 100644 --- a/ldt/ANNdata/MODIS_LST/readMODISlstANNdata.F90 +++ b/ldt/ANNdata/MODIS_LST/readMODISlstANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/synthetic_sm/readsyntheticsmANNdata.F90 b/ldt/ANNdata/synthetic_sm/readsyntheticsmANNdata.F90 index 439e15a98..2d124c060 100644 --- a/ldt/ANNdata/synthetic_sm/readsyntheticsmANNdata.F90 +++ b/ldt/ANNdata/synthetic_sm/readsyntheticsmANNdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/ANNdata/synthetic_sm/syntheticsm_ANNdataMod.F90 b/ldt/ANNdata/synthetic_sm/syntheticsm_ANNdataMod.F90 index 41cc13b2a..7534f3af8 100644 --- a/ldt/ANNdata/synthetic_sm/syntheticsm_ANNdataMod.F90 +++ b/ldt/ANNdata/synthetic_sm/syntheticsm_ANNdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ANSA_SNWD/ANSASNWDsnow_obsMod.F90 b/ldt/DAobs/ANSA_SNWD/ANSASNWDsnow_obsMod.F90 index fa69e776d..ed003993f 100644 --- a/ldt/DAobs/ANSA_SNWD/ANSASNWDsnow_obsMod.F90 +++ b/ldt/DAobs/ANSA_SNWD/ANSASNWDsnow_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ANSA_SNWD/readANSASNWDsnowObs.F90 b/ldt/DAobs/ANSA_SNWD/readANSASNWDsnowObs.F90 index 582596eff..4f61765df 100644 --- a/ldt/DAobs/ANSA_SNWD/readANSASNWDsnowObs.F90 +++ b/ldt/DAobs/ANSA_SNWD/readANSASNWDsnowObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ASCAT_TUW/ASCATTUWsm_obsMod.F90 b/ldt/DAobs/ASCAT_TUW/ASCATTUWsm_obsMod.F90 index d08522e69..df4995100 100644 --- a/ldt/DAobs/ASCAT_TUW/ASCATTUWsm_obsMod.F90 +++ b/ldt/DAobs/ASCAT_TUW/ASCATTUWsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ASCAT_TUW/readASCATTUWsmObs.F90 b/ldt/DAobs/ASCAT_TUW/readASCATTUWsmObs.F90 index 53ae7ba48..445d401e1 100644 --- a/ldt/DAobs/ASCAT_TUW/readASCATTUWsmObs.F90 +++ b/ldt/DAobs/ASCAT_TUW/readASCATTUWsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/Aquarius_L2sm/AquariusL2sm_obsMod.F90 b/ldt/DAobs/Aquarius_L2sm/AquariusL2sm_obsMod.F90 index dcc724a95..2bd9dd181 100644 --- a/ldt/DAobs/Aquarius_L2sm/AquariusL2sm_obsMod.F90 +++ b/ldt/DAobs/Aquarius_L2sm/AquariusL2sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/Aquarius_L2sm/readAquariusL2smObs.F90 b/ldt/DAobs/Aquarius_L2sm/readAquariusL2smObs.F90 index cade86622..f749b44bd 100644 --- a/ldt/DAobs/Aquarius_L2sm/readAquariusL2smObs.F90 +++ b/ldt/DAobs/Aquarius_L2sm/readAquariusL2smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/CDFS_GVF/CDFS_GVF_obsMod.F90 b/ldt/DAobs/CDFS_GVF/CDFS_GVF_obsMod.F90 index 6050948b7..a99cef84a 100644 --- a/ldt/DAobs/CDFS_GVF/CDFS_GVF_obsMod.F90 +++ b/ldt/DAobs/CDFS_GVF/CDFS_GVF_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/CDFS_GVF/readCDFS_GVFObs.F90 b/ldt/DAobs/CDFS_GVF/readCDFS_GVFObs.F90 index 013c3a0f4..0c56f8720 100644 --- a/ldt/DAobs/CDFS_GVF/readCDFS_GVFObs.F90 +++ b/ldt/DAobs/CDFS_GVF/readCDFS_GVFObs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ESACCI_sm/ESACCIsm_obsMod.F90 b/ldt/DAobs/ESACCI_sm/ESACCIsm_obsMod.F90 index da1cd462a..54e729daa 100644 --- a/ldt/DAobs/ESACCI_sm/ESACCIsm_obsMod.F90 +++ b/ldt/DAobs/ESACCI_sm/ESACCIsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/ESACCI_sm/readESACCIsmObs.F90 b/ldt/DAobs/ESACCI_sm/readESACCIsmObs.F90 index 5d9ad5176..d8fe70188 100644 --- a/ldt/DAobs/ESACCI_sm/readESACCIsmObs.F90 +++ b/ldt/DAobs/ESACCI_sm/readESACCIsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 b/ldt/DAobs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 index a90c62a13..f21034e01 100644 --- a/ldt/DAobs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 +++ b/ldt/DAobs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 b/ldt/DAobs/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 index d04a649d4..c43f6232a 100644 --- a/ldt/DAobs/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 +++ b/ldt/DAobs/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 b/ldt/DAobs/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 index f5eb4cb25..f4c2b9909 100644 --- a/ldt/DAobs/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 +++ b/ldt/DAobs/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 b/ldt/DAobs/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 index 8587e5407..a103a7357 100644 --- a/ldt/DAobs/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 +++ b/ldt/DAobs/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GEOS_FP_TEFFobs/GEOSTEFF_obsMod.F90 b/ldt/DAobs/GEOS_FP_TEFFobs/GEOSTEFF_obsMod.F90 index c04f20d29..0d58f2891 100644 --- a/ldt/DAobs/GEOS_FP_TEFFobs/GEOSTEFF_obsMod.F90 +++ b/ldt/DAobs/GEOS_FP_TEFFobs/GEOSTEFF_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GEOS_FP_TEFFobs/readGEOSTEFFObs.F90 b/ldt/DAobs/GEOS_FP_TEFFobs/readGEOSTEFFObs.F90 index 4b6519a81..e7a91f891 100644 --- a/ldt/DAobs/GEOS_FP_TEFFobs/readGEOSTEFFObs.F90 +++ b/ldt/DAobs/GEOS_FP_TEFFobs/readGEOSTEFFObs.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP ! diff --git a/ldt/DAobs/GLASSlai/GLASSlai_obsMod.F90 b/ldt/DAobs/GLASSlai/GLASSlai_obsMod.F90 index 957f7539d..37a91275d 100644 --- a/ldt/DAobs/GLASSlai/GLASSlai_obsMod.F90 +++ b/ldt/DAobs/GLASSlai/GLASSlai_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GLASSlai/readGLASSlaiObs.F90 b/ldt/DAobs/GLASSlai/readGLASSlaiObs.F90 index ad24763d8..bbee904a4 100644 --- a/ldt/DAobs/GLASSlai/readGLASSlaiObs.F90 +++ b/ldt/DAobs/GLASSlai/readGLASSlaiObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GRACEQL_tws/GRACEQLtws_obsMod.F90 b/ldt/DAobs/GRACEQL_tws/GRACEQLtws_obsMod.F90 index 97fcd4692..ecc4c2929 100755 --- a/ldt/DAobs/GRACEQL_tws/GRACEQLtws_obsMod.F90 +++ b/ldt/DAobs/GRACEQL_tws/GRACEQLtws_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GRACEQL_tws/readGRACEQLtwsObs.F90 b/ldt/DAobs/GRACEQL_tws/readGRACEQLtwsObs.F90 index db340569e..b373fac92 100755 --- a/ldt/DAobs/GRACEQL_tws/readGRACEQLtwsObs.F90 +++ b/ldt/DAobs/GRACEQL_tws/readGRACEQLtwsObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GRACE_tws/GRACEtws_obsMod.F90 b/ldt/DAobs/GRACE_tws/GRACEtws_obsMod.F90 index bc1c6c85d..4906a21ef 100644 --- a/ldt/DAobs/GRACE_tws/GRACEtws_obsMod.F90 +++ b/ldt/DAobs/GRACE_tws/GRACEtws_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/GRACE_tws/readGRACEtwsObs.F90 b/ldt/DAobs/GRACE_tws/readGRACEtwsObs.F90 index 240f60972..16acf7321 100644 --- a/ldt/DAobs/GRACE_tws/readGRACEtwsObs.F90 +++ b/ldt/DAobs/GRACE_tws/readGRACEtwsObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 index 649bb2443..e4cd01de1 100644 --- a/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/LISlsmPrecip_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 index 109685ceb..71e38a895 100644 --- a/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/readLISlsmPrecipobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 index 5d4f0b7af..23a21bb0b 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Drange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 index 34fb4f906..0bb3edc03 100644 --- a/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 +++ b/ldt/DAobs/LISlsmPrecipobs/read_Precip_climo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmSMobs/LISlsmSM_obsMod.F90 b/ldt/DAobs/LISlsmSMobs/LISlsmSM_obsMod.F90 index c21338b13..bfaa12b65 100644 --- a/ldt/DAobs/LISlsmSMobs/LISlsmSM_obsMod.F90 +++ b/ldt/DAobs/LISlsmSMobs/LISlsmSM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmSMobs/readLISlsmSMObs.F90 b/ldt/DAobs/LISlsmSMobs/readLISlsmSMObs.F90 index d08186e49..68aadff9e 100644 --- a/ldt/DAobs/LISlsmSMobs/readLISlsmSMObs.F90 +++ b/ldt/DAobs/LISlsmSMobs/readLISlsmSMObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 b/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 index 33e0742c1..5057275fb 100644 --- a/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/LISlsmTEFF_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 index d24976fa8..71a8da85a 100644 --- a/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 +++ b/ldt/DAobs/LISlsmTEFFobs/readLISlsmTEFFObs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 b/ldt/DAobs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 index e5efa1a7c..c928f3917 100644 --- a/ldt/DAobs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 +++ b/ldt/DAobs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LPRM_AMSREsm/readLPRM_AMSREsmObs.F90 b/ldt/DAobs/LPRM_AMSREsm/readLPRM_AMSREsmObs.F90 index 1e061a4f8..6a5267645 100644 --- a/ldt/DAobs/LPRM_AMSREsm/readLPRM_AMSREsmObs.F90 +++ b/ldt/DAobs/LPRM_AMSREsm/readLPRM_AMSREsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LPRMvod/LPRMvod_obsMod.F90 b/ldt/DAobs/LPRMvod/LPRMvod_obsMod.F90 index 3f8a9befd..e2b4928d2 100644 --- a/ldt/DAobs/LPRMvod/LPRMvod_obsMod.F90 +++ b/ldt/DAobs/LPRMvod/LPRMvod_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/LPRMvod/readLPRMvodObs.F90 b/ldt/DAobs/LPRMvod/readLPRMvodObs.F90 index a98b7ad7a..38b3cf613 100644 --- a/ldt/DAobs/LPRMvod/readLPRMvodObs.F90 +++ b/ldt/DAobs/LPRMvod/readLPRMvodObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/MCD15A2H_LAI/MCD15A2Hlai_obsMod.F90 b/ldt/DAobs/MCD15A2H_LAI/MCD15A2Hlai_obsMod.F90 index 30890b465..4aafa1e55 100644 --- a/ldt/DAobs/MCD15A2H_LAI/MCD15A2Hlai_obsMod.F90 +++ b/ldt/DAobs/MCD15A2H_LAI/MCD15A2Hlai_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/MCD15A2H_LAI/readMCD15A2HlaiObs.F90 b/ldt/DAobs/MCD15A2H_LAI/readMCD15A2HlaiObs.F90 index 2071f1951..8f8202b38 100644 --- a/ldt/DAobs/MCD15A2H_LAI/readMCD15A2HlaiObs.F90 +++ b/ldt/DAobs/MCD15A2H_LAI/readMCD15A2HlaiObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 b/ldt/DAobs/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 index 88b44997c..b1e9b947a 100644 --- a/ldt/DAobs/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 +++ b/ldt/DAobs/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 b/ldt/DAobs/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 index 7d8acfbdb..2f9551303 100644 --- a/ldt/DAobs/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 +++ b/ldt/DAobs/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_SMAPsm/NASASMAPsm_obsMod.F90 b/ldt/DAobs/NASA_SMAPsm/NASASMAPsm_obsMod.F90 index 41b25aee7..976808124 100644 --- a/ldt/DAobs/NASA_SMAPsm/NASASMAPsm_obsMod.F90 +++ b/ldt/DAobs/NASA_SMAPsm/NASASMAPsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_SMAPsm/readNASASMAPsmObs.F90 b/ldt/DAobs/NASA_SMAPsm/readNASASMAPsmObs.F90 index 8431d30e9..eca37bcf7 100644 --- a/ldt/DAobs/NASA_SMAPsm/readNASASMAPsmObs.F90 +++ b/ldt/DAobs/NASA_SMAPsm/readNASASMAPsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_SMAPvod/NASASMAPvod_obsMod.F90 b/ldt/DAobs/NASA_SMAPvod/NASASMAPvod_obsMod.F90 index 00a0f6065..c5684b3af 100644 --- a/ldt/DAobs/NASA_SMAPvod/NASASMAPvod_obsMod.F90 +++ b/ldt/DAobs/NASA_SMAPvod/NASASMAPvod_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/NASA_SMAPvod/readNASASMAPvodObs.F90 b/ldt/DAobs/NASA_SMAPvod/readNASASMAPvodObs.F90 index f4b42b502..f892bfc06 100644 --- a/ldt/DAobs/NASA_SMAPvod/readNASASMAPvodObs.F90 +++ b/ldt/DAobs/NASA_SMAPvod/readNASASMAPvodObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMAP_E_OPLsm/SMAPEOPL_SM_obsMod.F90 b/ldt/DAobs/SMAP_E_OPLsm/SMAPEOPL_SM_obsMod.F90 index 9b8d3c3a6..b08c69b6d 100644 --- a/ldt/DAobs/SMAP_E_OPLsm/SMAPEOPL_SM_obsMod.F90 +++ b/ldt/DAobs/SMAP_E_OPLsm/SMAPEOPL_SM_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMAP_E_OPLsm/readSMAPEOPL_SMObs.F90 b/ldt/DAobs/SMAP_E_OPLsm/readSMAPEOPL_SMObs.F90 index 605fe35a3..1dd82949a 100644 --- a/ldt/DAobs/SMAP_E_OPLsm/readSMAPEOPL_SMObs.F90 +++ b/ldt/DAobs/SMAP_E_OPLsm/readSMAPEOPL_SMObs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMMR_SNWD/SMMRSNWDsnow_obsMod.F90 b/ldt/DAobs/SMMR_SNWD/SMMRSNWDsnow_obsMod.F90 index 5b04bb3ba..d4c5872d1 100644 --- a/ldt/DAobs/SMMR_SNWD/SMMRSNWDsnow_obsMod.F90 +++ b/ldt/DAobs/SMMR_SNWD/SMMRSNWDsnow_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMMR_SNWD/readSMMRSNWDsnowObs.F90 b/ldt/DAobs/SMMR_SNWD/readSMMRSNWDsnowObs.F90 index f8c3fc4e1..c9b784e04 100644 --- a/ldt/DAobs/SMMR_SNWD/readSMMRSNWDsnowObs.F90 +++ b/ldt/DAobs/SMMR_SNWD/readSMMRSNWDsnowObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOPS/SMOPSsm_obsMod.F90 b/ldt/DAobs/SMOPS/SMOPSsm_obsMod.F90 index 45a63e0a4..a05f6e98f 100644 --- a/ldt/DAobs/SMOPS/SMOPSsm_obsMod.F90 +++ b/ldt/DAobs/SMOPS/SMOPSsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOPS/readSMOPSsmObs.F90 b/ldt/DAobs/SMOPS/readSMOPSsmObs.F90 index 84b28265f..67446edc7 100644 --- a/ldt/DAobs/SMOPS/readSMOPSsmObs.F90 +++ b/ldt/DAobs/SMOPS/readSMOPSsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_L2sm/SMOSL2sm_obsMod.F90 b/ldt/DAobs/SMOS_L2sm/SMOSL2sm_obsMod.F90 index 3298a7ac4..c94075b18 100644 --- a/ldt/DAobs/SMOS_L2sm/SMOSL2sm_obsMod.F90 +++ b/ldt/DAobs/SMOS_L2sm/SMOSL2sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_L2sm/readSMOSL2smObs.F90 b/ldt/DAobs/SMOS_L2sm/readSMOSL2smObs.F90 index be9d2ac3d..6d2b198fd 100644 --- a/ldt/DAobs/SMOS_L2sm/readSMOSL2smObs.F90 +++ b/ldt/DAobs/SMOS_L2sm/readSMOSL2smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_NESDIS/SMOSNESDISsm_obsMod.F90 b/ldt/DAobs/SMOS_NESDIS/SMOSNESDISsm_obsMod.F90 index ec340800e..2ab1b799d 100644 --- a/ldt/DAobs/SMOS_NESDIS/SMOSNESDISsm_obsMod.F90 +++ b/ldt/DAobs/SMOS_NESDIS/SMOSNESDISsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_NESDIS/readSMOSNESDISsmObs.F90 b/ldt/DAobs/SMOS_NESDIS/readSMOSNESDISsmObs.F90 index 80c0e1727..fe1be1ce3 100644 --- a/ldt/DAobs/SMOS_NESDIS/readSMOSNESDISsmObs.F90 +++ b/ldt/DAobs/SMOS_NESDIS/readSMOSNESDISsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_obsMod.F90 b/ldt/DAobs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_obsMod.F90 index fea83fcea..d879060ad 100644 --- a/ldt/DAobs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_obsMod.F90 +++ b/ldt/DAobs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_NRTNN_L2sm/readSMOSNRTNNL2smObs.F90 b/ldt/DAobs/SMOS_NRTNN_L2sm/readSMOSNRTNNL2smObs.F90 index 15e9cf570..f202348eb 100644 --- a/ldt/DAobs/SMOS_NRTNN_L2sm/readSMOSNRTNNL2smObs.F90 +++ b/ldt/DAobs/SMOS_NRTNN_L2sm/readSMOSNRTNNL2smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SMOS_NRTNN_L2sm/write_lookup_table.F90 b/ldt/DAobs/SMOS_NRTNN_L2sm/write_lookup_table.F90 index be97e9726..88af470b6 100644 --- a/ldt/DAobs/SMOS_NRTNN_L2sm/write_lookup_table.F90 +++ b/ldt/DAobs/SMOS_NRTNN_L2sm/write_lookup_table.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SSMI_SNWD/SSMISNWDsnow_obsMod.F90 b/ldt/DAobs/SSMI_SNWD/SSMISNWDsnow_obsMod.F90 index acd1e9710..91d3fc487 100644 --- a/ldt/DAobs/SSMI_SNWD/SSMISNWDsnow_obsMod.F90 +++ b/ldt/DAobs/SSMI_SNWD/SSMISNWDsnow_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/SSMI_SNWD/readSSMISNWDsnowObs.F90 b/ldt/DAobs/SSMI_SNWD/readSSMISNWDsnowObs.F90 index ce5995b4b..002455348 100644 --- a/ldt/DAobs/SSMI_SNWD/readSSMISNWDsnowObs.F90 +++ b/ldt/DAobs/SSMI_SNWD/readSSMISNWDsnowObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/THySM/THySM_obsMod.F90 b/ldt/DAobs/THySM/THySM_obsMod.F90 index 569792f9d..2195f64ff 100644 --- a/ldt/DAobs/THySM/THySM_obsMod.F90 +++ b/ldt/DAobs/THySM/THySM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/THySM/readTHySMobs.F90 b/ldt/DAobs/THySM/readTHySMobs.F90 index 33fdf3e9c..abaf99085 100644 --- a/ldt/DAobs/THySM/readTHySMobs.F90 +++ b/ldt/DAobs/THySM/readTHySMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/VIIRS_GVF/VIIRS_GVF_obsMod.F90 b/ldt/DAobs/VIIRS_GVF/VIIRS_GVF_obsMod.F90 index de9fcbb35..01dc43f22 100644 --- a/ldt/DAobs/VIIRS_GVF/VIIRS_GVF_obsMod.F90 +++ b/ldt/DAobs/VIIRS_GVF/VIIRS_GVF_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/VIIRS_GVF/readVIIRS_GVFObs.F90 b/ldt/DAobs/VIIRS_GVF/readVIIRS_GVFObs.F90 index 61b26439d..5842ad0fb 100644 --- a/ldt/DAobs/VIIRS_GVF/readVIIRS_GVFObs.F90 +++ b/ldt/DAobs/VIIRS_GVF/readVIIRS_GVFObs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/WindSat_sm/WindSatsm_obsMod.F90 b/ldt/DAobs/WindSat_sm/WindSatsm_obsMod.F90 index 438695ac1..9fcd7a2ad 100644 --- a/ldt/DAobs/WindSat_sm/WindSatsm_obsMod.F90 +++ b/ldt/DAobs/WindSat_sm/WindSatsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/WindSat_sm/readWindSatsmObs.F90 b/ldt/DAobs/WindSat_sm/readWindSatsmObs.F90 index 0a1f40d50..60d168992 100644 --- a/ldt/DAobs/WindSat_sm/readWindSatsmObs.F90 +++ b/ldt/DAobs/WindSat_sm/readWindSatsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/simGRACE_JPL/readsimGRACEJPLObs.F90 b/ldt/DAobs/simGRACE_JPL/readsimGRACEJPLObs.F90 index 346215755..4ec0015a1 100644 --- a/ldt/DAobs/simGRACE_JPL/readsimGRACEJPLObs.F90 +++ b/ldt/DAobs/simGRACE_JPL/readsimGRACEJPLObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/simGRACE_JPL/simGRACEJPL_obsMod.F90 b/ldt/DAobs/simGRACE_JPL/simGRACEJPL_obsMod.F90 index 5b55999cc..3afe2b5d0 100644 --- a/ldt/DAobs/simGRACE_JPL/simGRACEJPL_obsMod.F90 +++ b/ldt/DAobs/simGRACE_JPL/simGRACEJPL_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/synthetic_sm/readsyntheticsmObs.F90 b/ldt/DAobs/synthetic_sm/readsyntheticsmObs.F90 index f7189aba0..965c19bea 100644 --- a/ldt/DAobs/synthetic_sm/readsyntheticsmObs.F90 +++ b/ldt/DAobs/synthetic_sm/readsyntheticsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/DAobs/synthetic_sm/syntheticsm_obsMod.F90 b/ldt/DAobs/synthetic_sm/syntheticsm_obsMod.F90 index d54f5b99f..10b4332da 100644 --- a/ldt/DAobs/synthetic_sm/syntheticsm_obsMod.F90 +++ b/ldt/DAobs/synthetic_sm/syntheticsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/MetforcScale/LDT_SimpleWeight_TdscaleMod.F90 b/ldt/MetforcScale/LDT_SimpleWeight_TdscaleMod.F90 index d6b989c87..10d5f4b7c 100644 --- a/ldt/MetforcScale/LDT_SimpleWeight_TdscaleMod.F90 +++ b/ldt/MetforcScale/LDT_SimpleWeight_TdscaleMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 index 3edef91d9..2f7584c7d 100644 --- a/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 +++ b/ldt/SMAP_E_OPL/ARFSSMRETRIEVAL.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA GSFC Land Data Toolkit (LDT) +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! SUBROUTINE: ARFSSMRETRIEVAL diff --git a/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 index 5163841cf..c91f9314a 100644 --- a/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_ARFSSM_netcdfMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index f20b9ed67..6a68f5e9f 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 index 8c2b2caad..3f73ca329 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA GSFC Land Data Toolkit (LDT) +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! SUBROUTINE: SMAPL1BRESAMPLE diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index 6cb1d5b15..57f0f45ad 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 717c82a17..59c0ccdbc 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA GSFC Land Data Toolkit (LDT) +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! MODULE: invdist_l1b2arfs diff --git a/ldt/SMAP_E_OPL/readLISTeff.F90 b/ldt/SMAP_E_OPL/readLISTeff.F90 index 9f33be780..362ad7c44 100644 --- a/ldt/SMAP_E_OPL/readLISTeff.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP ! diff --git a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 index b26bb0c39..4dc4c391c 100644 --- a/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 +++ b/ldt/SMAP_E_OPL/readLISTeff_usaf.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" diff --git a/ldt/SMAP_E_OPL/readLISsnow.F90 b/ldt/SMAP_E_OPL/readLISsnow.F90 index 4b39842d8..3279073a1 100644 --- a/ldt/SMAP_E_OPL/readLISsnow.F90 +++ b/ldt/SMAP_E_OPL/readLISsnow.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP ! diff --git a/ldt/SMAP_E_OPL/readUSAFSI.F90 b/ldt/SMAP_E_OPL/readUSAFSI.F90 index a905b6f2c..a1034c34b 100644 --- a/ldt/SMAP_E_OPL/readUSAFSI.F90 +++ b/ldt/SMAP_E_OPL/readUSAFSI.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" #include "LDT_NetCDF_inc.h" diff --git a/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 b/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 index 38215dc65..d5a333dda 100644 --- a/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 +++ b/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP ! diff --git a/ldt/SMAP_E_OPL/scale_teff.F90 b/ldt/SMAP_E_OPL/scale_teff.F90 index c7c97fd07..e4e83dbe1 100644 --- a/ldt/SMAP_E_OPL/scale_teff.F90 +++ b/ldt/SMAP_E_OPL/scale_teff.F90 @@ -3,10 +3,10 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. -!-------------------------END NOTICE -- DO NOT EDIT---------------------- +!-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" !BOP ! diff --git a/ldt/USAFSI/LDT_bratsethMod.F90 b/ldt/USAFSI/LDT_bratsethMod.F90 index dc2ccba0b..f90fec770 100644 --- a/ldt/USAFSI/LDT_bratsethMod.F90 +++ b/ldt/USAFSI/LDT_bratsethMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/LDT_usafsiMod.F90 b/ldt/USAFSI/LDT_usafsiMod.F90 index 66f67d849..71fff404f 100644 --- a/ldt/USAFSI/LDT_usafsiMod.F90 +++ b/ldt/USAFSI/LDT_usafsiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_amsr2Mod.F90 b/ldt/USAFSI/USAFSI_amsr2Mod.F90 index 85c29ffa5..a500d5895 100755 --- a/ldt/USAFSI/USAFSI_amsr2Mod.F90 +++ b/ldt/USAFSI/USAFSI_amsr2Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_analysisMod.F90 b/ldt/USAFSI/USAFSI_analysisMod.F90 index d1d01ab14..2c6ee313f 100644 --- a/ldt/USAFSI/USAFSI_analysisMod.F90 +++ b/ldt/USAFSI/USAFSI_analysisMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_arraysMod.F90 b/ldt/USAFSI/USAFSI_arraysMod.F90 index 59cdffed1..5c895ebf3 100644 --- a/ldt/USAFSI/USAFSI_arraysMod.F90 +++ b/ldt/USAFSI/USAFSI_arraysMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_binary.F90 b/ldt/USAFSI/USAFSI_binary.F90 index c49c65269..efee40177 100644 --- a/ldt/USAFSI/USAFSI_binary.F90 +++ b/ldt/USAFSI/USAFSI_binary.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_galwemMod.F90 b/ldt/USAFSI/USAFSI_galwemMod.F90 index 33b482481..fcf4bb1aa 100644 --- a/ldt/USAFSI/USAFSI_galwemMod.F90 +++ b/ldt/USAFSI/USAFSI_galwemMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_gofsMod.F90 b/ldt/USAFSI/USAFSI_gofsMod.F90 index 0ab04ea73..8096e4977 100644 --- a/ldt/USAFSI/USAFSI_gofsMod.F90 +++ b/ldt/USAFSI/USAFSI_gofsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_lisMod.F90 b/ldt/USAFSI/USAFSI_lisMod.F90 index a0bab9eb7..139b0870d 100644 --- a/ldt/USAFSI/USAFSI_lisMod.F90 +++ b/ldt/USAFSI/USAFSI_lisMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_netcdfMod.F90 b/ldt/USAFSI/USAFSI_netcdfMod.F90 index bf590db9b..fae7e42c4 100644 --- a/ldt/USAFSI/USAFSI_netcdfMod.F90 +++ b/ldt/USAFSI/USAFSI_netcdfMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_paramsMod.F90 b/ldt/USAFSI/USAFSI_paramsMod.F90 index 534e15c7a..c735152bb 100644 --- a/ldt/USAFSI/USAFSI_paramsMod.F90 +++ b/ldt/USAFSI/USAFSI_paramsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_run.F90 b/ldt/USAFSI/USAFSI_run.F90 index 8d9df8ef8..23a34055c 100644 --- a/ldt/USAFSI/USAFSI_run.F90 +++ b/ldt/USAFSI/USAFSI_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_ssmisMod.F90 b/ldt/USAFSI/USAFSI_ssmisMod.F90 index 1557f7475..9e8378fb7 100644 --- a/ldt/USAFSI/USAFSI_ssmisMod.F90 +++ b/ldt/USAFSI/USAFSI_ssmisMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_utilMod.F90 b/ldt/USAFSI/USAFSI_utilMod.F90 index 3d430ca3a..0f26c1f90 100644 --- a/ldt/USAFSI/USAFSI_utilMod.F90 +++ b/ldt/USAFSI/USAFSI_utilMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/USAFSI/USAFSI_xcalgmiMod.F90 b/ldt/USAFSI/USAFSI_xcalgmiMod.F90 index e3e25ef47..51904142e 100755 --- a/ldt/USAFSI/USAFSI_xcalgmiMod.F90 +++ b/ldt/USAFSI/USAFSI_xcalgmiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/arch/Config.pl b/ldt/arch/Config.pl index 2ddc9eee0..d96487fad 100755 --- a/ldt/arch/Config.pl +++ b/ldt/arch/Config.pl @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/compile b/ldt/compile index fb6e4e4c1..658ec2114 100755 --- a/ldt/compile +++ b/ldt/compile @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/configure b/ldt/configure index bab9c35b5..2a6b5efdc 100755 --- a/ldt/configure +++ b/ldt/configure @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_ANNMod.F90 b/ldt/core/LDT_ANNMod.F90 index ca6932ce8..bf5eef3b2 100644 --- a/ldt/core/LDT_ANNMod.F90 +++ b/ldt/core/LDT_ANNMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_ANNdata_FTable.c b/ldt/core/LDT_ANNdata_FTable.c index 67fdcfdd8..4f802da0a 100644 --- a/ldt/core/LDT_ANNdata_FTable.c +++ b/ldt/core/LDT_ANNdata_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_CDFMod.F90 b/ldt/core/LDT_CDFMod.F90 index a3d68e13c..36383d4f5 100644 --- a/ldt/core/LDT_CDFMod.F90 +++ b/ldt/core/LDT_CDFMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DAmetricsDataMod.F90 b/ldt/core/LDT_DAmetricsDataMod.F90 index 23fc1e607..a4eb524bc 100644 --- a/ldt/core/LDT_DAmetricsDataMod.F90 +++ b/ldt/core/LDT_DAmetricsDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DAmetricsMod.F90 b/ldt/core/LDT_DAmetricsMod.F90 index ce02ea2d9..aba631b31 100644 --- a/ldt/core/LDT_DAmetricsMod.F90 +++ b/ldt/core/LDT_DAmetricsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DAobsDataMod.F90 b/ldt/core/LDT_DAobsDataMod.F90 index 27392061d..8faf56ed0 100644 --- a/ldt/core/LDT_DAobsDataMod.F90 +++ b/ldt/core/LDT_DAobsDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DAobs_FTable.c b/ldt/core/LDT_DAobs_FTable.c index fd1284227..255fb970d 100644 --- a/ldt/core/LDT_DAobs_FTable.c +++ b/ldt/core/LDT_DAobs_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DAobservationsMod.F90 b/ldt/core/LDT_DAobservationsMod.F90 index 9949bb8bc..feaf4bb4b 100644 --- a/ldt/core/LDT_DAobservationsMod.F90 +++ b/ldt/core/LDT_DAobservationsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DApreprocMod.F90 b/ldt/core/LDT_DApreprocMod.F90 index bce21191e..6cf50e8bc 100644 --- a/ldt/core/LDT_DApreprocMod.F90 +++ b/ldt/core/LDT_DApreprocMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_DrangeMod.F90 b/ldt/core/LDT_DrangeMod.F90 index b08e3b18a..3fa0947a5 100644 --- a/ldt/core/LDT_DrangeMod.F90 +++ b/ldt/core/LDT_DrangeMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_FORC_AttributesMod.F90 b/ldt/core/LDT_FORC_AttributesMod.F90 index 590162da2..6321e547a 100644 --- a/ldt/core/LDT_FORC_AttributesMod.F90 +++ b/ldt/core/LDT_FORC_AttributesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_LMLCMod.F90 b/ldt/core/LDT_LMLCMod.F90 index 188fa70be..c60c93261 100644 --- a/ldt/core/LDT_LMLCMod.F90 +++ b/ldt/core/LDT_LMLCMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_LSMCropModifier_Mod.F90 b/ldt/core/LDT_LSMCropModifier_Mod.F90 index c8f7cf474..0947b1cea 100644 --- a/ldt/core/LDT_LSMCropModifier_Mod.F90 +++ b/ldt/core/LDT_LSMCropModifier_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_LSMparamProcMod.F90 b/ldt/core/LDT_LSMparamProcMod.F90 index c5d9c2dcb..8722c067e 100644 --- a/ldt/core/LDT_LSMparamProcMod.F90 +++ b/ldt/core/LDT_LSMparamProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_LSMparams_FTable.c b/ldt/core/LDT_LSMparams_FTable.c index c195261f2..7d2812ac9 100644 --- a/ldt/core/LDT_LSMparams_FTable.c +++ b/ldt/core/LDT_LSMparams_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_MuMod.F90 b/ldt/core/LDT_MuMod.F90 index c73796e4d..2788390a9 100644 --- a/ldt/core/LDT_MuMod.F90 +++ b/ldt/core/LDT_MuMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_NUWRFprocMod.F90 b/ldt/core/LDT_NUWRFprocMod.F90 index 5c0dfbe67..82cf871db 100644 --- a/ldt/core/LDT_NUWRFprocMod.F90 +++ b/ldt/core/LDT_NUWRFprocMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_NatRunData_FTable.c b/ldt/core/LDT_NatRunData_FTable.c index cf65819fb..b8421a0a0 100644 --- a/ldt/core/LDT_NatRunData_FTable.c +++ b/ldt/core/LDT_NatRunData_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_OPTUEMod.F90 b/ldt/core/LDT_OPTUEMod.F90 index 62e401af2..12bb5fae6 100644 --- a/ldt/core/LDT_OPTUEMod.F90 +++ b/ldt/core/LDT_OPTUEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_OSSEmaskData_FTable.c b/ldt/core/LDT_OSSEmaskData_FTable.c index 77c295f68..e25e748d4 100644 --- a/ldt/core/LDT_OSSEmaskData_FTable.c +++ b/ldt/core/LDT_OSSEmaskData_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_PRIV_gridMod.F90 b/ldt/core/LDT_PRIV_gridMod.F90 index 5b97bdc83..90433ea5d 100644 --- a/ldt/core/LDT_PRIV_gridMod.F90 +++ b/ldt/core/LDT_PRIV_gridMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_PRIV_rcMod.F90 b/ldt/core/LDT_PRIV_rcMod.F90 index 318e20217..6d0befdad 100644 --- a/ldt/core/LDT_PRIV_rcMod.F90 +++ b/ldt/core/LDT_PRIV_rcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_PRIV_tileMod.F90 b/ldt/core/LDT_PRIV_tileMod.F90 index c78a2cbf0..39241f8dc 100644 --- a/ldt/core/LDT_PRIV_tileMod.F90 +++ b/ldt/core/LDT_PRIV_tileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_SigmaMod.F90 b/ldt/core/LDT_SigmaMod.F90 index f806b507b..4deff4e52 100644 --- a/ldt/core/LDT_SigmaMod.F90 +++ b/ldt/core/LDT_SigmaMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_SurfaceTypeMod.F90 b/ldt/core/LDT_SurfaceTypeMod.F90 index d40a022e5..3c6424605 100644 --- a/ldt/core/LDT_SurfaceTypeMod.F90 +++ b/ldt/core/LDT_SurfaceTypeMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_albedoMod.F90 b/ldt/core/LDT_albedoMod.F90 index b17e6b7c8..15793b1fe 100644 --- a/ldt/core/LDT_albedoMod.F90 +++ b/ldt/core/LDT_albedoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_albedo_FTable.c b/ldt/core/LDT_albedo_FTable.c index 41250640b..e8fa0eae6 100644 --- a/ldt/core/LDT_albedo_FTable.c +++ b/ldt/core/LDT_albedo_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_binaryIOlayer_module.F90 b/ldt/core/LDT_binaryIOlayer_module.F90 index f6bce81ae..9a352a319 100644 --- a/ldt/core/LDT_binaryIOlayer_module.F90 +++ b/ldt/core/LDT_binaryIOlayer_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_climateParmsMod.F90 b/ldt/core/LDT_climateParmsMod.F90 index 0be9f8ae5..f7146a592 100644 --- a/ldt/core/LDT_climateParmsMod.F90 +++ b/ldt/core/LDT_climateParmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_climoRstProcMod.F90 b/ldt/core/LDT_climoRstProcMod.F90 index 5f55a32da..5547245af 100644 --- a/ldt/core/LDT_climoRstProcMod.F90 +++ b/ldt/core/LDT_climoRstProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_climparms_FTable.c b/ldt/core/LDT_climparms_FTable.c index 592b817ef..dfb8dd8af 100644 --- a/ldt/core/LDT_climparms_FTable.c +++ b/ldt/core/LDT_climparms_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_constantsMod.F90 b/ldt/core/LDT_constantsMod.F90 index 7eb6f65a1..d667adba5 100644 --- a/ldt/core/LDT_constantsMod.F90 +++ b/ldt/core/LDT_constantsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_coreMod.F90 b/ldt/core/LDT_coreMod.F90 index cc111b6bc..d956afbc0 100644 --- a/ldt/core/LDT_coreMod.F90 +++ b/ldt/core/LDT_coreMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_create_subdirs.c b/ldt/core/LDT_create_subdirs.c index bfef1d735..dc0af42a0 100644 --- a/ldt/core/LDT_create_subdirs.c +++ b/ldt/core/LDT_create_subdirs.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_domainMod.F90 b/ldt/core/LDT_domainMod.F90 index 6dc7b1f5f..396b17a02 100644 --- a/ldt/core/LDT_domainMod.F90 +++ b/ldt/core/LDT_domainMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_domain_FTable.c b/ldt/core/LDT_domain_FTable.c index 21623a99b..5871543a5 100644 --- a/ldt/core/LDT_domain_FTable.c +++ b/ldt/core/LDT_domain_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_ensRstMod.F90 b/ldt/core/LDT_ensRstMod.F90 index 3f8c2588a..b6549ee7a 100644 --- a/ldt/core/LDT_ensRstMod.F90 +++ b/ldt/core/LDT_ensRstMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_fileIOMod.F90 b/ldt/core/LDT_fileIOMod.F90 index 096b3a383..246c51294 100644 --- a/ldt/core/LDT_fileIOMod.F90 +++ b/ldt/core/LDT_fileIOMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_forcingparms_Ftable.c b/ldt/core/LDT_forcingparms_Ftable.c index 7fb0708cc..f6be0ef1c 100644 --- a/ldt/core/LDT_forcingparms_Ftable.c +++ b/ldt/core/LDT_forcingparms_Ftable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_gfracMod.F90 b/ldt/core/LDT_gfracMod.F90 index a0ed6a23b..78ee092a6 100644 --- a/ldt/core/LDT_gfracMod.F90 +++ b/ldt/core/LDT_gfracMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_gfrac_FTable.c b/ldt/core/LDT_gfrac_FTable.c index a3ccfe49c..fe47d33df 100644 --- a/ldt/core/LDT_gfrac_FTable.c +++ b/ldt/core/LDT_gfrac_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_glacierFractionMod.F90 b/ldt/core/LDT_glacierFractionMod.F90 index 3d1855ded..d3d4d9d80 100644 --- a/ldt/core/LDT_glacierFractionMod.F90 +++ b/ldt/core/LDT_glacierFractionMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_glacierMod.F90 b/ldt/core/LDT_glacierMod.F90 index 439e01096..53dee3951 100644 --- a/ldt/core/LDT_glacierMod.F90 +++ b/ldt/core/LDT_glacierMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_glacier_FTable.c b/ldt/core/LDT_glacier_FTable.c index a80d3fca3..382ce231e 100644 --- a/ldt/core/LDT_glacier_FTable.c +++ b/ldt/core/LDT_glacier_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_gridmappingMod.F90 b/ldt/core/LDT_gridmappingMod.F90 index 4febde5fe..56d64c421 100644 --- a/ldt/core/LDT_gridmappingMod.F90 +++ b/ldt/core/LDT_gridmappingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_historyMod.F90 b/ldt/core/LDT_historyMod.F90 index 8a0462f89..fe89bd4b2 100644 --- a/ldt/core/LDT_historyMod.F90 +++ b/ldt/core/LDT_historyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_irrig_Ftable.c b/ldt/core/LDT_irrig_Ftable.c index 4e08180bf..9465ed944 100644 --- a/ldt/core/LDT_irrig_Ftable.c +++ b/ldt/core/LDT_irrig_Ftable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_irrigationMod.F90 b/ldt/core/LDT_irrigationMod.F90 index 4c40f5879..e63e8c976 100644 --- a/ldt/core/LDT_irrigationMod.F90 +++ b/ldt/core/LDT_irrigationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_laisaiMod.F90 b/ldt/core/LDT_laisaiMod.F90 index 19b154c98..11a61e1bf 100644 --- a/ldt/core/LDT_laisaiMod.F90 +++ b/ldt/core/LDT_laisaiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_laisai_FTable.c b/ldt/core/LDT_laisai_FTable.c index df205a80d..05d628f3f 100644 --- a/ldt/core/LDT_laisai_FTable.c +++ b/ldt/core/LDT_laisai_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_lakeParamProcMod.F90 b/ldt/core/LDT_lakeParamProcMod.F90 index ae93252fd..a48170260 100644 --- a/ldt/core/LDT_lakeParamProcMod.F90 +++ b/ldt/core/LDT_lakeParamProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_lakeparams_FTable.c b/ldt/core/LDT_lakeparams_FTable.c index c1e374671..66cdc8939 100644 --- a/ldt/core/LDT_lakeparams_FTable.c +++ b/ldt/core/LDT_lakeparams_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_landcover_FTable.c b/ldt/core/LDT_landcover_FTable.c index 74f0ba0be..f31fdbafc 100644 --- a/ldt/core/LDT_landcover_FTable.c +++ b/ldt/core/LDT_landcover_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_logMod.F90 b/ldt/core/LDT_logMod.F90 index 88d427e51..0901750b1 100644 --- a/ldt/core/LDT_logMod.F90 +++ b/ldt/core/LDT_logMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_mapSurfaceModelType.F90 b/ldt/core/LDT_mapSurfaceModelType.F90 index ce046fa44..34b97a79b 100644 --- a/ldt/core/LDT_mapSurfaceModelType.F90 +++ b/ldt/core/LDT_mapSurfaceModelType.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_mask_FTable.c b/ldt/core/LDT_mask_FTable.c index 57bbd27c8..06b412503 100644 --- a/ldt/core/LDT_mask_FTable.c +++ b/ldt/core/LDT_mask_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_metforcDscaleMod.F90 b/ldt/core/LDT_metforcDscaleMod.F90 index 33264010d..b69fe3f04 100644 --- a/ldt/core/LDT_metforcDscaleMod.F90 +++ b/ldt/core/LDT_metforcDscaleMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_metforcdscale_FTable.c b/ldt/core/LDT_metforcdscale_FTable.c index ed425f482..a2f44d6ac 100644 --- a/ldt/core/LDT_metforcdscale_FTable.c +++ b/ldt/core/LDT_metforcdscale_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_metforcingMod.F90 b/ldt/core/LDT_metforcingMod.F90 index f728358d1..d8be4abad 100644 --- a/ldt/core/LDT_metforcingMod.F90 +++ b/ldt/core/LDT_metforcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_metforcingParmsMod.F90 b/ldt/core/LDT_metforcingParmsMod.F90 index 6fbdf813b..36cbfa10b 100644 --- a/ldt/core/LDT_metforcingParmsMod.F90 +++ b/ldt/core/LDT_metforcingParmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_metforcing_FTable.c b/ldt/core/LDT_metforcing_FTable.c index 2b0b2e318..4888fc6df 100644 --- a/ldt/core/LDT_metforcing_FTable.c +++ b/ldt/core/LDT_metforcing_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_mpDecomp.c b/ldt/core/LDT_mpDecomp.c index eca19ae56..6a2f0d593 100644 --- a/ldt/core/LDT_mpDecomp.c +++ b/ldt/core/LDT_mpDecomp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_mpiMod.F90 b/ldt/core/LDT_mpiMod.F90 index ffeb15a7b..ed523613c 100644 --- a/ldt/core/LDT_mpiMod.F90 +++ b/ldt/core/LDT_mpiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_noahparms_FTable.c b/ldt/core/LDT_noahparms_FTable.c index a4cb08e6a..7b3a82a2b 100644 --- a/ldt/core/LDT_noahparms_FTable.c +++ b/ldt/core/LDT_noahparms_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_numericalMethodsMod.F90 b/ldt/core/LDT_numericalMethodsMod.F90 index aa7d7bedc..839356369 100644 --- a/ldt/core/LDT_numericalMethodsMod.F90 +++ b/ldt/core/LDT_numericalMethodsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_obsSimMod.F90 b/ldt/core/LDT_obsSimMod.F90 index 7dc5422c2..75501b137 100644 --- a/ldt/core/LDT_obsSimMod.F90 +++ b/ldt/core/LDT_obsSimMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_openwaterMod.F90 b/ldt/core/LDT_openwaterMod.F90 index abfa213cf..16f22df21 100644 --- a/ldt/core/LDT_openwaterMod.F90 +++ b/ldt/core/LDT_openwaterMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_paramDataMod.F90 b/ldt/core/LDT_paramDataMod.F90 index 600bf48ef..00bcb0a49 100644 --- a/ldt/core/LDT_paramDataMod.F90 +++ b/ldt/core/LDT_paramDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_paramMaskCheckMod.F90 b/ldt/core/LDT_paramMaskCheckMod.F90 index 69ee50a6d..a38ae56d7 100644 --- a/ldt/core/LDT_paramMaskCheckMod.F90 +++ b/ldt/core/LDT_paramMaskCheckMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_paramOptCheckMod.F90 b/ldt/core/LDT_paramOptCheckMod.F90 index b3b9d8efc..58882f98b 100644 --- a/ldt/core/LDT_paramOptCheckMod.F90 +++ b/ldt/core/LDT_paramOptCheckMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_paramProcMod.F90 b/ldt/core/LDT_paramProcMod.F90 index 6d58cd4f0..b47d65c98 100644 --- a/ldt/core/LDT_paramProcMod.F90 +++ b/ldt/core/LDT_paramProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_paramTileInputMod.F90 b/ldt/core/LDT_paramTileInputMod.F90 index b55f0bacb..a87768910 100644 --- a/ldt/core/LDT_paramTileInputMod.F90 +++ b/ldt/core/LDT_paramTileInputMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_ran2_gasdev.F90 b/ldt/core/LDT_ran2_gasdev.F90 index a73e221db..e2a7c29f1 100644 --- a/ldt/core/LDT_ran2_gasdev.F90 +++ b/ldt/core/LDT_ran2_gasdev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_readConfig.F90 b/ldt/core/LDT_readConfig.F90 index e035de22b..9303d707b 100644 --- a/ldt/core/LDT_readConfig.F90 +++ b/ldt/core/LDT_readConfig.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_routingParamProcMod.F90 b/ldt/core/LDT_routingParamProcMod.F90 index 51ff7ef81..626e92529 100644 --- a/ldt/core/LDT_routingParamProcMod.F90 +++ b/ldt/core/LDT_routingParamProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_routingparams_FTable.c b/ldt/core/LDT_routingparams_FTable.c index 82bec17cb..28b98761b 100644 --- a/ldt/core/LDT_routingparams_FTable.c +++ b/ldt/core/LDT_routingparams_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_rstTransformProcMod.F90 b/ldt/core/LDT_rstTransformProcMod.F90 index 13141e5f2..33116e44e 100644 --- a/ldt/core/LDT_rstTransformProcMod.F90 +++ b/ldt/core/LDT_rstTransformProcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_runmode_FTable.c b/ldt/core/LDT_runmode_FTable.c index 1d2551151..b5a489ebf 100644 --- a/ldt/core/LDT_runmode_FTable.c +++ b/ldt/core/LDT_runmode_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_soilsMod.F90 b/ldt/core/LDT_soilsMod.F90 index 7eb889b1f..dd750988c 100644 --- a/ldt/core/LDT_soilsMod.F90 +++ b/ldt/core/LDT_soilsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_soils_FTable.c b/ldt/core/LDT_soils_FTable.c index a178f69b0..017cfa136 100644 --- a/ldt/core/LDT_soils_FTable.c +++ b/ldt/core/LDT_soils_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_spatialDownscalingMod.F90 b/ldt/core/LDT_spatialDownscalingMod.F90 index 77947dc6b..d84e014e0 100644 --- a/ldt/core/LDT_spatialDownscalingMod.F90 +++ b/ldt/core/LDT_spatialDownscalingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_statDscaleMod.F90 b/ldt/core/LDT_statDscaleMod.F90 index a39ee4789..6b360fa01 100644 --- a/ldt/core/LDT_statDscaleMod.F90 +++ b/ldt/core/LDT_statDscaleMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_statdscale_FTable.c b/ldt/core/LDT_statdscale_FTable.c index cb20dadc1..1136d823f 100644 --- a/ldt/core/LDT_statdscale_FTable.c +++ b/ldt/core/LDT_statdscale_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_timeMgrMod.F90 b/ldt/core/LDT_timeMgrMod.F90 index f9d555f5b..20ac021fb 100644 --- a/ldt/core/LDT_timeMgrMod.F90 +++ b/ldt/core/LDT_timeMgrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_topoMod.F90 b/ldt/core/LDT_topoMod.F90 index 401d6da1c..99e7f630b 100644 --- a/ldt/core/LDT_topoMod.F90 +++ b/ldt/core/LDT_topoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_topo_FTable.c b/ldt/core/LDT_topo_FTable.c index 034c633ee..303f361ed 100644 --- a/ldt/core/LDT_topo_FTable.c +++ b/ldt/core/LDT_topo_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/LDT_vegdataMod.F90 b/ldt/core/LDT_vegdataMod.F90 index 39996e749..59c02e9da 100644 --- a/ldt/core/LDT_vegdataMod.F90 +++ b/ldt/core/LDT_vegdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/core/readzipf.c b/ldt/core/readzipf.c index 5af14f8c8..b2781c0da 100644 --- a/ldt/core/readzipf.c +++ b/ldt/core/readzipf.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/UTM/readinput_UTM.F90 b/ldt/domains/UTM/readinput_UTM.F90 index 2685d62c8..5e37bbcb5 100644 --- a/ldt/domains/UTM/readinput_UTM.F90 +++ b/ldt/domains/UTM/readinput_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/easev2/readinput_easev2.F90 b/ldt/domains/easev2/readinput_easev2.F90 index 9b8d833d3..503b22d08 100644 --- a/ldt/domains/easev2/readinput_easev2.F90 +++ b/ldt/domains/easev2/readinput_easev2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/gaussian/gaussian_quadrature.F90 b/ldt/domains/gaussian/gaussian_quadrature.F90 index 015064f65..371053a76 100644 --- a/ldt/domains/gaussian/gaussian_quadrature.F90 +++ b/ldt/domains/gaussian/gaussian_quadrature.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/gaussian/readinput_gaussian.F90 b/ldt/domains/gaussian/readinput_gaussian.F90 index dce52b10b..a02007c40 100644 --- a/ldt/domains/gaussian/readinput_gaussian.F90 +++ b/ldt/domains/gaussian/readinput_gaussian.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/hrap/readinput_hrap.F90 b/ldt/domains/hrap/readinput_hrap.F90 index 0f767d88e..5acb2f1f2 100644 --- a/ldt/domains/hrap/readinput_hrap.F90 +++ b/ldt/domains/hrap/readinput_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/lambert/readinput_lambert.F90 b/ldt/domains/lambert/readinput_lambert.F90 index 1e9e10976..a7dd864bb 100644 --- a/ldt/domains/lambert/readinput_lambert.F90 +++ b/ldt/domains/lambert/readinput_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/latlon/readinput_latlon.F90 b/ldt/domains/latlon/readinput_latlon.F90 index d3ed74632..a4611bf87 100644 --- a/ldt/domains/latlon/readinput_latlon.F90 +++ b/ldt/domains/latlon/readinput_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/merc/readinput_merc.F90 b/ldt/domains/merc/readinput_merc.F90 index 4a3115dbe..67dcd8587 100644 --- a/ldt/domains/merc/readinput_merc.F90 +++ b/ldt/domains/merc/readinput_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/domains/polar/readinput_polar.F90 b/ldt/domains/polar/readinput_polar.F90 index 06f068ed4..848e91b90 100644 --- a/ldt/domains/polar/readinput_polar.F90 +++ b/ldt/domains/polar/readinput_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/UTM_utils.F90 b/ldt/interp/UTM_utils.F90 index 9c574de3d..0a88b4b49 100755 --- a/ldt/interp/UTM_utils.F90 +++ b/ldt/interp/UTM_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/bilinear_interp.F90 b/ldt/interp/bilinear_interp.F90 index 1f6c42605..cd37f2ad9 100644 --- a/ldt/interp/bilinear_interp.F90 +++ b/ldt/interp/bilinear_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/bilinear_interp_input.F90 b/ldt/interp/bilinear_interp_input.F90 index 36691b319..8d6224eb0 100644 --- a/ldt/interp/bilinear_interp_input.F90 +++ b/ldt/interp/bilinear_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/bilinear_interp_input_withgrid.F90 b/ldt/interp/bilinear_interp_input_withgrid.F90 index abada4a96..966d6177f 100644 --- a/ldt/interp/bilinear_interp_input_withgrid.F90 +++ b/ldt/interp/bilinear_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/breakpt_module.F90 b/ldt/interp/breakpt_module.F90 index a9c40c979..699db0a57 100644 --- a/ldt/interp/breakpt_module.F90 +++ b/ldt/interp/breakpt_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord.F90 b/ldt/interp/compute_earth_coord.F90 index a246fdc50..4db7a608e 100644 --- a/ldt/interp/compute_earth_coord.F90 +++ b/ldt/interp/compute_earth_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_UTM.F90 b/ldt/interp/compute_earth_coord_UTM.F90 index 2a95ad9b2..df22653d0 100644 --- a/ldt/interp/compute_earth_coord_UTM.F90 +++ b/ldt/interp/compute_earth_coord_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_ease.F90 b/ldt/interp/compute_earth_coord_ease.F90 index 281b07fef..0dc39a925 100644 --- a/ldt/interp/compute_earth_coord_ease.F90 +++ b/ldt/interp/compute_earth_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_gauss.F90 b/ldt/interp/compute_earth_coord_gauss.F90 index 4d0f74dc0..889336aa7 100644 --- a/ldt/interp/compute_earth_coord_gauss.F90 +++ b/ldt/interp/compute_earth_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_hrap.F90 b/ldt/interp/compute_earth_coord_hrap.F90 index 21ff8ecae..6d8843fb7 100644 --- a/ldt/interp/compute_earth_coord_hrap.F90 +++ b/ldt/interp/compute_earth_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_lambert.F90 b/ldt/interp/compute_earth_coord_lambert.F90 index 4d0e40d32..bea34c7be 100644 --- a/ldt/interp/compute_earth_coord_lambert.F90 +++ b/ldt/interp/compute_earth_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_latlon.F90 b/ldt/interp/compute_earth_coord_latlon.F90 index 0e9f17375..ed5d475af 100644 --- a/ldt/interp/compute_earth_coord_latlon.F90 +++ b/ldt/interp/compute_earth_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_latlon_ll.F90 b/ldt/interp/compute_earth_coord_latlon_ll.F90 index f635143b3..dd1552a9e 100644 --- a/ldt/interp/compute_earth_coord_latlon_ll.F90 +++ b/ldt/interp/compute_earth_coord_latlon_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_latlon_ur.F90 b/ldt/interp/compute_earth_coord_latlon_ur.F90 index 746758fe8..352e3316f 100644 --- a/ldt/interp/compute_earth_coord_latlon_ur.F90 +++ b/ldt/interp/compute_earth_coord_latlon_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_ll.F90 b/ldt/interp/compute_earth_coord_ll.F90 index b8f4b2cf4..5ddbc32e5 100644 --- a/ldt/interp/compute_earth_coord_ll.F90 +++ b/ldt/interp/compute_earth_coord_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_merc.F90 b/ldt/interp/compute_earth_coord_merc.F90 index 857367e14..6050b5ab9 100644 --- a/ldt/interp/compute_earth_coord_merc.F90 +++ b/ldt/interp/compute_earth_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_polar.F90 b/ldt/interp/compute_earth_coord_polar.F90 index 68967fae0..c790f8bf8 100644 --- a/ldt/interp/compute_earth_coord_polar.F90 +++ b/ldt/interp/compute_earth_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_earth_coord_ur.F90 b/ldt/interp/compute_earth_coord_ur.F90 index a1bf875db..e3c7fadb8 100644 --- a/ldt/interp/compute_earth_coord_ur.F90 +++ b/ldt/interp/compute_earth_coord_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord.F90 b/ldt/interp/compute_grid_coord.F90 index c6c6a3b9c..7c50b76f3 100644 --- a/ldt/interp/compute_grid_coord.F90 +++ b/ldt/interp/compute_grid_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_ease.F90 b/ldt/interp/compute_grid_coord_ease.F90 index b16d34561..373101f34 100644 --- a/ldt/interp/compute_grid_coord_ease.F90 +++ b/ldt/interp/compute_grid_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_gauss.F90 b/ldt/interp/compute_grid_coord_gauss.F90 index 038b89b43..376580aa2 100644 --- a/ldt/interp/compute_grid_coord_gauss.F90 +++ b/ldt/interp/compute_grid_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_hrap.F90 b/ldt/interp/compute_grid_coord_hrap.F90 index d6bba4f09..892fdda2d 100644 --- a/ldt/interp/compute_grid_coord_hrap.F90 +++ b/ldt/interp/compute_grid_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_lambert.F90 b/ldt/interp/compute_grid_coord_lambert.F90 index 12c23200f..d699e999a 100644 --- a/ldt/interp/compute_grid_coord_lambert.F90 +++ b/ldt/interp/compute_grid_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_latlon.F90 b/ldt/interp/compute_grid_coord_latlon.F90 index cff48fb7a..f4e9beadc 100644 --- a/ldt/interp/compute_grid_coord_latlon.F90 +++ b/ldt/interp/compute_grid_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_merc.F90 b/ldt/interp/compute_grid_coord_merc.F90 index 7fa420223..4dc597365 100644 --- a/ldt/interp/compute_grid_coord_merc.F90 +++ b/ldt/interp/compute_grid_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_grid_coord_polar.F90 b/ldt/interp/compute_grid_coord_polar.F90 index e9e653eac..38adc02ed 100644 --- a/ldt/interp/compute_grid_coord_polar.F90 +++ b/ldt/interp/compute_grid_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_stnwts.F90 b/ldt/interp/compute_stnwts.F90 index ea829845e..88d72f2de 100644 --- a/ldt/interp/compute_stnwts.F90 +++ b/ldt/interp/compute_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/compute_vinterp_weights.F90 b/ldt/interp/compute_vinterp_weights.F90 index 30d1dc267..b4ec7f9cf 100644 --- a/ldt/interp/compute_vinterp_weights.F90 +++ b/ldt/interp/compute_vinterp_weights.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/conserv_interp.F90 b/ldt/interp/conserv_interp.F90 index 95d918aa0..46d80870a 100644 --- a/ldt/interp/conserv_interp.F90 +++ b/ldt/interp/conserv_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/conserv_interp_input.F90 b/ldt/interp/conserv_interp_input.F90 index 6c78b597b..f9fbaa448 100644 --- a/ldt/interp/conserv_interp_input.F90 +++ b/ldt/interp/conserv_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/conserv_interp_input_withgrid.F90 b/ldt/interp/conserv_interp_input_withgrid.F90 index bb5bbe544..22ce86e36 100644 --- a/ldt/interp/conserv_interp_input_withgrid.F90 +++ b/ldt/interp/conserv_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/diff_lon.F90 b/ldt/interp/diff_lon.F90 index 91792709a..ac3247b68 100644 --- a/ldt/interp/diff_lon.F90 +++ b/ldt/interp/diff_lon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/ezlh_convert.F90 b/ldt/interp/ezlh_convert.F90 index d86cb9a4f..e83289fd5 100755 --- a/ldt/interp/ezlh_convert.F90 +++ b/ldt/interp/ezlh_convert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/ezlh_inverse.F90 b/ldt/interp/ezlh_inverse.F90 index dce789cfe..91843a741 100755 --- a/ldt/interp/ezlh_inverse.F90 +++ b/ldt/interp/ezlh_inverse.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/gaussian_mod.F90.keep b/ldt/interp/gaussian_mod.F90.keep index bd9563b6f..63eaaaa2a 100644 --- a/ldt/interp/gaussian_mod.F90.keep +++ b/ldt/interp/gaussian_mod.F90.keep @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/gaussian_routines.F90 b/ldt/interp/gaussian_routines.F90 index 79ee8e111..68080c8c7 100644 --- a/ldt/interp/gaussian_routines.F90 +++ b/ldt/interp/gaussian_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/gausslat.F90 b/ldt/interp/gausslat.F90 index 20128406c..b91e70d45 100644 --- a/ldt/interp/gausslat.F90 +++ b/ldt/interp/gausslat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/get_fieldpos.F90 b/ldt/interp/get_fieldpos.F90 index e42e23eda..6951aaf9f 100644 --- a/ldt/interp/get_fieldpos.F90 +++ b/ldt/interp/get_fieldpos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/hrapToLatLon.F90 b/ldt/interp/hrapToLatLon.F90 index de7a66e8a..9be802cc6 100644 --- a/ldt/interp/hrapToLatLon.F90 +++ b/ldt/interp/hrapToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/idw_module.F90 b/ldt/interp/idw_module.F90 index 022f45851..1cf214bbf 100644 --- a/ldt/interp/idw_module.F90 +++ b/ldt/interp/idw_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/interp_stndata.F90 b/ldt/interp/interp_stndata.F90 index 8d6c7b7b3..7f1a310ff 100644 --- a/ldt/interp/interp_stndata.F90 +++ b/ldt/interp/interp_stndata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/latlonTohrap.F90 b/ldt/interp/latlonTohrap.F90 index f3a8928ab..8718605c6 100644 --- a/ldt/interp/latlonTohrap.F90 +++ b/ldt/interp/latlonTohrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/latlonTopolar.F90 b/ldt/interp/latlonTopolar.F90 index 55df36918..365662ce0 100644 --- a/ldt/interp/latlonTopolar.F90 +++ b/ldt/interp/latlonTopolar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/lltops.F90 b/ldt/interp/lltops.F90 index 4f3661ab7..7812c9917 100644 --- a/ldt/interp/lltops.F90 +++ b/ldt/interp/lltops.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/map_utils.F90 b/ldt/interp/map_utils.F90 index 65477cd24..e54080e81 100644 --- a/ldt/interp/map_utils.F90 +++ b/ldt/interp/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/mqb_module.F90 b/ldt/interp/mqb_module.F90 index 414ae5f62..f5bba3e33 100644 --- a/ldt/interp/mqb_module.F90 +++ b/ldt/interp/mqb_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/neighbor_interp.F90 b/ldt/interp/neighbor_interp.F90 index 6f0e594c9..9ecd28d78 100644 --- a/ldt/interp/neighbor_interp.F90 +++ b/ldt/interp/neighbor_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/neighbor_interp_input.F90 b/ldt/interp/neighbor_interp_input.F90 index 4a1c572eb..d0d9c1044 100644 --- a/ldt/interp/neighbor_interp_input.F90 +++ b/ldt/interp/neighbor_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/neighbor_interp_input_withgrid.F90 b/ldt/interp/neighbor_interp_input_withgrid.F90 index 8b77b1636..aba0b5541 100644 --- a/ldt/interp/neighbor_interp_input_withgrid.F90 +++ b/ldt/interp/neighbor_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/normalize_stnwts.F90 b/ldt/interp/normalize_stnwts.F90 index 0f8e5d480..d95252415 100644 --- a/ldt/interp/normalize_stnwts.F90 +++ b/ldt/interp/normalize_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/polarToLatLon.F90 b/ldt/interp/polarToLatLon.F90 index 700249857..da44ae1b4 100644 --- a/ldt/interp/polarToLatLon.F90 +++ b/ldt/interp/polarToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/polfixs.F90 b/ldt/interp/polfixs.F90 index 29c6fbe8a..76d65363c 100644 --- a/ldt/interp/polfixs.F90 +++ b/ldt/interp/polfixs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/pstoll.F90 b/ldt/interp/pstoll.F90 index 0a8818363..165f0cd44 100644 --- a/ldt/interp/pstoll.F90 +++ b/ldt/interp/pstoll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/stninterp_module.F90 b/ldt/interp/stninterp_module.F90 index 6397ecc40..acadaeed2 100644 --- a/ldt/interp/stninterp_module.F90 +++ b/ldt/interp/stninterp_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/upscaleByAveraging.F90 b/ldt/interp/upscaleByAveraging.F90 index c990bb6c1..28872cd92 100644 --- a/ldt/interp/upscaleByAveraging.F90 +++ b/ldt/interp/upscaleByAveraging.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/upscaleByAveraging_input.F90 b/ldt/interp/upscaleByAveraging_input.F90 index 25a4a8fd1..7afdfd95b 100644 --- a/ldt/interp/upscaleByAveraging_input.F90 +++ b/ldt/interp/upscaleByAveraging_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/upscaleByCnt.F90 b/ldt/interp/upscaleByCnt.F90 index 3c784b863..8088f452e 100644 --- a/ldt/interp/upscaleByCnt.F90 +++ b/ldt/interp/upscaleByCnt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/upscaleByMode.F90 b/ldt/interp/upscaleByMode.F90 index 3146ee331..57c43fb17 100755 --- a/ldt/interp/upscaleByMode.F90 +++ b/ldt/interp/upscaleByMode.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/vinterp.F90 b/ldt/interp/vinterp.F90 index acacc4ef6..4186f7939 100644 --- a/ldt/interp/vinterp.F90 +++ b/ldt/interp/vinterp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/interp/zterp.F90 b/ldt/interp/zterp.F90 index beca04190..ee8057224 100644 --- a/ldt/interp/zterp.F90 +++ b/ldt/interp/zterp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/lib/xmrg/LDT_xmrg_reader.F90 b/ldt/lib/xmrg/LDT_xmrg_reader.F90 index d23afd869..7bd2af9c1 100755 --- a/ldt/lib/xmrg/LDT_xmrg_reader.F90 +++ b/ldt/lib/xmrg/LDT_xmrg_reader.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/main/LDTmain.F90 b/ldt/main/LDTmain.F90 index 1fb4bc9c3..6d9c5cea6 100644 --- a/ldt/main/LDTmain.F90 +++ b/ldt/main/LDTmain.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/make/makedep.py b/ldt/make/makedep.py index a7d033e9c..daec48a11 100755 --- a/ldt/make/makedep.py +++ b/ldt/make/makedep.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 b/ldt/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 index c32a381db..f63143aab 100644 --- a/ldt/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 +++ b/ldt/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 index 1f58eb638..148a9f4f6 100644 --- a/ldt/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 index d06323251..f7bdbf7a7 100644 --- a/ldt/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 index 521919b68..15f8030aa 100644 --- a/ldt/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 index b80953c07..0c3b42227 100644 --- a/ldt/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 index 7870567f2..88424da6a 100644 --- a/ldt/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 b/ldt/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 index 1b02b7186..2babdef6f 100644 --- a/ldt/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 +++ b/ldt/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 b/ldt/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 index 094b4135c..45c42fb2a 100644 --- a/ldt/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 +++ b/ldt/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/finalize_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/finalize_TRMM3B42V6.F90 index baa1447f7..1dce901df 100644 --- a/ldt/metforcing/3B42V6/finalize_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/finalize_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/get_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/get_TRMM3B42V6.F90 index 12231c5c9..d1b7d6e8e 100644 --- a/ldt/metforcing/3B42V6/get_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/get_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/interp_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/interp_TRMM3B42V6.F90 index 600063112..ff30bf0c0 100644 --- a/ldt/metforcing/3B42V6/interp_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/interp_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/read_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/read_TRMM3B42V6.F90 index 978830ba4..12450e59d 100644 --- a/ldt/metforcing/3B42V6/read_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/read_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 index 23c4e5c66..3cfdec577 100644 --- a/ldt/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 b/ldt/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 index 2364d94ed..d29500dd4 100644 --- a/ldt/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 +++ b/ldt/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 b/ldt/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 index b09d21e51..0ab81cc85 100644 --- a/ldt/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 +++ b/ldt/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/finalize_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/finalize_TRMM3B42V7.F90 index d0aba143f..77e6bab50 100644 --- a/ldt/metforcing/3B42V7/finalize_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/finalize_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/get_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/get_TRMM3B42V7.F90 index f5462c1fb..8c18f9172 100644 --- a/ldt/metforcing/3B42V7/get_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/get_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/interp_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/interp_TRMM3B42V7.F90 index ce8c65d83..ae469dece 100644 --- a/ldt/metforcing/3B42V7/interp_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/interp_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/read_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/read_TRMM3B42V7.F90 index b729e488e..91d525389 100644 --- a/ldt/metforcing/3B42V7/read_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/read_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 index 19764b753..185a07cb7 100644 --- a/ldt/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 b/ldt/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 index cc6256210..6812f0105 100644 --- a/ldt/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 +++ b/ldt/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 b/ldt/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 index 62899212e..e40901a1a 100644 --- a/ldt/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 +++ b/ldt/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/finalize_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/finalize_RFE2Daily.F90 index 361bfb33b..43b16c1aa 100644 --- a/ldt/metforcing/RFE2Daily/finalize_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/finalize_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/get_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/get_RFE2Daily.F90 index 0739a67f4..a11b83cbc 100644 --- a/ldt/metforcing/RFE2Daily/get_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/get_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 index db738b789..b1422178f 100644 --- a/ldt/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 index 8f4fa95d6..fb2c99110 100644 --- a/ldt/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/reproject_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/reproject_RFE2Daily.F90 index 9d5081a3e..c3bd06581 100644 --- a/ldt/metforcing/RFE2Daily/reproject_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/reproject_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/reset_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/reset_RFE2Daily.F90 index 589013fd9..2f927534f 100644 --- a/ldt/metforcing/RFE2Daily/reset_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/reset_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 b/ldt/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 index 407759f03..252bbca72 100644 --- a/ldt/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 +++ b/ldt/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 b/ldt/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 index 978804f52..65854ca25 100644 --- a/ldt/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 +++ b/ldt/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/finalize_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/finalize_RFE2gdas.F90 index 8a52f8b9a..155a48483 100644 --- a/ldt/metforcing/RFE2gdas/finalize_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/finalize_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/get_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/get_RFE2gdas.F90 index 06f07a53d..085b5eb23 100644 --- a/ldt/metforcing/RFE2gdas/get_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/get_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/readRFE2gdascrd.F90 b/ldt/metforcing/RFE2gdas/readRFE2gdascrd.F90 index da075b02b..c1318739b 100644 --- a/ldt/metforcing/RFE2gdas/readRFE2gdascrd.F90 +++ b/ldt/metforcing/RFE2gdas/readRFE2gdascrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 index e72f79f44..912c7d265 100644 --- a/ldt/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/reproject_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/reproject_RFE2gdas.F90 index 5b65f384e..efb6b45fb 100644 --- a/ldt/metforcing/RFE2gdas/reproject_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/reproject_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/reset_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/reset_RFE2gdas.F90 index f37ed49a6..29ccab33d 100644 --- a/ldt/metforcing/RFE2gdas/reset_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/reset_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 b/ldt/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 index 47bc11eb5..335e117d2 100644 --- a/ldt/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 +++ b/ldt/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 b/ldt/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 index 8d7c2701e..deb24d5f6 100644 --- a/ldt/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 +++ b/ldt/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFAKdom/read_WRFAK_elev.F90 b/ldt/metforcing/WRFAKdom/read_WRFAK_elev.F90 index 1b8260c92..dbc4cb32c 100644 --- a/ldt/metforcing/WRFAKdom/read_WRFAK_elev.F90 +++ b/ldt/metforcing/WRFAKdom/read_WRFAK_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 b/ldt/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 index b4ebf77be..c3e397330 100644 --- a/ldt/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 +++ b/ldt/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 b/ldt/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 index 6d5a9bf80..1cf4b5de3 100644 --- a/ldt/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 +++ b/ldt/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 b/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 index 48381060b..418e8544e 100644 --- a/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 +++ b/ldt/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 b/ldt/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 index 7bc43b2b8..ac1f4d3d9 100644 --- a/ldt/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 +++ b/ldt/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/agrradps/agrradps_forcingMod.F90 b/ldt/metforcing/agrradps/agrradps_forcingMod.F90 index d82c15b11..13cccd971 100644 --- a/ldt/metforcing/agrradps/agrradps_forcingMod.F90 +++ b/ldt/metforcing/agrradps/agrradps_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/chirps2_forcingMod.F90 b/ldt/metforcing/chirps2/chirps2_forcingMod.F90 index 97447bbf2..941ce05a6 100644 --- a/ldt/metforcing/chirps2/chirps2_forcingMod.F90 +++ b/ldt/metforcing/chirps2/chirps2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/finalize_chirps2.F90 b/ldt/metforcing/chirps2/finalize_chirps2.F90 index 08d9ec38d..96c20b452 100644 --- a/ldt/metforcing/chirps2/finalize_chirps2.F90 +++ b/ldt/metforcing/chirps2/finalize_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/get_chirps2.F90 b/ldt/metforcing/chirps2/get_chirps2.F90 index 0343f36ff..b5a474c42 100644 --- a/ldt/metforcing/chirps2/get_chirps2.F90 +++ b/ldt/metforcing/chirps2/get_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/read_chirps2.F90 b/ldt/metforcing/chirps2/read_chirps2.F90 index 7cfa2af4f..0d8211856 100644 --- a/ldt/metforcing/chirps2/read_chirps2.F90 +++ b/ldt/metforcing/chirps2/read_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/readconfig_chirps2.F90 b/ldt/metforcing/chirps2/readconfig_chirps2.F90 index 0103603f3..a540c9f62 100644 --- a/ldt/metforcing/chirps2/readconfig_chirps2.F90 +++ b/ldt/metforcing/chirps2/readconfig_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/reset_chirps2.F90 b/ldt/metforcing/chirps2/reset_chirps2.F90 index 17eda36f3..7c1256ff1 100644 --- a/ldt/metforcing/chirps2/reset_chirps2.F90 +++ b/ldt/metforcing/chirps2/reset_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/chirps2/timeinterp_chirps2.F90 b/ldt/metforcing/chirps2/timeinterp_chirps2.F90 index d8d10096e..6bf94bf68 100644 --- a/ldt/metforcing/chirps2/timeinterp_chirps2.F90 +++ b/ldt/metforcing/chirps2/timeinterp_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/cmap_forcingMod.F90 b/ldt/metforcing/cmap/cmap_forcingMod.F90 index d9aee667e..dd74bdfa3 100644 --- a/ldt/metforcing/cmap/cmap_forcingMod.F90 +++ b/ldt/metforcing/cmap/cmap_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/finalize_cmap.F90 b/ldt/metforcing/cmap/finalize_cmap.F90 index 1aaa6055c..d4a27a4e0 100644 --- a/ldt/metforcing/cmap/finalize_cmap.F90 +++ b/ldt/metforcing/cmap/finalize_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/get_cmap.F90 b/ldt/metforcing/cmap/get_cmap.F90 index a49668230..41ccfcf73 100644 --- a/ldt/metforcing/cmap/get_cmap.F90 +++ b/ldt/metforcing/cmap/get_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/interp_cmap.F90 b/ldt/metforcing/cmap/interp_cmap.F90 index 69a0e0fbe..fd941a268 100644 --- a/ldt/metforcing/cmap/interp_cmap.F90 +++ b/ldt/metforcing/cmap/interp_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/read_cmap.F90 b/ldt/metforcing/cmap/read_cmap.F90 index 3d622f00b..b433471f0 100644 --- a/ldt/metforcing/cmap/read_cmap.F90 +++ b/ldt/metforcing/cmap/read_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/readcrd_cmap.F90 b/ldt/metforcing/cmap/readcrd_cmap.F90 index c1f1df6ef..65175e539 100644 --- a/ldt/metforcing/cmap/readcrd_cmap.F90 +++ b/ldt/metforcing/cmap/readcrd_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/reset_cmap.F90 b/ldt/metforcing/cmap/reset_cmap.F90 index 8135d6f12..3c39993c1 100644 --- a/ldt/metforcing/cmap/reset_cmap.F90 +++ b/ldt/metforcing/cmap/reset_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmap/timeinterp_cmap.F90 b/ldt/metforcing/cmap/timeinterp_cmap.F90 index 912c01ed5..ec6a7488b 100644 --- a/ldt/metforcing/cmap/timeinterp_cmap.F90 +++ b/ldt/metforcing/cmap/timeinterp_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/cm_readzipf.c b/ldt/metforcing/cmorph/cm_readzipf.c index 78e48f9b7..4bdf9a6c9 100644 --- a/ldt/metforcing/cmorph/cm_readzipf.c +++ b/ldt/metforcing/cmorph/cm_readzipf.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/cmorph_forcingMod.F90 b/ldt/metforcing/cmorph/cmorph_forcingMod.F90 index e8a8830d7..13342a5a1 100644 --- a/ldt/metforcing/cmorph/cmorph_forcingMod.F90 +++ b/ldt/metforcing/cmorph/cmorph_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/finalize_cmorph.F90 b/ldt/metforcing/cmorph/finalize_cmorph.F90 index 4ea5f3b2e..3871e42cc 100644 --- a/ldt/metforcing/cmorph/finalize_cmorph.F90 +++ b/ldt/metforcing/cmorph/finalize_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/get_cmorph.F90 b/ldt/metforcing/cmorph/get_cmorph.F90 index 9a3e44b1b..dd68721fa 100644 --- a/ldt/metforcing/cmorph/get_cmorph.F90 +++ b/ldt/metforcing/cmorph/get_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/interp_cmorph.F90 b/ldt/metforcing/cmorph/interp_cmorph.F90 index 3e377dd74..286f4b36c 100644 --- a/ldt/metforcing/cmorph/interp_cmorph.F90 +++ b/ldt/metforcing/cmorph/interp_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/read_cmorph.F90 b/ldt/metforcing/cmorph/read_cmorph.F90 index d44efe1e3..09df1d763 100644 --- a/ldt/metforcing/cmorph/read_cmorph.F90 +++ b/ldt/metforcing/cmorph/read_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/readcrd_cmorph.F90 b/ldt/metforcing/cmorph/readcrd_cmorph.F90 index c7d2f81e2..e61411117 100644 --- a/ldt/metforcing/cmorph/readcrd_cmorph.F90 +++ b/ldt/metforcing/cmorph/readcrd_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/cmorph/timeinterp_cmorph.F90 b/ldt/metforcing/cmorph/timeinterp_cmorph.F90 index 1604d757e..4478cda21 100644 --- a/ldt/metforcing/cmorph/timeinterp_cmorph.F90 +++ b/ldt/metforcing/cmorph/timeinterp_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/ecmwf_forcingMod.F90 b/ldt/metforcing/ecmwf/ecmwf_forcingMod.F90 index 7cfd95a11..d70bd507e 100644 --- a/ldt/metforcing/ecmwf/ecmwf_forcingMod.F90 +++ b/ldt/metforcing/ecmwf/ecmwf_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/finalize_ecmwf.F90 b/ldt/metforcing/ecmwf/finalize_ecmwf.F90 index 4f5fd87b0..c5d8e6c73 100644 --- a/ldt/metforcing/ecmwf/finalize_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/finalize_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/get_ecmwf.F90 b/ldt/metforcing/ecmwf/get_ecmwf.F90 index 2f6875b25..af5465afd 100644 --- a/ldt/metforcing/ecmwf/get_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/get_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/read_ecmwf.F90 b/ldt/metforcing/ecmwf/read_ecmwf.F90 index a387f33cc..d42f4f5cf 100644 --- a/ldt/metforcing/ecmwf/read_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/read_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/read_ecmwf_elev.F90 b/ldt/metforcing/ecmwf/read_ecmwf_elev.F90 index 4b1644a37..fa3edf926 100644 --- a/ldt/metforcing/ecmwf/read_ecmwf_elev.F90 +++ b/ldt/metforcing/ecmwf/read_ecmwf_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/read_ecmwfelev_ldtproc.F90 b/ldt/metforcing/ecmwf/read_ecmwfelev_ldtproc.F90 index 8ef0629ba..f06827ff6 100644 --- a/ldt/metforcing/ecmwf/read_ecmwfelev_ldtproc.F90 +++ b/ldt/metforcing/ecmwf/read_ecmwfelev_ldtproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/readcrd_ecmwf.F90 b/ldt/metforcing/ecmwf/readcrd_ecmwf.F90 index 890d156c0..0a33bae14 100644 --- a/ldt/metforcing/ecmwf/readcrd_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/readcrd_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/reset_ecmwf.F90 b/ldt/metforcing/ecmwf/reset_ecmwf.F90 index ce2aab8db..b4c559217 100644 --- a/ldt/metforcing/ecmwf/reset_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/reset_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/ecmwf/timeinterp_ecmwf.F90 b/ldt/metforcing/ecmwf/timeinterp_ecmwf.F90 index b353fadd1..040094365 100644 --- a/ldt/metforcing/ecmwf/timeinterp_ecmwf.F90 +++ b/ldt/metforcing/ecmwf/timeinterp_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/era5_forcingMod.F90 b/ldt/metforcing/era5/era5_forcingMod.F90 index cffb93bb9..8a595a7b8 100644 --- a/ldt/metforcing/era5/era5_forcingMod.F90 +++ b/ldt/metforcing/era5/era5_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/finalize_era5.F90 b/ldt/metforcing/era5/finalize_era5.F90 index 112f7e56c..2ea0fb33d 100644 --- a/ldt/metforcing/era5/finalize_era5.F90 +++ b/ldt/metforcing/era5/finalize_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/get_era5.F90 b/ldt/metforcing/era5/get_era5.F90 index 52b22aa6b..ef125d43c 100644 --- a/ldt/metforcing/era5/get_era5.F90 +++ b/ldt/metforcing/era5/get_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/read_era5.F90 b/ldt/metforcing/era5/read_era5.F90 index 52550422b..0f818acc2 100644 --- a/ldt/metforcing/era5/read_era5.F90 +++ b/ldt/metforcing/era5/read_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/read_era5_elev.F90 b/ldt/metforcing/era5/read_era5_elev.F90 index 8f5360729..de0f874d8 100644 --- a/ldt/metforcing/era5/read_era5_elev.F90 +++ b/ldt/metforcing/era5/read_era5_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/readcrd_era5.F90 b/ldt/metforcing/era5/readcrd_era5.F90 index eb2516ce9..0715fdc25 100644 --- a/ldt/metforcing/era5/readcrd_era5.F90 +++ b/ldt/metforcing/era5/readcrd_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/reset_era5.F90 b/ldt/metforcing/era5/reset_era5.F90 index 0cf11163c..786fe9899 100644 --- a/ldt/metforcing/era5/reset_era5.F90 +++ b/ldt/metforcing/era5/reset_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/era5/timeinterp_era5.F90 b/ldt/metforcing/era5/timeinterp_era5.F90 index afb46f839..89b5de718 100644 --- a/ldt/metforcing/era5/timeinterp_era5.F90 +++ b/ldt/metforcing/era5/timeinterp_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/create_gdasf9_filename.F90 b/ldt/metforcing/gdas/create_gdasf9_filename.F90 index 88a50f6ed..948610bc0 100644 --- a/ldt/metforcing/gdas/create_gdasf9_filename.F90 +++ b/ldt/metforcing/gdas/create_gdasf9_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/create_gdasfilename.F90 b/ldt/metforcing/gdas/create_gdasfilename.F90 index effa0d13c..d7f2ab7e2 100644 --- a/ldt/metforcing/gdas/create_gdasfilename.F90 +++ b/ldt/metforcing/gdas/create_gdasfilename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/finalize_gdas.F90 b/ldt/metforcing/gdas/finalize_gdas.F90 index e971652d5..388ddd5b9 100644 --- a/ldt/metforcing/gdas/finalize_gdas.F90 +++ b/ldt/metforcing/gdas/finalize_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/gdas_forcingMod.F90 b/ldt/metforcing/gdas/gdas_forcingMod.F90 index 9640f0a11..773982dc0 100644 --- a/ldt/metforcing/gdas/gdas_forcingMod.F90 +++ b/ldt/metforcing/gdas/gdas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/get_gdas.F90 b/ldt/metforcing/gdas/get_gdas.F90 index c19a904f6..59e1aff55 100644 --- a/ldt/metforcing/gdas/get_gdas.F90 +++ b/ldt/metforcing/gdas/get_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/read_gdas.F90 b/ldt/metforcing/gdas/read_gdas.F90 index bcd6b4828..a37c9dd33 100644 --- a/ldt/metforcing/gdas/read_gdas.F90 +++ b/ldt/metforcing/gdas/read_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/read_gdas_elev.F90 b/ldt/metforcing/gdas/read_gdas_elev.F90 index e890bcdec..d06a0bc0c 100644 --- a/ldt/metforcing/gdas/read_gdas_elev.F90 +++ b/ldt/metforcing/gdas/read_gdas_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/read_gdaselev_ldtproc.F90 b/ldt/metforcing/gdas/read_gdaselev_ldtproc.F90 index 02c7df635..0f33b0cc7 100644 --- a/ldt/metforcing/gdas/read_gdaselev_ldtproc.F90 +++ b/ldt/metforcing/gdas/read_gdaselev_ldtproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/readcrd_gdas.F90 b/ldt/metforcing/gdas/readcrd_gdas.F90 index 6ceab4551..506647134 100644 --- a/ldt/metforcing/gdas/readcrd_gdas.F90 +++ b/ldt/metforcing/gdas/readcrd_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/reset_gdas.F90 b/ldt/metforcing/gdas/reset_gdas.F90 index f2bf3142c..33e498781 100644 --- a/ldt/metforcing/gdas/reset_gdas.F90 +++ b/ldt/metforcing/gdas/reset_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gdas/timeinterp_gdas.F90 b/ldt/metforcing/gdas/timeinterp_gdas.F90 index f38cd560d..11f3f53ce 100644 --- a/ldt/metforcing/gdas/timeinterp_gdas.F90 +++ b/ldt/metforcing/gdas/timeinterp_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/finalize_geos5fcst.F90 b/ldt/metforcing/geos5fcst/finalize_geos5fcst.F90 index 0164a8b0f..7d73cda30 100644 --- a/ldt/metforcing/geos5fcst/finalize_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/finalize_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/geos5fcst_forcingMod.F90 b/ldt/metforcing/geos5fcst/geos5fcst_forcingMod.F90 index f4a024cb1..44f433f62 100644 --- a/ldt/metforcing/geos5fcst/geos5fcst_forcingMod.F90 +++ b/ldt/metforcing/geos5fcst/geos5fcst_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/get_geos5fcst.F90 b/ldt/metforcing/geos5fcst/get_geos5fcst.F90 index 57b37ed2f..05c9e65f5 100644 --- a/ldt/metforcing/geos5fcst/get_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/get_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/interp_geos5fcst.F90 b/ldt/metforcing/geos5fcst/interp_geos5fcst.F90 index 9c7d785f0..c84771474 100644 --- a/ldt/metforcing/geos5fcst/interp_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/interp_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/read_geos5fcst.F90 b/ldt/metforcing/geos5fcst/read_geos5fcst.F90 index 4619f963f..fd14e3d9b 100644 --- a/ldt/metforcing/geos5fcst/read_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/read_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/readcrd_geos5fcst.F90 b/ldt/metforcing/geos5fcst/readcrd_geos5fcst.F90 index 92262a39d..9f794274c 100644 --- a/ldt/metforcing/geos5fcst/readcrd_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/readcrd_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/reset_geos5fcst.F90 b/ldt/metforcing/geos5fcst/reset_geos5fcst.F90 index 6f3df0fd1..9ff216016 100644 --- a/ldt/metforcing/geos5fcst/reset_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/reset_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/geos5fcst/timeinterp_geos5fcst.F90 b/ldt/metforcing/geos5fcst/timeinterp_geos5fcst.F90 index b09b5e678..af169b7a2 100644 --- a/ldt/metforcing/geos5fcst/timeinterp_geos5fcst.F90 +++ b/ldt/metforcing/geos5fcst/timeinterp_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/create_gfs_f0backup_filename.F90 b/ldt/metforcing/gfs/create_gfs_f0backup_filename.F90 index 051e945c9..36dbe7688 100644 --- a/ldt/metforcing/gfs/create_gfs_f0backup_filename.F90 +++ b/ldt/metforcing/gfs/create_gfs_f0backup_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/create_gfsfilename.F90 b/ldt/metforcing/gfs/create_gfsfilename.F90 index e5992de53..f03d75661 100644 --- a/ldt/metforcing/gfs/create_gfsfilename.F90 +++ b/ldt/metforcing/gfs/create_gfsfilename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/finalize_gfs.F90 b/ldt/metforcing/gfs/finalize_gfs.F90 index abe9e1ac2..f1ef142c4 100644 --- a/ldt/metforcing/gfs/finalize_gfs.F90 +++ b/ldt/metforcing/gfs/finalize_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/get_gfs.F90 b/ldt/metforcing/gfs/get_gfs.F90 index 2697d7a04..054e67def 100644 --- a/ldt/metforcing/gfs/get_gfs.F90 +++ b/ldt/metforcing/gfs/get_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/gfs_forcingMod.F90 b/ldt/metforcing/gfs/gfs_forcingMod.F90 index b0309e353..a8060bfc9 100644 --- a/ldt/metforcing/gfs/gfs_forcingMod.F90 +++ b/ldt/metforcing/gfs/gfs_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/read_gfs.F90 b/ldt/metforcing/gfs/read_gfs.F90 index 658edc32f..1d6d7d610 100644 --- a/ldt/metforcing/gfs/read_gfs.F90 +++ b/ldt/metforcing/gfs/read_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/read_gfs_elev.F90 b/ldt/metforcing/gfs/read_gfs_elev.F90 index b6f260557..985ff2af6 100644 --- a/ldt/metforcing/gfs/read_gfs_elev.F90 +++ b/ldt/metforcing/gfs/read_gfs_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/readcrd_gfs.F90 b/ldt/metforcing/gfs/readcrd_gfs.F90 index 5da67c631..7298e342d 100644 --- a/ldt/metforcing/gfs/readcrd_gfs.F90 +++ b/ldt/metforcing/gfs/readcrd_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gfs/timeinterp_gfs.F90 b/ldt/metforcing/gfs/timeinterp_gfs.F90 index 40201ab75..8da42813b 100644 --- a/ldt/metforcing/gfs/timeinterp_gfs.F90 +++ b/ldt/metforcing/gfs/timeinterp_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gldas/gldas_forcingMod.F90 b/ldt/metforcing/gldas/gldas_forcingMod.F90 index 07ee74d3a..3b99d7f7a 100644 --- a/ldt/metforcing/gldas/gldas_forcingMod.F90 +++ b/ldt/metforcing/gldas/gldas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gswp1/gswp1_forcingMod.F90 b/ldt/metforcing/gswp1/gswp1_forcingMod.F90 index be9b15c57..dbc95168b 100644 --- a/ldt/metforcing/gswp1/gswp1_forcingMod.F90 +++ b/ldt/metforcing/gswp1/gswp1_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/gswp2/gswp2_forcingMod.F90 b/ldt/metforcing/gswp2/gswp2_forcingMod.F90 index d07f5bcf3..50ec837e7 100644 --- a/ldt/metforcing/gswp2/gswp2_forcingMod.F90 +++ b/ldt/metforcing/gswp2/gswp2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/finalize_merra2.F90 b/ldt/metforcing/merra2/finalize_merra2.F90 index a610ca771..7e8dd7429 100644 --- a/ldt/metforcing/merra2/finalize_merra2.F90 +++ b/ldt/metforcing/merra2/finalize_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/get_merra2.F90 b/ldt/metforcing/merra2/get_merra2.F90 index fb6ed64b1..8af0cd198 100644 --- a/ldt/metforcing/merra2/get_merra2.F90 +++ b/ldt/metforcing/merra2/get_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/merra2_forcingMod.F90 b/ldt/metforcing/merra2/merra2_forcingMod.F90 index 423d87043..960377c99 100644 --- a/ldt/metforcing/merra2/merra2_forcingMod.F90 +++ b/ldt/metforcing/merra2/merra2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/read_merra2.F90 b/ldt/metforcing/merra2/read_merra2.F90 index c73087c4d..d6ae1b339 100644 --- a/ldt/metforcing/merra2/read_merra2.F90 +++ b/ldt/metforcing/merra2/read_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/read_merra2_elev.F90 b/ldt/metforcing/merra2/read_merra2_elev.F90 index 8ecd696ff..d1564d046 100644 --- a/ldt/metforcing/merra2/read_merra2_elev.F90 +++ b/ldt/metforcing/merra2/read_merra2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/readcrd_merra2.F90 b/ldt/metforcing/merra2/readcrd_merra2.F90 index d72bb6012..373f8a6ad 100644 --- a/ldt/metforcing/merra2/readcrd_merra2.F90 +++ b/ldt/metforcing/merra2/readcrd_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/reset_merra2.F90 b/ldt/metforcing/merra2/reset_merra2.F90 index 10c0189cd..bfd4d60e9 100644 --- a/ldt/metforcing/merra2/reset_merra2.F90 +++ b/ldt/metforcing/merra2/reset_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/merra2/timeinterp_merra2.F90 b/ldt/metforcing/merra2/timeinterp_merra2.F90 index 22c483379..f1e592d2b 100644 --- a/ldt/metforcing/merra2/timeinterp_merra2.F90 +++ b/ldt/metforcing/merra2/timeinterp_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/create_nam242f9_filename.F90 b/ldt/metforcing/nam242/create_nam242f9_filename.F90 index ea7607b23..72039198f 100644 --- a/ldt/metforcing/nam242/create_nam242f9_filename.F90 +++ b/ldt/metforcing/nam242/create_nam242f9_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/create_nam242filename.F90 b/ldt/metforcing/nam242/create_nam242filename.F90 index 010933e3e..9cf8119f6 100644 --- a/ldt/metforcing/nam242/create_nam242filename.F90 +++ b/ldt/metforcing/nam242/create_nam242filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/finalize_nam242.F90 b/ldt/metforcing/nam242/finalize_nam242.F90 index 92dd2b6da..d4a5106f3 100644 --- a/ldt/metforcing/nam242/finalize_nam242.F90 +++ b/ldt/metforcing/nam242/finalize_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/get_nam242.F90 b/ldt/metforcing/nam242/get_nam242.F90 index 57e23a265..3dbabdd97 100644 --- a/ldt/metforcing/nam242/get_nam242.F90 +++ b/ldt/metforcing/nam242/get_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/nam242_forcingMod.F90 b/ldt/metforcing/nam242/nam242_forcingMod.F90 index a59ac8b41..fde12eb35 100644 --- a/ldt/metforcing/nam242/nam242_forcingMod.F90 +++ b/ldt/metforcing/nam242/nam242_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/read_nam242.F90 b/ldt/metforcing/nam242/read_nam242.F90 index 7ea03621f..dca64b40f 100644 --- a/ldt/metforcing/nam242/read_nam242.F90 +++ b/ldt/metforcing/nam242/read_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/read_nam242_elev.F90 b/ldt/metforcing/nam242/read_nam242_elev.F90 index dec2c7acf..5dd2734bc 100644 --- a/ldt/metforcing/nam242/read_nam242_elev.F90 +++ b/ldt/metforcing/nam242/read_nam242_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/readcrd_nam242.F90 b/ldt/metforcing/nam242/readcrd_nam242.F90 index 0491da066..fa5c5b094 100644 --- a/ldt/metforcing/nam242/readcrd_nam242.F90 +++ b/ldt/metforcing/nam242/readcrd_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/reset_nam242.F90 b/ldt/metforcing/nam242/reset_nam242.F90 index 63f16b5c6..c9bc5894f 100644 --- a/ldt/metforcing/nam242/reset_nam242.F90 +++ b/ldt/metforcing/nam242/reset_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nam242/timeinterp_nam242.F90 b/ldt/metforcing/nam242/timeinterp_nam242.F90 index f357a8f49..072e1f181 100644 --- a/ldt/metforcing/nam242/timeinterp_nam242.F90 +++ b/ldt/metforcing/nam242/timeinterp_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/narr/narr_forcingMod.F90 b/ldt/metforcing/narr/narr_forcingMod.F90 index 0f516233a..d067d3400 100644 --- a/ldt/metforcing/narr/narr_forcingMod.F90 +++ b/ldt/metforcing/narr/narr_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/finalize_nldas2.F90 b/ldt/metforcing/nldas2/finalize_nldas2.F90 index eda514e73..8a3cb4897 100644 --- a/ldt/metforcing/nldas2/finalize_nldas2.F90 +++ b/ldt/metforcing/nldas2/finalize_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/get_gesdisc_filenames.F90 b/ldt/metforcing/nldas2/get_gesdisc_filenames.F90 index eaebb1ed3..7b4c91c84 100755 --- a/ldt/metforcing/nldas2/get_gesdisc_filenames.F90 +++ b/ldt/metforcing/nldas2/get_gesdisc_filenames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/get_ncep_filenames.F90 b/ldt/metforcing/nldas2/get_ncep_filenames.F90 index aa1419003..25380206c 100755 --- a/ldt/metforcing/nldas2/get_ncep_filenames.F90 +++ b/ldt/metforcing/nldas2/get_ncep_filenames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/get_nldas2.F90 b/ldt/metforcing/nldas2/get_nldas2.F90 index e2048c492..5fa0b1f7f 100644 --- a/ldt/metforcing/nldas2/get_nldas2.F90 +++ b/ldt/metforcing/nldas2/get_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/nldas2_ec_removal.F90 b/ldt/metforcing/nldas2/nldas2_ec_removal.F90 index 370b1e83c..6cddffce8 100644 --- a/ldt/metforcing/nldas2/nldas2_ec_removal.F90 +++ b/ldt/metforcing/nldas2/nldas2_ec_removal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/nldas2_forcingMod.F90 b/ldt/metforcing/nldas2/nldas2_forcingMod.F90 index 9e5477267..566b4fdd5 100644 --- a/ldt/metforcing/nldas2/nldas2_forcingMod.F90 +++ b/ldt/metforcing/nldas2/nldas2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/read_nldas2_elev.F90 b/ldt/metforcing/nldas2/read_nldas2_elev.F90 index ca935350b..24d19f854 100644 --- a/ldt/metforcing/nldas2/read_nldas2_elev.F90 +++ b/ldt/metforcing/nldas2/read_nldas2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/read_nldas2a.F90 b/ldt/metforcing/nldas2/read_nldas2a.F90 index 14cc7e8f5..8d269a1d6 100644 --- a/ldt/metforcing/nldas2/read_nldas2a.F90 +++ b/ldt/metforcing/nldas2/read_nldas2a.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/read_nldas2b.F90 b/ldt/metforcing/nldas2/read_nldas2b.F90 index c0743c826..0d4847c82 100644 --- a/ldt/metforcing/nldas2/read_nldas2b.F90 +++ b/ldt/metforcing/nldas2/read_nldas2b.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/readcrd_nldas2.F90 b/ldt/metforcing/nldas2/readcrd_nldas2.F90 index 61f800af3..00c27d1d9 100644 --- a/ldt/metforcing/nldas2/readcrd_nldas2.F90 +++ b/ldt/metforcing/nldas2/readcrd_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/reset_nldas2.F90 b/ldt/metforcing/nldas2/reset_nldas2.F90 index 543c8734e..3d2589bd2 100644 --- a/ldt/metforcing/nldas2/reset_nldas2.F90 +++ b/ldt/metforcing/nldas2/reset_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/nldas2/timeinterp_nldas2.F90 b/ldt/metforcing/nldas2/timeinterp_nldas2.F90 index 6d5b3933d..fdb90cbd9 100644 --- a/ldt/metforcing/nldas2/timeinterp_nldas2.F90 +++ b/ldt/metforcing/nldas2/timeinterp_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/finalize_princeton.F90 b/ldt/metforcing/princeton/finalize_princeton.F90 index 9543ff2c8..66a89b0ad 100644 --- a/ldt/metforcing/princeton/finalize_princeton.F90 +++ b/ldt/metforcing/princeton/finalize_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/get_princeton.F90 b/ldt/metforcing/princeton/get_princeton.F90 index 5233c0447..a5161ba36 100644 --- a/ldt/metforcing/princeton/get_princeton.F90 +++ b/ldt/metforcing/princeton/get_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/princeton_forcingMod.F90 b/ldt/metforcing/princeton/princeton_forcingMod.F90 index d5d6e0b23..d422aee84 100644 --- a/ldt/metforcing/princeton/princeton_forcingMod.F90 +++ b/ldt/metforcing/princeton/princeton_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/read_princeton.F90 b/ldt/metforcing/princeton/read_princeton.F90 index dd1c95bfc..d770d6ff7 100644 --- a/ldt/metforcing/princeton/read_princeton.F90 +++ b/ldt/metforcing/princeton/read_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/read_princeton_elev.F90 b/ldt/metforcing/princeton/read_princeton_elev.F90 index dd93595e4..90c70fc91 100644 --- a/ldt/metforcing/princeton/read_princeton_elev.F90 +++ b/ldt/metforcing/princeton/read_princeton_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/readcrd_princeton.F90 b/ldt/metforcing/princeton/readcrd_princeton.F90 index 4297d0a4b..0aae63622 100644 --- a/ldt/metforcing/princeton/readcrd_princeton.F90 +++ b/ldt/metforcing/princeton/readcrd_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/reset_princeton.F90 b/ldt/metforcing/princeton/reset_princeton.F90 index d6fbd9ed2..ded57bfcd 100644 --- a/ldt/metforcing/princeton/reset_princeton.F90 +++ b/ldt/metforcing/princeton/reset_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/princeton/timeinterp_princeton.F90 b/ldt/metforcing/princeton/timeinterp_princeton.F90 index b82592b7a..a7efe37b6 100644 --- a/ldt/metforcing/princeton/timeinterp_princeton.F90 +++ b/ldt/metforcing/princeton/timeinterp_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/finalize_stg2.F90 b/ldt/metforcing/stg2/finalize_stg2.F90 index 9b7586c4a..119bed4ba 100644 --- a/ldt/metforcing/stg2/finalize_stg2.F90 +++ b/ldt/metforcing/stg2/finalize_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/get_stg2.F90 b/ldt/metforcing/stg2/get_stg2.F90 index 5225cdc32..f41c4bc85 100644 --- a/ldt/metforcing/stg2/get_stg2.F90 +++ b/ldt/metforcing/stg2/get_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/interp_stg2.F90 b/ldt/metforcing/stg2/interp_stg2.F90 index c982abeec..f11115433 100644 --- a/ldt/metforcing/stg2/interp_stg2.F90 +++ b/ldt/metforcing/stg2/interp_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/read_stg2.F90 b/ldt/metforcing/stg2/read_stg2.F90 index fc5b1eb09..1b6d06abf 100644 --- a/ldt/metforcing/stg2/read_stg2.F90 +++ b/ldt/metforcing/stg2/read_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/readcrd_stg2.F90 b/ldt/metforcing/stg2/readcrd_stg2.F90 index f77da854a..f367c0a94 100644 --- a/ldt/metforcing/stg2/readcrd_stg2.F90 +++ b/ldt/metforcing/stg2/readcrd_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/stg2_forcingMod.F90 b/ldt/metforcing/stg2/stg2_forcingMod.F90 index efed8425b..c7ce14adf 100644 --- a/ldt/metforcing/stg2/stg2_forcingMod.F90 +++ b/ldt/metforcing/stg2/stg2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/stg2file.F90 b/ldt/metforcing/stg2/stg2file.F90 index c64ab8461..d9d1dc769 100644 --- a/ldt/metforcing/stg2/stg2file.F90 +++ b/ldt/metforcing/stg2/stg2file.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg2/timeinterp_stg2.F90 b/ldt/metforcing/stg2/timeinterp_stg2.F90 index 3d2763a41..391b74b09 100644 --- a/ldt/metforcing/stg2/timeinterp_stg2.F90 +++ b/ldt/metforcing/stg2/timeinterp_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/finalize_stg4.F90 b/ldt/metforcing/stg4/finalize_stg4.F90 index 8d94ce93c..762019227 100644 --- a/ldt/metforcing/stg4/finalize_stg4.F90 +++ b/ldt/metforcing/stg4/finalize_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/get_stg4.F90 b/ldt/metforcing/stg4/get_stg4.F90 index 93482820c..31c81292c 100644 --- a/ldt/metforcing/stg4/get_stg4.F90 +++ b/ldt/metforcing/stg4/get_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/interp_stg4.F90 b/ldt/metforcing/stg4/interp_stg4.F90 index 0109b8c3f..f68401f78 100644 --- a/ldt/metforcing/stg4/interp_stg4.F90 +++ b/ldt/metforcing/stg4/interp_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/read_stg4.F90 b/ldt/metforcing/stg4/read_stg4.F90 index ca8fa6879..b17d3456c 100644 --- a/ldt/metforcing/stg4/read_stg4.F90 +++ b/ldt/metforcing/stg4/read_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/readcrd_stg4.F90 b/ldt/metforcing/stg4/readcrd_stg4.F90 index ca239927c..707846b3f 100644 --- a/ldt/metforcing/stg4/readcrd_stg4.F90 +++ b/ldt/metforcing/stg4/readcrd_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/reset_stg4.F90 b/ldt/metforcing/stg4/reset_stg4.F90 index 77e62c7f5..eecd70332 100644 --- a/ldt/metforcing/stg4/reset_stg4.F90 +++ b/ldt/metforcing/stg4/reset_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/stg4_forcingMod.F90 b/ldt/metforcing/stg4/stg4_forcingMod.F90 index b112a6d99..69321a7c3 100644 --- a/ldt/metforcing/stg4/stg4_forcingMod.F90 +++ b/ldt/metforcing/stg4/stg4_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/stg4file.F90 b/ldt/metforcing/stg4/stg4file.F90 index b589a7c9f..32b1ca4ab 100644 --- a/ldt/metforcing/stg4/stg4file.F90 +++ b/ldt/metforcing/stg4/stg4file.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/metforcing/stg4/timeinterp_stg4.F90 b/ldt/metforcing/stg4/timeinterp_stg4.F90 index c471a7d25..119bd121a 100644 --- a/ldt/metforcing/stg4/timeinterp_stg4.F90 +++ b/ldt/metforcing/stg4/timeinterp_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/NatureRun/LISout/LISoutNatureRun_Mod.F90 b/ldt/obsSim/NatureRun/LISout/LISoutNatureRun_Mod.F90 index 75d5ea253..8b3df514a 100644 --- a/ldt/obsSim/NatureRun/LISout/LISoutNatureRun_Mod.F90 +++ b/ldt/obsSim/NatureRun/LISout/LISoutNatureRun_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/NatureRun/LISout/readLISoutNatureRun.F90 b/ldt/obsSim/NatureRun/LISout/readLISoutNatureRun.F90 index 207d7d6fe..42b2b6051 100644 --- a/ldt/obsSim/NatureRun/LISout/readLISoutNatureRun.F90 +++ b/ldt/obsSim/NatureRun/LISout/readLISoutNatureRun.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/AMSR2/AMSR2OSSEmask_Mod.F90 b/ldt/obsSim/OSSEmask/AMSR2/AMSR2OSSEmask_Mod.F90 index 011b7ec1d..28cefb9f3 100644 --- a/ldt/obsSim/OSSEmask/AMSR2/AMSR2OSSEmask_Mod.F90 +++ b/ldt/obsSim/OSSEmask/AMSR2/AMSR2OSSEmask_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/AMSR2/readAMSR2OSSEmask.F90 b/ldt/obsSim/OSSEmask/AMSR2/readAMSR2OSSEmask.F90 index 5cc537b8d..6529ce857 100644 --- a/ldt/obsSim/OSSEmask/AMSR2/readAMSR2OSSEmask.F90 +++ b/ldt/obsSim/OSSEmask/AMSR2/readAMSR2OSSEmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/LISout/LISoutOSSEmask_Mod.F90 b/ldt/obsSim/OSSEmask/LISout/LISoutOSSEmask_Mod.F90 index c0d866d8a..b434a6c5e 100644 --- a/ldt/obsSim/OSSEmask/LISout/LISoutOSSEmask_Mod.F90 +++ b/ldt/obsSim/OSSEmask/LISout/LISoutOSSEmask_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/LISout/readLISoutOSSEmask.F90 b/ldt/obsSim/OSSEmask/LISout/readLISoutOSSEmask.F90 index 08f1acf9c..c29a2e5f7 100644 --- a/ldt/obsSim/OSSEmask/LISout/readLISoutOSSEmask.F90 +++ b/ldt/obsSim/OSSEmask/LISout/readLISoutOSSEmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/MODIS/MODISOSSEmask_Mod.F90 b/ldt/obsSim/OSSEmask/MODIS/MODISOSSEmask_Mod.F90 index fed3a98fe..d402abdab 100644 --- a/ldt/obsSim/OSSEmask/MODIS/MODISOSSEmask_Mod.F90 +++ b/ldt/obsSim/OSSEmask/MODIS/MODISOSSEmask_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/MODIS/readMODISOSSEmask.F90 b/ldt/obsSim/OSSEmask/MODIS/readMODISOSSEmask.F90 index ddbd1f99f..1de2a643c 100644 --- a/ldt/obsSim/OSSEmask/MODIS/readMODISOSSEmask.F90 +++ b/ldt/obsSim/OSSEmask/MODIS/readMODISOSSEmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/Sentinel1A/Sentinel1AOSSEmask_Mod.F90 b/ldt/obsSim/OSSEmask/Sentinel1A/Sentinel1AOSSEmask_Mod.F90 index a0bc20c4f..f10e55148 100644 --- a/ldt/obsSim/OSSEmask/Sentinel1A/Sentinel1AOSSEmask_Mod.F90 +++ b/ldt/obsSim/OSSEmask/Sentinel1A/Sentinel1AOSSEmask_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/Sentinel1A/readSentinel1AOSSEmask.F90 b/ldt/obsSim/OSSEmask/Sentinel1A/readSentinel1AOSSEmask.F90 index 30465751f..c58ec0c0a 100644 --- a/ldt/obsSim/OSSEmask/Sentinel1A/readSentinel1AOSSEmask.F90 +++ b/ldt/obsSim/OSSEmask/Sentinel1A/readSentinel1AOSSEmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/TSMM/TSMMOSSEmask_Mod.F90 b/ldt/obsSim/OSSEmask/TSMM/TSMMOSSEmask_Mod.F90 index 620e54cee..ce4ad8136 100644 --- a/ldt/obsSim/OSSEmask/TSMM/TSMMOSSEmask_Mod.F90 +++ b/ldt/obsSim/OSSEmask/TSMM/TSMMOSSEmask_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/obsSim/OSSEmask/TSMM/readTSMMOSSEmask.F90 b/ldt/obsSim/OSSEmask/TSMM/readTSMMOSSEmask.F90 index d44f43d00..7fc126ab3 100644 --- a/ldt/obsSim/OSSEmask/TSMM/readTSMMOSSEmask.F90 +++ b/ldt/obsSim/OSSEmask/TSMM/readTSMMOSSEmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/CLM2/CLM2_parmsMod.F90 b/ldt/params/CLM2/CLM2_parmsMod.F90 index e6d58ab81..4bbf13148 100644 --- a/ldt/params/CLM2/CLM2_parmsMod.F90 +++ b/ldt/params/CLM2/CLM2_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/CLM45/CLM45_parmsMod.F90 b/ldt/params/CLM45/CLM45_parmsMod.F90 index 4c0873976..5d62cb996 100644 --- a/ldt/params/CLM45/CLM45_parmsMod.F90 +++ b/ldt/params/CLM45/CLM45_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/CLM45/read_netcdf_4d.F90 b/ldt/params/CLM45/read_netcdf_4d.F90 index b0ad9470e..5012bdeb2 100644 --- a/ldt/params/CLM45/read_netcdf_4d.F90 +++ b/ldt/params/CLM45/read_netcdf_4d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/Crocus_parmsMod.F90 b/ldt/params/Crocus/Crocus_parmsMod.F90 index b8825f7c9..e7e01141e 100755 --- a/ldt/params/Crocus/Crocus_parmsMod.F90 +++ b/ldt/params/Crocus/Crocus_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/read_CONSTANT_slopetype_cro.F90 b/ldt/params/Crocus/read_CONSTANT_slopetype_cro.F90 index 5f1573d6a..0dc554902 100755 --- a/ldt/params/Crocus/read_CONSTANT_slopetype_cro.F90 +++ b/ldt/params/Crocus/read_CONSTANT_slopetype_cro.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/read_CONSTANT_tbot_cro.F90 b/ldt/params/Crocus/read_CONSTANT_tbot_cro.F90 index 1b74f296c..3b68bc012 100755 --- a/ldt/params/Crocus/read_CONSTANT_tbot_cro.F90 +++ b/ldt/params/Crocus/read_CONSTANT_tbot_cro.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/read_ISLSCP1_cro_tbot.F90 b/ldt/params/Crocus/read_ISLSCP1_cro_tbot.F90 index 2cb5307fe..3a9466793 100755 --- a/ldt/params/Crocus/read_ISLSCP1_cro_tbot.F90 +++ b/ldt/params/Crocus/read_ISLSCP1_cro_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/read_NCEP_GFS_cro_tbot.F90 b/ldt/params/Crocus/read_NCEP_GFS_cro_tbot.F90 index 1c0c505b4..4476c6f3b 100755 --- a/ldt/params/Crocus/read_NCEP_GFS_cro_tbot.F90 +++ b/ldt/params/Crocus/read_NCEP_GFS_cro_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Crocus/read_NCEP_cro_tbot.F90 b/ldt/params/Crocus/read_NCEP_cro_tbot.F90 index e50096b48..bac5a6a27 100755 --- a/ldt/params/Crocus/read_NCEP_cro_tbot.F90 +++ b/ldt/params/Crocus/read_NCEP_cro_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/FLAKE/FLAKE_parmsMod.F90 b/ldt/params/FLAKE/FLAKE_parmsMod.F90 index d863a793d..b964f3a69 100644 --- a/ldt/params/FLAKE/FLAKE_parmsMod.F90 +++ b/ldt/params/FLAKE/FLAKE_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/FLAKE/read_GLWD_inlandwatertype.F90 b/ldt/params/FLAKE/read_GLWD_inlandwatertype.F90 index fd73bb615..f93b0f921 100644 --- a/ldt/params/FLAKE/read_GLWD_inlandwatertype.F90 +++ b/ldt/params/FLAKE/read_GLWD_inlandwatertype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/GeoWRSI_parmsMod.F90 b/ldt/params/GeoWRSI/GeoWRSI_parmsMod.F90 index 0b56bdc72..fc9403878 100644 --- a/ldt/params/GeoWRSI/GeoWRSI_parmsMod.F90 +++ b/ldt/params/GeoWRSI/GeoWRSI_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/geowrsi2_arraymgmt_module.F90 b/ldt/params/GeoWRSI/geowrsi2_arraymgmt_module.F90 index 8e4b1cf70..391c909d6 100644 --- a/ldt/params/GeoWRSI/geowrsi2_arraymgmt_module.F90 +++ b/ldt/params/GeoWRSI/geowrsi2_arraymgmt_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/geowrsi2_set_gcoords.F90 b/ldt/params/GeoWRSI/geowrsi2_set_gcoords.F90 index 035a0be30..e17a3df90 100644 --- a/ldt/params/GeoWRSI/geowrsi2_set_gcoords.F90 +++ b/ldt/params/GeoWRSI/geowrsi2_set_gcoords.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_landmask.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_landmask.F90 index 81dc663aa..d2b418fab 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_landmask.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_landmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_lgp.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_lgp.F90 index 0f154bbd9..d63a2e92d 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_lgp.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_lgp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_sos.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_sos.F90 index 618408f23..104e004ce 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_sos.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_sos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_sosanom.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_sosanom.F90 index 68e9e2c8f..18c021206 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_sosanom.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_sosanom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_sosclim.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_sosclim.F90 index ff3cf5f3b..99a50f65c 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_sosclim.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_sosclim.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_whc.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_whc.F90 index 60d99ae25..007be4806 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_whc.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_whc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/GeoWRSI/read_GeoWRSI2_wrsiclim.F90 b/ldt/params/GeoWRSI/read_GeoWRSI2_wrsiclim.F90 index 0be198075..6a3e03f60 100644 --- a/ldt/params/GeoWRSI/read_GeoWRSI2_wrsiclim.F90 +++ b/ldt/params/GeoWRSI/read_GeoWRSI2_wrsiclim.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/HYMAP_parmsMod.F90 b/ldt/params/HYMAP/HYMAP_parmsMod.F90 index 6a26c5fb8..3f707138b 100644 --- a/ldt/params/HYMAP/HYMAP_parmsMod.F90 +++ b/ldt/params/HYMAP/HYMAP_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_baseflow_delay.F90 b/ldt/params/HYMAP/read_HYMAP_baseflow_delay.F90 index 6182f335b..b8a0fcb69 100644 --- a/ldt/params/HYMAP/read_HYMAP_baseflow_delay.F90 +++ b/ldt/params/HYMAP/read_HYMAP_baseflow_delay.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_baseflow_dwi_ratio.F90 b/ldt/params/HYMAP/read_HYMAP_baseflow_dwi_ratio.F90 index 0d77add0f..37c1aa950 100755 --- a/ldt/params/HYMAP/read_HYMAP_baseflow_dwi_ratio.F90 +++ b/ldt/params/HYMAP/read_HYMAP_baseflow_dwi_ratio.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_basin.F90 b/ldt/params/HYMAP/read_HYMAP_basin.F90 index 1ff9b9f8a..b601db7a1 100755 --- a/ldt/params/HYMAP/read_HYMAP_basin.F90 +++ b/ldt/params/HYMAP/read_HYMAP_basin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_basin_mask.F90 b/ldt/params/HYMAP/read_HYMAP_basin_mask.F90 index 2a28f36a1..1cdacb0ac 100644 --- a/ldt/params/HYMAP/read_HYMAP_basin_mask.F90 +++ b/ldt/params/HYMAP/read_HYMAP_basin_mask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_drain_area.F90 b/ldt/params/HYMAP/read_HYMAP_drain_area.F90 index 3809a200e..9195f184f 100755 --- a/ldt/params/HYMAP/read_HYMAP_drain_area.F90 +++ b/ldt/params/HYMAP/read_HYMAP_drain_area.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_fld_height.F90 b/ldt/params/HYMAP/read_HYMAP_fld_height.F90 index 8a5cee7b4..feb4b8f98 100644 --- a/ldt/params/HYMAP/read_HYMAP_fld_height.F90 +++ b/ldt/params/HYMAP/read_HYMAP_fld_height.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_fld_z.F90 b/ldt/params/HYMAP/read_HYMAP_fld_z.F90 index 69c16e529..d1942673b 100644 --- a/ldt/params/HYMAP/read_HYMAP_fld_z.F90 +++ b/ldt/params/HYMAP/read_HYMAP_fld_z.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_flow_dir_x.F90 b/ldt/params/HYMAP/read_HYMAP_flow_dir_x.F90 index af2c10bd5..839cb6575 100644 --- a/ldt/params/HYMAP/read_HYMAP_flow_dir_x.F90 +++ b/ldt/params/HYMAP/read_HYMAP_flow_dir_x.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_flow_dir_y.F90 b/ldt/params/HYMAP/read_HYMAP_flow_dir_y.F90 index 1da2d5556..463720457 100644 --- a/ldt/params/HYMAP/read_HYMAP_flow_dir_y.F90 +++ b/ldt/params/HYMAP/read_HYMAP_flow_dir_y.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_flow_type.F90 b/ldt/params/HYMAP/read_HYMAP_flow_type.F90 index bac6ecc25..c6ea24639 100755 --- a/ldt/params/HYMAP/read_HYMAP_flow_type.F90 +++ b/ldt/params/HYMAP/read_HYMAP_flow_type.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_grid_area.F90 b/ldt/params/HYMAP/read_HYMAP_grid_area.F90 index 2a8c54359..b9bb65b22 100644 --- a/ldt/params/HYMAP/read_HYMAP_grid_area.F90 +++ b/ldt/params/HYMAP/read_HYMAP_grid_area.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_grid_dist.F90 b/ldt/params/HYMAP/read_HYMAP_grid_dist.F90 index c120b0df1..916df3460 100644 --- a/ldt/params/HYMAP/read_HYMAP_grid_dist.F90 +++ b/ldt/params/HYMAP/read_HYMAP_grid_dist.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_grid_elev.F90 b/ldt/params/HYMAP/read_HYMAP_grid_elev.F90 index b557da632..6c3f70407 100644 --- a/ldt/params/HYMAP/read_HYMAP_grid_elev.F90 +++ b/ldt/params/HYMAP/read_HYMAP_grid_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_refq.F90 b/ldt/params/HYMAP/read_HYMAP_refq.F90 index baf7e9e41..884554ac7 100644 --- a/ldt/params/HYMAP/read_HYMAP_refq.F90 +++ b/ldt/params/HYMAP/read_HYMAP_refq.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_river_height.F90 b/ldt/params/HYMAP/read_HYMAP_river_height.F90 index 15dca00a0..8f651fb34 100644 --- a/ldt/params/HYMAP/read_HYMAP_river_height.F90 +++ b/ldt/params/HYMAP/read_HYMAP_river_height.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_river_length.F90 b/ldt/params/HYMAP/read_HYMAP_river_length.F90 index 14a1f13ba..ec8f0d661 100644 --- a/ldt/params/HYMAP/read_HYMAP_river_length.F90 +++ b/ldt/params/HYMAP/read_HYMAP_river_length.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_river_width.F90 b/ldt/params/HYMAP/read_HYMAP_river_width.F90 index 81e76d184..47c0f48db 100644 --- a/ldt/params/HYMAP/read_HYMAP_river_width.F90 +++ b/ldt/params/HYMAP/read_HYMAP_river_width.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_river_z.F90 b/ldt/params/HYMAP/read_HYMAP_river_z.F90 index 5dff1fc4c..d2ec6533d 100644 --- a/ldt/params/HYMAP/read_HYMAP_river_z.F90 +++ b/ldt/params/HYMAP/read_HYMAP_river_z.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_runoff_delay.F90 b/ldt/params/HYMAP/read_HYMAP_runoff_delay.F90 index 266ddbea5..69b4db405 100644 --- a/ldt/params/HYMAP/read_HYMAP_runoff_delay.F90 +++ b/ldt/params/HYMAP/read_HYMAP_runoff_delay.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_runoff_delaym.F90 b/ldt/params/HYMAP/read_HYMAP_runoff_delaym.F90 index 62f3027ce..774b262c3 100644 --- a/ldt/params/HYMAP/read_HYMAP_runoff_delaym.F90 +++ b/ldt/params/HYMAP/read_HYMAP_runoff_delaym.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/HYMAP/read_HYMAP_runoff_dwi_ratio.F90 b/ldt/params/HYMAP/read_HYMAP_runoff_dwi_ratio.F90 index 2baad3fb2..d26bbb831 100755 --- a/ldt/params/HYMAP/read_HYMAP_runoff_dwi_ratio.F90 +++ b/ldt/params/HYMAP/read_HYMAP_runoff_dwi_ratio.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/JULES/JULES50_parmsMod.F90 b/ldt/params/JULES/JULES50_parmsMod.F90 index 833db1642..6e9c9d245 100644 --- a/ldt/params/JULES/JULES50_parmsMod.F90 +++ b/ldt/params/JULES/JULES50_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/JULES/create_soil_albedo_from_whs.F90 b/ldt/params/JULES/create_soil_albedo_from_whs.F90 index 60c9bc865..ff4199daf 100755 --- a/ldt/params/JULES/create_soil_albedo_from_whs.F90 +++ b/ldt/params/JULES/create_soil_albedo_from_whs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/JULES/create_soil_params_from_cap.F90 b/ldt/params/JULES/create_soil_params_from_cap.F90 index 4ec2fc681..5d611b69b 100755 --- a/ldt/params/JULES/create_soil_params_from_cap.F90 +++ b/ldt/params/JULES/create_soil_params_from_cap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/JULES/read_um_soil_params.F90 b/ldt/params/JULES/read_um_soil_params.F90 index 4bdaad09f..0a11c9d44 100755 --- a/ldt/params/JULES/read_um_soil_params.F90 +++ b/ldt/params/JULES/read_um_soil_params.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_AVHRR_lai.F90 b/ldt/params/LAISAI/read_AVHRR_lai.F90 index ac954a531..e7320810c 100644 --- a/ldt/params/LAISAI/read_AVHRR_lai.F90 +++ b/ldt/params/LAISAI/read_AVHRR_lai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_AVHRR_sai.F90 b/ldt/params/LAISAI/read_AVHRR_sai.F90 index 336f5a9ed..db7a2ad83 100644 --- a/ldt/params/LAISAI/read_AVHRR_sai.F90 +++ b/ldt/params/LAISAI/read_AVHRR_sai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_CLSMF25_lai.F90 b/ldt/params/LAISAI/read_CLSMF25_lai.F90 index 29c8f1f98..5249a93c1 100644 --- a/ldt/params/LAISAI/read_CLSMF25_lai.F90 +++ b/ldt/params/LAISAI/read_CLSMF25_lai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_CLSMF25_laimax.F90 b/ldt/params/LAISAI/read_CLSMF25_laimax.F90 index 5e742e0cb..f702a28ea 100644 --- a/ldt/params/LAISAI/read_CLSMF25_laimax.F90 +++ b/ldt/params/LAISAI/read_CLSMF25_laimax.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_CLSMF25_laimin.F90 b/ldt/params/LAISAI/read_CLSMF25_laimin.F90 index 6b11a79ef..b9c4cee1f 100644 --- a/ldt/params/LAISAI/read_CLSMF25_laimin.F90 +++ b/ldt/params/LAISAI/read_CLSMF25_laimin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_CONSTANT_lai.F90 b/ldt/params/LAISAI/read_CONSTANT_lai.F90 index b0083baaa..bef813cdc 100644 --- a/ldt/params/LAISAI/read_CONSTANT_lai.F90 +++ b/ldt/params/LAISAI/read_CONSTANT_lai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/read_CONSTANT_sai.F90 b/ldt/params/LAISAI/read_CONSTANT_sai.F90 index 998229783..aceb6e2c4 100644 --- a/ldt/params/LAISAI/read_CONSTANT_sai.F90 +++ b/ldt/params/LAISAI/read_CONSTANT_sai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/setLAISAIParmsFullnames.F90 b/ldt/params/LAISAI/setLAISAIParmsFullnames.F90 index feb8c4f12..6619108e1 100644 --- a/ldt/params/LAISAI/setLAISAIParmsFullnames.F90 +++ b/ldt/params/LAISAI/setLAISAIParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/set_AVHRR_lai_attribs.F90 b/ldt/params/LAISAI/set_AVHRR_lai_attribs.F90 index b9eb24438..f8dd911bd 100644 --- a/ldt/params/LAISAI/set_AVHRR_lai_attribs.F90 +++ b/ldt/params/LAISAI/set_AVHRR_lai_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/LAISAI/set_CLSMF25_lai_attribs.F90 b/ldt/params/LAISAI/set_CLSMF25_lai_attribs.F90 index 5852093d9..f79ee9560 100644 --- a/ldt/params/LAISAI/set_CLSMF25_lai_attribs.F90 +++ b/ldt/params/LAISAI/set_CLSMF25_lai_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Mosaic/Mosaic_parmsMod.F90 b/ldt/params/Mosaic/Mosaic_parmsMod.F90 index 2af812607..62aa632cd 100644 --- a/ldt/params/Mosaic/Mosaic_parmsMod.F90 +++ b/ldt/params/Mosaic/Mosaic_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/Noah_parmsMod.F90 b/ldt/params/Noah/Noah_parmsMod.F90 index 8a2ab6163..679b31eb7 100644 --- a/ldt/params/Noah/Noah_parmsMod.F90 +++ b/ldt/params/Noah/Noah_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/module_MMF_groundwater.F90 b/ldt/params/Noah/module_MMF_groundwater.F90 index 6e1291483..af5194212 100644 --- a/ldt/params/Noah/module_MMF_groundwater.F90 +++ b/ldt/params/Noah/module_MMF_groundwater.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_CONSTANT_slopetype.F90 b/ldt/params/Noah/read_CONSTANT_slopetype.F90 index caedb37f2..e9db024bb 100644 --- a/ldt/params/Noah/read_CONSTANT_slopetype.F90 +++ b/ldt/params/Noah/read_CONSTANT_slopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_CONSTANT_tbot.F90 b/ldt/params/Noah/read_CONSTANT_tbot.F90 index d5ca54a1c..fde2b8865 100644 --- a/ldt/params/Noah/read_CONSTANT_tbot.F90 +++ b/ldt/params/Noah/read_CONSTANT_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_GFS_slopetype.F90 b/ldt/params/Noah/read_GFS_slopetype.F90 index acfa29362..6f9ab13a7 100644 --- a/ldt/params/Noah/read_GFS_slopetype.F90 +++ b/ldt/params/Noah/read_GFS_slopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_ISLSCP1_tbot.F90 b/ldt/params/Noah/read_ISLSCP1_tbot.F90 index 41d4abfd3..2ce62ead4 100644 --- a/ldt/params/Noah/read_ISLSCP1_tbot.F90 +++ b/ldt/params/Noah/read_ISLSCP1_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_NCEPNative_slopetype.F90 b/ldt/params/Noah/read_NCEPNative_slopetype.F90 index 0eecf8c98..e7406e09b 100644 --- a/ldt/params/Noah/read_NCEPNative_slopetype.F90 +++ b/ldt/params/Noah/read_NCEPNative_slopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_NCEP_GFS_tbot.F90 b/ldt/params/Noah/read_NCEP_GFS_tbot.F90 index 55fed8214..c76828680 100644 --- a/ldt/params/Noah/read_NCEP_GFS_tbot.F90 +++ b/ldt/params/Noah/read_NCEP_GFS_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_NCEP_slopetype.F90 b/ldt/params/Noah/read_NCEP_slopetype.F90 index fb12e3254..be756c06d 100644 --- a/ldt/params/Noah/read_NCEP_slopetype.F90 +++ b/ldt/params/Noah/read_NCEP_slopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Noah/read_NCEP_tbot.F90 b/ldt/params/Noah/read_NCEP_tbot.F90 index be15e7e2d..9ad087ab6 100644 --- a/ldt/params/Noah/read_NCEP_tbot.F90 +++ b/ldt/params/Noah/read_NCEP_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RDHM/RDHM_parmsMod.F90 b/ldt/params/RDHM/RDHM_parmsMod.F90 index 3949339c1..18f08e15d 100644 --- a/ldt/params/RDHM/RDHM_parmsMod.F90 +++ b/ldt/params/RDHM/RDHM_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RUC/RUC_parmsMod.F90 b/ldt/params/RUC/RUC_parmsMod.F90 index b3af02138..31d5115db 100644 --- a/ldt/params/RUC/RUC_parmsMod.F90 +++ b/ldt/params/RUC/RUC_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RUC/read_RUC_ISLSCP1tbot.F90 b/ldt/params/RUC/read_RUC_ISLSCP1tbot.F90 index 47ba20c11..317a477d8 100644 --- a/ldt/params/RUC/read_RUC_ISLSCP1tbot.F90 +++ b/ldt/params/RUC/read_RUC_ISLSCP1tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RUC/read_RUC_NCEPLIS_slopetype.F90 b/ldt/params/RUC/read_RUC_NCEPLIS_slopetype.F90 index b7e754b98..6b2880bb0 100644 --- a/ldt/params/RUC/read_RUC_NCEPLIS_slopetype.F90 +++ b/ldt/params/RUC/read_RUC_NCEPLIS_slopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RUC/read_RUC_NCEPLIS_tbot.F90 b/ldt/params/RUC/read_RUC_NCEPLIS_tbot.F90 index 0869cdb89..81decf651 100644 --- a/ldt/params/RUC/read_RUC_NCEPLIS_tbot.F90 +++ b/ldt/params/RUC/read_RUC_NCEPLIS_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/RUC/read_RUC_NCEPslopetype.F90 b/ldt/params/RUC/read_RUC_NCEPslopetype.F90 index 64153c89b..f98790682 100644 --- a/ldt/params/RUC/read_RUC_NCEPslopetype.F90 +++ b/ldt/params/RUC/read_RUC_NCEPslopetype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SACHTET/SACHTET_parmsMod.F90 b/ldt/params/SACHTET/SACHTET_parmsMod.F90 index ea080a863..c600f5ea8 100644 --- a/ldt/params/SACHTET/SACHTET_parmsMod.F90 +++ b/ldt/params/SACHTET/SACHTET_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SACHTET/create_SACsoilparms_Korenv1.F90 b/ldt/params/SACHTET/create_SACsoilparms_Korenv1.F90 index fcf5df485..a47b87db3 100644 --- a/ldt/params/SACHTET/create_SACsoilparms_Korenv1.F90 +++ b/ldt/params/SACHTET/create_SACsoilparms_Korenv1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SACHTET/read_SACHTET356_pet.F90 b/ldt/params/SACHTET/read_SACHTET356_pet.F90 index 216b03f6c..18a53472a 100644 --- a/ldt/params/SACHTET/read_SACHTET356_pet.F90 +++ b/ldt/params/SACHTET/read_SACHTET356_pet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SACHTET/read_SACHTET356_petadj.F90 b/ldt/params/SACHTET/read_SACHTET356_petadj.F90 index 135625977..bfa66688e 100644 --- a/ldt/params/SACHTET/read_SACHTET356_petadj.F90 +++ b/ldt/params/SACHTET/read_SACHTET356_petadj.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SACHTET/read_SACHTET356_tbot.F90 b/ldt/params/SACHTET/read_SACHTET356_tbot.F90 index 4a772c7ba..0702941a4 100644 --- a/ldt/params/SACHTET/read_SACHTET356_tbot.F90 +++ b/ldt/params/SACHTET/read_SACHTET356_tbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SiB2/SiB2_parmsMod.F90 b/ldt/params/SiB2/SiB2_parmsMod.F90 index 6605c00dd..877fd99f4 100644 --- a/ldt/params/SiB2/SiB2_parmsMod.F90 +++ b/ldt/params/SiB2/SiB2_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SiB2/read_SiB2_parms.F90 b/ldt/params/SiB2/read_SiB2_parms.F90 index 79e50a7ac..77253ec99 100644 --- a/ldt/params/SiB2/read_SiB2_parms.F90 +++ b/ldt/params/SiB2/read_SiB2_parms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/Snow17/Snow17_parmsMod.F90 b/ldt/params/Snow17/Snow17_parmsMod.F90 index 1f766d91b..774054a36 100644 --- a/ldt/params/Snow17/Snow17_parmsMod.F90 +++ b/ldt/params/Snow17/Snow17_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SnowModel/SnowModel_parmsMod.F90 b/ldt/params/SnowModel/SnowModel_parmsMod.F90 index f462f481f..3f229b57b 100644 --- a/ldt/params/SnowModel/SnowModel_parmsMod.F90 +++ b/ldt/params/SnowModel/SnowModel_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 b/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 index bee9a6ced..a1302e9cf 100644 --- a/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 +++ b/ldt/params/SnowModel/read_SMGradsBin_topoveg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/VIC/LDT_vic412rstMod.F90 b/ldt/params/VIC/LDT_vic412rstMod.F90 index 38c7f44ce..4f37fd94f 100644 --- a/ldt/params/VIC/LDT_vic412rstMod.F90 +++ b/ldt/params/VIC/LDT_vic412rstMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/VIC/VIC_parmsMod.F90 b/ldt/params/VIC/VIC_parmsMod.F90 index 69abd548b..ce2ced2be 100644 --- a/ldt/params/VIC/VIC_parmsMod.F90 +++ b/ldt/params/VIC/VIC_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_BarlageNative_maxsnoalb.F90 b/ldt/params/albedo/read_BarlageNative_maxsnoalb.F90 index 97ce4eb31..5d1a96b4a 100644 --- a/ldt/params/albedo/read_BarlageNative_maxsnoalb.F90 +++ b/ldt/params/albedo/read_BarlageNative_maxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_BrieglebNative_monalbedo.F90 b/ldt/params/albedo/read_BrieglebNative_monalbedo.F90 index 68afcaa26..67b2529e7 100644 --- a/ldt/params/albedo/read_BrieglebNative_monalbedo.F90 +++ b/ldt/params/albedo/read_BrieglebNative_monalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_BrieglebNative_qtralbedo.F90 b/ldt/params/albedo/read_BrieglebNative_qtralbedo.F90 index 070fb9099..ee8507d48 100644 --- a/ldt/params/albedo/read_BrieglebNative_qtralbedo.F90 +++ b/ldt/params/albedo/read_BrieglebNative_qtralbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_Briegleb_albedo.F90 b/ldt/params/albedo/read_Briegleb_albedo.F90 index 0bc67100f..7d3f9a210 100644 --- a/ldt/params/albedo/read_Briegleb_albedo.F90 +++ b/ldt/params/albedo/read_Briegleb_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_CONSTANT_albedo.F90 b/ldt/params/albedo/read_CONSTANT_albedo.F90 index 54de82e45..b90745f58 100644 --- a/ldt/params/albedo/read_CONSTANT_albedo.F90 +++ b/ldt/params/albedo/read_CONSTANT_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_CONSTANT_mxsnoalb.F90 b/ldt/params/albedo/read_CONSTANT_mxsnoalb.F90 index 893530cf4..b04aa75eb 100644 --- a/ldt/params/albedo/read_CONSTANT_mxsnoalb.F90 +++ b/ldt/params/albedo/read_CONSTANT_mxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_GFS_maxsnoalb.F90 b/ldt/params/albedo/read_GFS_maxsnoalb.F90 index 8051269de..48eebdc8e 100644 --- a/ldt/params/albedo/read_GFS_maxsnoalb.F90 +++ b/ldt/params/albedo/read_GFS_maxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_RobinsonKuklaNative_mxsnoalb.F90 b/ldt/params/albedo/read_RobinsonKuklaNative_mxsnoalb.F90 index d7f5bfe09..09b0b535e 100644 --- a/ldt/params/albedo/read_RobinsonKuklaNative_mxsnoalb.F90 +++ b/ldt/params/albedo/read_RobinsonKuklaNative_mxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_RobinsonKukla_mxsnoalb.F90 b/ldt/params/albedo/read_RobinsonKukla_mxsnoalb.F90 index 99a276ba2..99fa56ebf 100644 --- a/ldt/params/albedo/read_RobinsonKukla_mxsnoalb.F90 +++ b/ldt/params/albedo/read_RobinsonKukla_mxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/read_SACHTET356_mxsnoalb.F90 b/ldt/params/albedo/read_SACHTET356_mxsnoalb.F90 index 42575e8c0..974f15d93 100644 --- a/ldt/params/albedo/read_SACHTET356_mxsnoalb.F90 +++ b/ldt/params/albedo/read_SACHTET356_mxsnoalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/setAlbedoParmsFullnames.F90 b/ldt/params/albedo/setAlbedoParmsFullnames.F90 index ae9794164..e185d39ff 100644 --- a/ldt/params/albedo/setAlbedoParmsFullnames.F90 +++ b/ldt/params/albedo/setAlbedoParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/albedo/set_albedo_attribs.F90 b/ldt/params/albedo/set_albedo_attribs.F90 index 1153e08d4..95071565f 100644 --- a/ldt/params/albedo/set_albedo_attribs.F90 +++ b/ldt/params/albedo/set_albedo_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/CLSMF25_parmsMod.F90 b/ldt/params/catchment/CLSMF25_parmsMod.F90 index 3efbb8cb3..c8f33544f 100644 --- a/ldt/params/catchment/CLSMF25_parmsMod.F90 +++ b/ldt/params/catchment/CLSMF25_parmsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_albnir.F90 b/ldt/params/catchment/read_CLSMF25_albnir.F90 index c39370801..9ae24ab91 100644 --- a/ldt/params/catchment/read_CLSMF25_albnir.F90 +++ b/ldt/params/catchment/read_CLSMF25_albnir.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_albvis.F90 b/ldt/params/catchment/read_CLSMF25_albvis.F90 index 9e84bffae..2a2686c66 100644 --- a/ldt/params/catchment/read_CLSMF25_albvis.F90 +++ b/ldt/params/catchment/read_CLSMF25_albvis.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_araparams.F90 b/ldt/params/catchment/read_CLSMF25_araparams.F90 index 51113eb3e..15f5f1ec7 100644 --- a/ldt/params/catchment/read_CLSMF25_araparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_araparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_arsparams.F90 b/ldt/params/catchment/read_CLSMF25_arsparams.F90 index 9d4834d7b..450d05af9 100644 --- a/ldt/params/catchment/read_CLSMF25_arsparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_arsparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_arwparams.F90 b/ldt/params/catchment/read_CLSMF25_arwparams.F90 index 8cba7cb42..1b5fbd55f 100644 --- a/ldt/params/catchment/read_CLSMF25_arwparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_arwparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_bedrockdepth.F90 b/ldt/params/catchment/read_CLSMF25_bedrockdepth.F90 index 9be51a562..f1968f00b 100644 --- a/ldt/params/catchment/read_CLSMF25_bedrockdepth.F90 +++ b/ldt/params/catchment/read_CLSMF25_bedrockdepth.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_bexp.F90 b/ldt/params/catchment/read_CLSMF25_bexp.F90 index ddfba3e76..15cb8727d 100644 --- a/ldt/params/catchment/read_CLSMF25_bexp.F90 +++ b/ldt/params/catchment/read_CLSMF25_bexp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_bfparams.F90 b/ldt/params/catchment/read_CLSMF25_bfparams.F90 index 9364ce8ff..ab9eddb7d 100644 --- a/ldt/params/catchment/read_CLSMF25_bfparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_bfparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_gnuparam.F90 b/ldt/params/catchment/read_CLSMF25_gnuparam.F90 index 7091ebe1d..abbc851e1 100644 --- a/ldt/params/catchment/read_CLSMF25_gnuparam.F90 +++ b/ldt/params/catchment/read_CLSMF25_gnuparam.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_ksat.F90 b/ldt/params/catchment/read_CLSMF25_ksat.F90 index cf17b3faf..8d16e41ff 100644 --- a/ldt/params/catchment/read_CLSMF25_ksat.F90 +++ b/ldt/params/catchment/read_CLSMF25_ksat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_psisat.F90 b/ldt/params/catchment/read_CLSMF25_psisat.F90 index 2a85732b8..9f6fbea04 100644 --- a/ldt/params/catchment/read_CLSMF25_psisat.F90 +++ b/ldt/params/catchment/read_CLSMF25_psisat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_tauparams.F90 b/ldt/params/catchment/read_CLSMF25_tauparams.F90 index 72fdf1f99..ff925789e 100644 --- a/ldt/params/catchment/read_CLSMF25_tauparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_tauparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_tsparams.F90 b/ldt/params/catchment/read_CLSMF25_tsparams.F90 index ed69e95a7..036a6d6f0 100644 --- a/ldt/params/catchment/read_CLSMF25_tsparams.F90 +++ b/ldt/params/catchment/read_CLSMF25_tsparams.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/read_CLSMF25_wpwet.F90 b/ldt/params/catchment/read_CLSMF25_wpwet.F90 index 5208d3ed5..488096652 100644 --- a/ldt/params/catchment/read_CLSMF25_wpwet.F90 +++ b/ldt/params/catchment/read_CLSMF25_wpwet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/catchment/set_CLSMF25_gfrac_attribs.F90 b/ldt/params/catchment/set_CLSMF25_gfrac_attribs.F90 index 8cecea792..a54076425 100644 --- a/ldt/params/catchment/set_CLSMF25_gfrac_attribs.F90 +++ b/ldt/params/catchment/set_CLSMF25_gfrac_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/climateparms/LDT_NAFPA_back_climpptMod.F90 b/ldt/params/climateparms/LDT_NAFPA_back_climpptMod.F90 index 5fe9340a5..374952fc1 100644 --- a/ldt/params/climateparms/LDT_NAFPA_back_climpptMod.F90 +++ b/ldt/params/climateparms/LDT_NAFPA_back_climpptMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/climateparms/read_NLDAS_climppt.F90 b/ldt/params/climateparms/read_NLDAS_climppt.F90 index 5d68938d1..242e221a5 100755 --- a/ldt/params/climateparms/read_NLDAS_climppt.F90 +++ b/ldt/params/climateparms/read_NLDAS_climppt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/climateparms/read_PRISM_climppt.F90 b/ldt/params/climateparms/read_PRISM_climppt.F90 index 828ab7671..615d65fa9 100644 --- a/ldt/params/climateparms/read_PRISM_climppt.F90 +++ b/ldt/params/climateparms/read_PRISM_climppt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/climateparms/read_WorldClim_climppt.F90 b/ldt/params/climateparms/read_WorldClim_climppt.F90 index de485d584..696c5232d 100644 --- a/ldt/params/climateparms/read_WorldClim_climppt.F90 +++ b/ldt/params/climateparms/read_WorldClim_climppt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/climateparms/setClimateParmsFullnames.F90 b/ldt/params/climateparms/setClimateParmsFullnames.F90 index a7a035a1d..ba3448f6f 100644 --- a/ldt/params/climateparms/setClimateParmsFullnames.F90 +++ b/ldt/params/climateparms/setClimateParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/crop_parms/Monfredaetal08_crops_module.F90 b/ldt/params/crop_parms/Monfredaetal08_crops_module.F90 index 4bbc5e87c..09a745691 100755 --- a/ldt/params/crop_parms/Monfredaetal08_crops_module.F90 +++ b/ldt/params/crop_parms/Monfredaetal08_crops_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/crop_parms/assigncroptype.F90 b/ldt/params/crop_parms/assigncroptype.F90 index 09d8c2a8e..ff47c9784 100644 --- a/ldt/params/crop_parms/assigncroptype.F90 +++ b/ldt/params/crop_parms/assigncroptype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/crop_parms/read_UMDCROPMAP_croptype.F90 b/ldt/params/crop_parms/read_UMDCROPMAP_croptype.F90 index 09a326579..349551a1e 100755 --- a/ldt/params/crop_parms/read_UMDCROPMAP_croptype.F90 +++ b/ldt/params/crop_parms/read_UMDCROPMAP_croptype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/crop_parms/readcropinventory.F90 b/ldt/params/crop_parms/readcropinventory.F90 index c4d8152ad..ab8984d0a 100644 --- a/ldt/params/crop_parms/readcropinventory.F90 +++ b/ldt/params/crop_parms/readcropinventory.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/crop_parms/setCropParmsFullnames.F90 b/ldt/params/crop_parms/setCropParmsFullnames.F90 index d0cd9ea96..4a76c2b30 100644 --- a/ldt/params/crop_parms/setCropParmsFullnames.F90 +++ b/ldt/params/crop_parms/setCropParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_AVHRRNative_gfrac.F90 b/ldt/params/gfrac/read_AVHRRNative_gfrac.F90 index 3633dd7d9..a0eff9873 100644 --- a/ldt/params/gfrac/read_AVHRRNative_gfrac.F90 +++ b/ldt/params/gfrac/read_AVHRRNative_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_AVHRR_gfrac.F90 b/ldt/params/gfrac/read_AVHRR_gfrac.F90 index 2acb4ee7f..e0fa5280c 100644 --- a/ldt/params/gfrac/read_AVHRR_gfrac.F90 +++ b/ldt/params/gfrac/read_AVHRR_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CLSMF25_gfrac.F90 b/ldt/params/gfrac/read_CLSMF25_gfrac.F90 index be9565e8c..081caa11c 100644 --- a/ldt/params/gfrac/read_CLSMF25_gfrac.F90 +++ b/ldt/params/gfrac/read_CLSMF25_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CLSMF25_gfracmax.F90 b/ldt/params/gfrac/read_CLSMF25_gfracmax.F90 index 8735828f7..d1aead826 100644 --- a/ldt/params/gfrac/read_CLSMF25_gfracmax.F90 +++ b/ldt/params/gfrac/read_CLSMF25_gfracmax.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CLSMF25_gfracmin.F90 b/ldt/params/gfrac/read_CLSMF25_gfracmin.F90 index e6b984e8d..98a42cbcd 100644 --- a/ldt/params/gfrac/read_CLSMF25_gfracmin.F90 +++ b/ldt/params/gfrac/read_CLSMF25_gfracmin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CONSTANT_gfrac.F90 b/ldt/params/gfrac/read_CONSTANT_gfrac.F90 index 4dcbf48e6..17b58e16a 100644 --- a/ldt/params/gfrac/read_CONSTANT_gfrac.F90 +++ b/ldt/params/gfrac/read_CONSTANT_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CONSTANT_gfracmax.F90 b/ldt/params/gfrac/read_CONSTANT_gfracmax.F90 index b77c26f0c..4555e6dc1 100644 --- a/ldt/params/gfrac/read_CONSTANT_gfracmax.F90 +++ b/ldt/params/gfrac/read_CONSTANT_gfracmax.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_CONSTANT_gfracmin.F90 b/ldt/params/gfrac/read_CONSTANT_gfracmin.F90 index 5ffedbc25..3b6fc674f 100644 --- a/ldt/params/gfrac/read_CONSTANT_gfracmin.F90 +++ b/ldt/params/gfrac/read_CONSTANT_gfracmin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_NCEPNative_shdmax.F90 b/ldt/params/gfrac/read_NCEPNative_shdmax.F90 index eac2edd57..efb2c6bfd 100644 --- a/ldt/params/gfrac/read_NCEPNative_shdmax.F90 +++ b/ldt/params/gfrac/read_NCEPNative_shdmax.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_NCEPNative_shdmin.F90 b/ldt/params/gfrac/read_NCEPNative_shdmin.F90 index 6653c80f3..bc77cb1dd 100644 --- a/ldt/params/gfrac/read_NCEPNative_shdmin.F90 +++ b/ldt/params/gfrac/read_NCEPNative_shdmin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_NCEP_shdmax.F90 b/ldt/params/gfrac/read_NCEP_shdmax.F90 index a346bd96b..3921b63f0 100644 --- a/ldt/params/gfrac/read_NCEP_shdmax.F90 +++ b/ldt/params/gfrac/read_NCEP_shdmax.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_NCEP_shdmin.F90 b/ldt/params/gfrac/read_NCEP_shdmin.F90 index bef40d95e..98b639500 100644 --- a/ldt/params/gfrac/read_NCEP_shdmin.F90 +++ b/ldt/params/gfrac/read_NCEP_shdmin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/read_SACHTET356_gfrac.F90 b/ldt/params/gfrac/read_SACHTET356_gfrac.F90 index 3ad1843ad..a539dd090 100644 --- a/ldt/params/gfrac/read_SACHTET356_gfrac.F90 +++ b/ldt/params/gfrac/read_SACHTET356_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/setGfracParmsFullnames.F90 b/ldt/params/gfrac/setGfracParmsFullnames.F90 index b580dd680..82d7eae99 100644 --- a/ldt/params/gfrac/setGfracParmsFullnames.F90 +++ b/ldt/params/gfrac/setGfracParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/gfrac/set_gfrac_attribs.F90 b/ldt/params/gfrac/set_gfrac_attribs.F90 index fb5ee4d02..3f20390a1 100644 --- a/ldt/params/gfrac/set_gfrac_attribs.F90 +++ b/ldt/params/gfrac/set_gfrac_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/glacier/read_GLIMS_glacierfraction.F90 b/ldt/params/glacier/read_GLIMS_glacierfraction.F90 index 957424b84..89b11abbd 100755 --- a/ldt/params/glacier/read_GLIMS_glacierfraction.F90 +++ b/ldt/params/glacier/read_GLIMS_glacierfraction.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/glacier/read_GLIMS_glaciermask.F90 b/ldt/params/glacier/read_GLIMS_glaciermask.F90 index 6ffdbf18a..13768026e 100755 --- a/ldt/params/glacier/read_GLIMS_glaciermask.F90 +++ b/ldt/params/glacier/read_GLIMS_glaciermask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/glacier/setGlacierFracParmsFullnames.F90 b/ldt/params/glacier/setGlacierFracParmsFullnames.F90 index 07ca28033..f615a7559 100644 --- a/ldt/params/glacier/setGlacierFracParmsFullnames.F90 +++ b/ldt/params/glacier/setGlacierFracParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/glacier/set_glacierfraction_attribs.F90 b/ldt/params/glacier/set_glacierfraction_attribs.F90 index 8bc277162..139951a43 100644 --- a/ldt/params/glacier/set_glacierfraction_attribs.F90 +++ b/ldt/params/glacier/set_glacierfraction_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/read_GRIPC_irrigfrac.F90 b/ldt/params/irrigation/read_GRIPC_irrigfrac.F90 index 6f6163204..f58354daf 100644 --- a/ldt/params/irrigation/read_GRIPC_irrigfrac.F90 +++ b/ldt/params/irrigation/read_GRIPC_irrigfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/read_GRIPC_irrigtype.F90 b/ldt/params/irrigation/read_GRIPC_irrigtype.F90 index 9478ffd96..1e315db26 100644 --- a/ldt/params/irrigation/read_GRIPC_irrigtype.F90 +++ b/ldt/params/irrigation/read_GRIPC_irrigtype.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/read_OzdoganGutman_irrigfrac.F90 b/ldt/params/irrigation/read_OzdoganGutman_irrigfrac.F90 index dc6c4b6fd..d9547e74e 100644 --- a/ldt/params/irrigation/read_OzdoganGutman_irrigfrac.F90 +++ b/ldt/params/irrigation/read_OzdoganGutman_irrigfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/read_USGSNative_irriggwratio.F90 b/ldt/params/irrigation/read_USGSNative_irriggwratio.F90 index 4e2c8851f..eba1f05df 100644 --- a/ldt/params/irrigation/read_USGSNative_irriggwratio.F90 +++ b/ldt/params/irrigation/read_USGSNative_irriggwratio.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/read_UserDerived_irrigfrac.F90 b/ldt/params/irrigation/read_UserDerived_irrigfrac.F90 index 746ff4cbb..d31b948a8 100644 --- a/ldt/params/irrigation/read_UserDerived_irrigfrac.F90 +++ b/ldt/params/irrigation/read_UserDerived_irrigfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/setIrrigParmsFullnames.F90 b/ldt/params/irrigation/setIrrigParmsFullnames.F90 index 81a3277e3..2ce5c03c1 100644 --- a/ldt/params/irrigation/setIrrigParmsFullnames.F90 +++ b/ldt/params/irrigation/setIrrigParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/set_irrigation_attribs.F90 b/ldt/params/irrigation/set_irrigation_attribs.F90 index 3cf7cf46b..f46c8ef2d 100644 --- a/ldt/params/irrigation/set_irrigation_attribs.F90 +++ b/ldt/params/irrigation/set_irrigation_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/irrigation/set_irriggwratio_attribs.F90 b/ldt/params/irrigation/set_irriggwratio_attribs.F90 index 006a8d979..f3befde78 100644 --- a/ldt/params/irrigation/set_irriggwratio_attribs.F90 +++ b/ldt/params/irrigation/set_irriggwratio_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_ALMIPII_droot.F90 b/ldt/params/landcover/read_ALMIPII_droot.F90 index 31f5310a1..17f17bcdd 100644 --- a/ldt/params/landcover/read_ALMIPII_droot.F90 +++ b/ldt/params/landcover/read_ALMIPII_droot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_ALMIPII_lc.F90 b/ldt/params/landcover/read_ALMIPII_lc.F90 index 7e945df5a..91eb12aa0 100644 --- a/ldt/params/landcover/read_ALMIPII_lc.F90 +++ b/ldt/params/landcover/read_ALMIPII_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_AVHRR_GFS_lc.F90 b/ldt/params/landcover/read_AVHRR_GFS_lc.F90 index bd4946cfe..3fa0e285f 100755 --- a/ldt/params/landcover/read_AVHRR_GFS_lc.F90 +++ b/ldt/params/landcover/read_AVHRR_GFS_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_AVHRR_lc.F90 b/ldt/params/landcover/read_AVHRR_lc.F90 index 500bb97bf..369cb7582 100755 --- a/ldt/params/landcover/read_AVHRR_lc.F90 +++ b/ldt/params/landcover/read_AVHRR_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_CLM45_lc.F90 b/ldt/params/landcover/read_CLM45_lc.F90 index 6f5112189..588b43d78 100644 --- a/ldt/params/landcover/read_CLM45_lc.F90 +++ b/ldt/params/landcover/read_CLM45_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_CLSMF25_lc.F90 b/ldt/params/landcover/read_CLSMF25_lc.F90 index f465457f2..506d008a5 100755 --- a/ldt/params/landcover/read_CLSMF25_lc.F90 +++ b/ldt/params/landcover/read_CLSMF25_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_CONSTANT_lc.F90 b/ldt/params/landcover/read_CONSTANT_lc.F90 index 82b73a96d..635e75e04 100755 --- a/ldt/params/landcover/read_CONSTANT_lc.F90 +++ b/ldt/params/landcover/read_CONSTANT_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_ISA_lc.F90 b/ldt/params/landcover/read_ISA_lc.F90 index 1641c0262..1da5e8c4d 100755 --- a/ldt/params/landcover/read_ISA_lc.F90 +++ b/ldt/params/landcover/read_ISA_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_MCD12Q1_lc.F90 b/ldt/params/landcover/read_MCD12Q1_lc.F90 index 448f16f13..1e04a406f 100755 --- a/ldt/params/landcover/read_MCD12Q1_lc.F90 +++ b/ldt/params/landcover/read_MCD12Q1_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_MODISNative_PFT.F90 b/ldt/params/landcover/read_MODISNative_PFT.F90 index 7ec61b3e3..6c850bfa7 100755 --- a/ldt/params/landcover/read_MODISNative_PFT.F90 +++ b/ldt/params/landcover/read_MODISNative_PFT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_MODISNative_lc.F90 b/ldt/params/landcover/read_MODISNative_lc.F90 index c3f391e12..e3ab883b2 100755 --- a/ldt/params/landcover/read_MODISNative_lc.F90 +++ b/ldt/params/landcover/read_MODISNative_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_MODIS_lc.F90 b/ldt/params/landcover/read_MODIS_lc.F90 index f0a281b53..05bd457f5 100755 --- a/ldt/params/landcover/read_MODIS_lc.F90 +++ b/ldt/params/landcover/read_MODIS_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 b/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 index 6757937bb..e8784430b 100644 --- a/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 +++ b/ldt/params/landcover/read_NALCMS_SM_IGBPNCEP_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_NALCMS_SM_lc.F90 b/ldt/params/landcover/read_NALCMS_SM_lc.F90 index 5fec3a1d3..022d55937 100644 --- a/ldt/params/landcover/read_NALCMS_SM_lc.F90 +++ b/ldt/params/landcover/read_NALCMS_SM_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_SACHTET356_lc.F90 b/ldt/params/landcover/read_SACHTET356_lc.F90 index 6eb255522..49358613e 100755 --- a/ldt/params/landcover/read_SACHTET356_lc.F90 +++ b/ldt/params/landcover/read_SACHTET356_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90 b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90 index 4395c3349..8cdbdb9d8 100755 --- a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90 +++ b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.binary b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.binary index 52baebbde..f574e592b 100755 --- a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.binary +++ b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.binary @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.nc b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.nc index 4395c3349..8cdbdb9d8 100755 --- a/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.nc +++ b/ldt/params/landcover/read_UKMO_IGBP_PFT.F90.nc @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_UM_ancillary.F90 b/ldt/params/landcover/read_UM_ancillary.F90 index 94d8619b8..662222f78 100755 --- a/ldt/params/landcover/read_UM_ancillary.F90 +++ b/ldt/params/landcover/read_UM_ancillary.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_USGSNative_lc.F90 b/ldt/params/landcover/read_USGSNative_lc.F90 index abd1ce65e..9e452e88f 100644 --- a/ldt/params/landcover/read_USGSNative_lc.F90 +++ b/ldt/params/landcover/read_USGSNative_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_USGS_lc.F90 b/ldt/params/landcover/read_USGS_lc.F90 index 89ddb6554..09c823eee 100644 --- a/ldt/params/landcover/read_USGS_lc.F90 +++ b/ldt/params/landcover/read_USGS_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_VIC411_lc.F90 b/ldt/params/landcover/read_VIC411_lc.F90 index 26829909f..7bb3f87fc 100755 --- a/ldt/params/landcover/read_VIC411_lc.F90 +++ b/ldt/params/landcover/read_VIC411_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/landcover/read_VIC412_lc.F90 b/ldt/params/landcover/read_VIC412_lc.F90 index 52deb770f..77257c14d 100755 --- a/ldt/params/landcover/read_VIC412_lc.F90 +++ b/ldt/params/landcover/read_VIC412_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/create_maskfile.F90 b/ldt/params/mask/create_maskfile.F90 index 6ac226bac..0a17fbce0 100755 --- a/ldt/params/mask/create_maskfile.F90 +++ b/ldt/params/mask/create_maskfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_ISA_maskfile.F90 b/ldt/params/mask/read_ISA_maskfile.F90 index 9983b5ba5..fdba9b335 100755 --- a/ldt/params/mask/read_ISA_maskfile.F90 +++ b/ldt/params/mask/read_ISA_maskfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_maskfile.F90 b/ldt/params/mask/read_maskfile.F90 index d3c1a11b1..ecbd4a89a 100755 --- a/ldt/params/mask/read_maskfile.F90 +++ b/ldt/params/mask/read_maskfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_maskfile_MCD12Q1.F90 b/ldt/params/mask/read_maskfile_MCD12Q1.F90 index 43e4f6d58..ebc7f456c 100644 --- a/ldt/params/mask/read_maskfile_MCD12Q1.F90 +++ b/ldt/params/mask/read_maskfile_MCD12Q1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_maskfile_UKMO_CAP_Netcdf.F90 b/ldt/params/mask/read_maskfile_UKMO_CAP_Netcdf.F90 index 10b6e678a..335df5d39 100644 --- a/ldt/params/mask/read_maskfile_UKMO_CAP_Netcdf.F90 +++ b/ldt/params/mask/read_maskfile_UKMO_CAP_Netcdf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_maskfile_UKMO_IGBP_Native_PFT.F90 b/ldt/params/mask/read_maskfile_UKMO_IGBP_Native_PFT.F90 index 61cec1d89..fa30238c5 100644 --- a/ldt/params/mask/read_maskfile_UKMO_IGBP_Native_PFT.F90 +++ b/ldt/params/mask/read_maskfile_UKMO_IGBP_Native_PFT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_regmask_gis.F90 b/ldt/params/mask/read_regmask_gis.F90 index be9d2e407..8ee84a351 100644 --- a/ldt/params/mask/read_regmask_gis.F90 +++ b/ldt/params/mask/read_regmask_gis.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_regmask_mask.F90 b/ldt/params/mask/read_regmask_mask.F90 index 66414269b..d33e48d0b 100644 --- a/ldt/params/mask/read_regmask_mask.F90 +++ b/ldt/params/mask/read_regmask_mask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/mask/read_regmask_wrsi.F90 b/ldt/params/mask/read_regmask_wrsi.F90 index e1c733cbb..54ac03e87 100644 --- a/ldt/params/mask/read_regmask_wrsi.F90 +++ b/ldt/params/mask/read_regmask_wrsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_ALMIPII_dsoil.F90 b/ldt/params/soils/read_ALMIPII_dsoil.F90 index e151f766a..176a96c8c 100644 --- a/ldt/params/soils/read_ALMIPII_dsoil.F90 +++ b/ldt/params/soils/read_ALMIPII_dsoil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_ALMIPII_soilfractions.F90 b/ldt/params/soils/read_ALMIPII_soilfractions.F90 index 4d3a75025..bc209c1f7 100644 --- a/ldt/params/soils/read_ALMIPII_soilfractions.F90 +++ b/ldt/params/soils/read_ALMIPII_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_CLSMF25_porosity.F90 b/ldt/params/soils/read_CLSMF25_porosity.F90 index b8dedaf27..7f339feea 100644 --- a/ldt/params/soils/read_CLSMF25_porosity.F90 +++ b/ldt/params/soils/read_CLSMF25_porosity.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_CONSTANT_porosity.F90 b/ldt/params/soils/read_CONSTANT_porosity.F90 index c518476b8..8f83d112c 100644 --- a/ldt/params/soils/read_CONSTANT_porosity.F90 +++ b/ldt/params/soils/read_CONSTANT_porosity.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_CONSTANT_soilfractions.F90 b/ldt/params/soils/read_CONSTANT_soilfractions.F90 index 740b1b2dd..3e042ee2d 100644 --- a/ldt/params/soils/read_CONSTANT_soilfractions.F90 +++ b/ldt/params/soils/read_CONSTANT_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_CONSTANT_texture.F90 b/ldt/params/soils/read_CONSTANT_texture.F90 index ed3ba3aff..6c39e3907 100644 --- a/ldt/params/soils/read_CONSTANT_texture.F90 +++ b/ldt/params/soils/read_CONSTANT_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_FAO_color.F90 b/ldt/params/soils/read_FAO_color.F90 index 89b8501ff..1f83891d1 100644 --- a/ldt/params/soils/read_FAO_color.F90 +++ b/ldt/params/soils/read_FAO_color.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_FAO_porosity.F90 b/ldt/params/soils/read_FAO_porosity.F90 index 0459411fe..90c743952 100644 --- a/ldt/params/soils/read_FAO_porosity.F90 +++ b/ldt/params/soils/read_FAO_porosity.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_FAO_soilfractions.F90 b/ldt/params/soils/read_FAO_soilfractions.F90 index 63e3db752..a5caa2204 100644 --- a/ldt/params/soils/read_FAO_soilfractions.F90 +++ b/ldt/params/soils/read_FAO_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_FAO_texture.F90 b/ldt/params/soils/read_FAO_texture.F90 index 2df796073..e138d3e80 100644 --- a/ldt/params/soils/read_FAO_texture.F90 +++ b/ldt/params/soils/read_FAO_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_ISRIC_soilfractions.F90 b/ldt/params/soils/read_ISRIC_soilfractions.F90 index 7b7efbeb1..85436a99f 100644 --- a/ldt/params/soils/read_ISRIC_soilfractions.F90 +++ b/ldt/params/soils/read_ISRIC_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_ISRIC_texture.F90 b/ldt/params/soils/read_ISRIC_texture.F90 index 21e17b627..a73e44171 100644 --- a/ldt/params/soils/read_ISRIC_texture.F90 +++ b/ldt/params/soils/read_ISRIC_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_STATSGOFAO_Native_texture.F90 b/ldt/params/soils/read_STATSGOFAO_Native_texture.F90 index ac675e801..7475e7668 100644 --- a/ldt/params/soils/read_STATSGOFAO_Native_texture.F90 +++ b/ldt/params/soils/read_STATSGOFAO_Native_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_STATSGOFAO_texture.F90 b/ldt/params/soils/read_STATSGOFAO_texture.F90 index 47bcefb01..7d4c3fa52 100644 --- a/ldt/params/soils/read_STATSGOFAO_texture.F90 +++ b/ldt/params/soils/read_STATSGOFAO_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_STATSGOv1_hydrosoilgroup.F90 b/ldt/params/soils/read_STATSGOv1_hydrosoilgroup.F90 index 00173a6e4..c78610311 100644 --- a/ldt/params/soils/read_STATSGOv1_hydrosoilgroup.F90 +++ b/ldt/params/soils/read_STATSGOv1_hydrosoilgroup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_STATSGOv1_soilfractions.F90 b/ldt/params/soils/read_STATSGOv1_soilfractions.F90 index 850531248..b361d37cc 100644 --- a/ldt/params/soils/read_STATSGOv1_soilfractions.F90 +++ b/ldt/params/soils/read_STATSGOv1_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_STATSGOv1_texture.F90 b/ldt/params/soils/read_STATSGOv1_texture.F90 index 6cf96bad4..6f05ab1a7 100644 --- a/ldt/params/soils/read_STATSGOv1_texture.F90 +++ b/ldt/params/soils/read_STATSGOv1_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_Special_soilfractions.F90 b/ldt/params/soils/read_Special_soilfractions.F90 index 888aa5c33..a16a820df 100644 --- a/ldt/params/soils/read_Special_soilfractions.F90 +++ b/ldt/params/soils/read_Special_soilfractions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_Special_texture.F90 b/ldt/params/soils/read_Special_texture.F90 index 7631b7b2f..8f26e4ca4 100644 --- a/ldt/params/soils/read_Special_texture.F90 +++ b/ldt/params/soils/read_Special_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/read_ZOBLER_GFS_texture.F90 b/ldt/params/soils/read_ZOBLER_GFS_texture.F90 index b239e534f..14c1c7d5b 100644 --- a/ldt/params/soils/read_ZOBLER_GFS_texture.F90 +++ b/ldt/params/soils/read_ZOBLER_GFS_texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_CONSTANT_texture_attribs.F90 b/ldt/params/soils/set_CONSTANT_texture_attribs.F90 index efd7a7de4..47c11b53b 100644 --- a/ldt/params/soils/set_CONSTANT_texture_attribs.F90 +++ b/ldt/params/soils/set_CONSTANT_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_ISRIC_texture_attribs.F90 b/ldt/params/soils/set_ISRIC_texture_attribs.F90 index 470996bc6..b657dfa02 100644 --- a/ldt/params/soils/set_ISRIC_texture_attribs.F90 +++ b/ldt/params/soils/set_ISRIC_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_STATSGOFAO_LIS_texture_attribs.F90 b/ldt/params/soils/set_STATSGOFAO_LIS_texture_attribs.F90 index 580edd2d6..37aff85e3 100644 --- a/ldt/params/soils/set_STATSGOFAO_LIS_texture_attribs.F90 +++ b/ldt/params/soils/set_STATSGOFAO_LIS_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_STATSGOFAO_Native_texture_attribs.F90 b/ldt/params/soils/set_STATSGOFAO_Native_texture_attribs.F90 index 2375887b8..1823bc7f1 100644 --- a/ldt/params/soils/set_STATSGOFAO_Native_texture_attribs.F90 +++ b/ldt/params/soils/set_STATSGOFAO_Native_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_STATSGOv1_hsg_attribs.F90 b/ldt/params/soils/set_STATSGOv1_hsg_attribs.F90 index 36f325199..13bedf0ba 100644 --- a/ldt/params/soils/set_STATSGOv1_hsg_attribs.F90 +++ b/ldt/params/soils/set_STATSGOv1_hsg_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_STATSGOv1_texture_attribs.F90 b/ldt/params/soils/set_STATSGOv1_texture_attribs.F90 index 720d46dc8..58671e083 100644 --- a/ldt/params/soils/set_STATSGOv1_texture_attribs.F90 +++ b/ldt/params/soils/set_STATSGOv1_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_Special_texture_attribs.F90 b/ldt/params/soils/set_Special_texture_attribs.F90 index 515779ba1..838a280df 100644 --- a/ldt/params/soils/set_Special_texture_attribs.F90 +++ b/ldt/params/soils/set_Special_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/soils/set_ZOBLER_GFS_texture_attribs.F90 b/ldt/params/soils/set_ZOBLER_GFS_texture_attribs.F90 index f85820d51..b4df44a3e 100644 --- a/ldt/params/soils/set_ZOBLER_GFS_texture_attribs.F90 +++ b/ldt/params/soils/set_ZOBLER_GFS_texture_attribs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/calc_SlopeAspect_module.F90 b/ldt/params/topo/calc_SlopeAspect_module.F90 index f68fc2841..3cdfcfb8f 100644 --- a/ldt/params/topo/calc_SlopeAspect_module.F90 +++ b/ldt/params/topo/calc_SlopeAspect_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_CONSTANT_aspect.F90 b/ldt/params/topo/read_CONSTANT_aspect.F90 index 5f2c0f754..82dc0e0b8 100644 --- a/ldt/params/topo/read_CONSTANT_aspect.F90 +++ b/ldt/params/topo/read_CONSTANT_aspect.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_CONSTANT_elev.F90 b/ldt/params/topo/read_CONSTANT_elev.F90 index f5491dfca..7829709e6 100644 --- a/ldt/params/topo/read_CONSTANT_elev.F90 +++ b/ldt/params/topo/read_CONSTANT_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_CONSTANT_slope.F90 b/ldt/params/topo/read_CONSTANT_slope.F90 index 5e534d55f..2934cb48c 100644 --- a/ldt/params/topo/read_CONSTANT_slope.F90 +++ b/ldt/params/topo/read_CONSTANT_slope.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30Native_elev.F90 b/ldt/params/topo/read_GTOPO30Native_elev.F90 index 3ea46ce0c..bbb5ba95d 100644 --- a/ldt/params/topo/read_GTOPO30Native_elev.F90 +++ b/ldt/params/topo/read_GTOPO30Native_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30_GFS_elev.F90 b/ldt/params/topo/read_GTOPO30_GFS_elev.F90 index 465de4bc8..0ab031b6c 100644 --- a/ldt/params/topo/read_GTOPO30_GFS_elev.F90 +++ b/ldt/params/topo/read_GTOPO30_GFS_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30_aspect.F90 b/ldt/params/topo/read_GTOPO30_aspect.F90 index 310941468..cf1e8cbe7 100644 --- a/ldt/params/topo/read_GTOPO30_aspect.F90 +++ b/ldt/params/topo/read_GTOPO30_aspect.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30_curv.F90 b/ldt/params/topo/read_GTOPO30_curv.F90 index 1f4162076..1cbbb3414 100644 --- a/ldt/params/topo/read_GTOPO30_curv.F90 +++ b/ldt/params/topo/read_GTOPO30_curv.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30_elev.F90 b/ldt/params/topo/read_GTOPO30_elev.F90 index cbdb83ee3..fd39d52f2 100644 --- a/ldt/params/topo/read_GTOPO30_elev.F90 +++ b/ldt/params/topo/read_GTOPO30_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_GTOPO30_slope.F90 b/ldt/params/topo/read_GTOPO30_slope.F90 index eae9a4e44..8b79e0944 100644 --- a/ldt/params/topo/read_GTOPO30_slope.F90 +++ b/ldt/params/topo/read_GTOPO30_slope.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_MERIT1K_aspect.F90 b/ldt/params/topo/read_MERIT1K_aspect.F90 index f9dfae9a5..0c2b64e2b 100755 --- a/ldt/params/topo/read_MERIT1K_aspect.F90 +++ b/ldt/params/topo/read_MERIT1K_aspect.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_MERIT1K_elev.F90 b/ldt/params/topo/read_MERIT1K_elev.F90 index f07170587..3ce0d8902 100755 --- a/ldt/params/topo/read_MERIT1K_elev.F90 +++ b/ldt/params/topo/read_MERIT1K_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_MERIT1K_slope.F90 b/ldt/params/topo/read_MERIT1K_slope.F90 index 916665b0c..f3afcb554 100755 --- a/ldt/params/topo/read_MERIT1K_slope.F90 +++ b/ldt/params/topo/read_MERIT1K_slope.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_NED_SM_aspect.F90 b/ldt/params/topo/read_NED_SM_aspect.F90 index 2e29f5293..63a6a53f9 100644 --- a/ldt/params/topo/read_NED_SM_aspect.F90 +++ b/ldt/params/topo/read_NED_SM_aspect.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- !BOP ! diff --git a/ldt/params/topo/read_NED_SM_curvature.F90 b/ldt/params/topo/read_NED_SM_curvature.F90 index 75a9fff7f..0b11ac5dd 100644 --- a/ldt/params/topo/read_NED_SM_curvature.F90 +++ b/ldt/params/topo/read_NED_SM_curvature.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- !BOP ! diff --git a/ldt/params/topo/read_NED_SM_elev.F90 b/ldt/params/topo/read_NED_SM_elev.F90 index 3c6299e77..c3c22cd7c 100644 --- a/ldt/params/topo/read_NED_SM_elev.F90 +++ b/ldt/params/topo/read_NED_SM_elev.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- !BOP ! diff --git a/ldt/params/topo/read_NED_SM_slope.F90 b/ldt/params/topo/read_NED_SM_slope.F90 index 3132195f2..454f302fd 100644 --- a/ldt/params/topo/read_NED_SM_slope.F90 +++ b/ldt/params/topo/read_NED_SM_slope.F90 @@ -1,5 +1,11 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA Goddard Space Flight Center Land Data Toolkit (LDT) v1.0 +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- !BOP ! diff --git a/ldt/params/topo/read_SRTM_Native_aspect.F90 b/ldt/params/topo/read_SRTM_Native_aspect.F90 index 63adb5b22..465c7057b 100644 --- a/ldt/params/topo/read_SRTM_Native_aspect.F90 +++ b/ldt/params/topo/read_SRTM_Native_aspect.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_SRTM_Native_elev.F90 b/ldt/params/topo/read_SRTM_Native_elev.F90 index 716c7391d..4d2c4649e 100644 --- a/ldt/params/topo/read_SRTM_Native_elev.F90 +++ b/ldt/params/topo/read_SRTM_Native_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_SRTM_Native_slope.F90 b/ldt/params/topo/read_SRTM_Native_slope.F90 index 948c47c1d..53a5df248 100644 --- a/ldt/params/topo/read_SRTM_Native_slope.F90 +++ b/ldt/params/topo/read_SRTM_Native_slope.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_SRTM_aspect.F90 b/ldt/params/topo/read_SRTM_aspect.F90 index 3aa03cef4..810e8d509 100644 --- a/ldt/params/topo/read_SRTM_aspect.F90 +++ b/ldt/params/topo/read_SRTM_aspect.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_SRTM_elev.F90 b/ldt/params/topo/read_SRTM_elev.F90 index 5356ebad2..94491f992 100644 --- a/ldt/params/topo/read_SRTM_elev.F90 +++ b/ldt/params/topo/read_SRTM_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/read_SRTM_slope.F90 b/ldt/params/topo/read_SRTM_slope.F90 index 97e339329..6a43744f1 100644 --- a/ldt/params/topo/read_SRTM_slope.F90 +++ b/ldt/params/topo/read_SRTM_slope.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/params/topo/setTopoParmsFullnames.F90 b/ldt/params/topo/setTopoParmsFullnames.F90 index f2b8c4c4d..14bd5ec75 100644 --- a/ldt/params/topo/setTopoParmsFullnames.F90 +++ b/ldt/params/topo/setTopoParmsFullnames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_ANNdata_pluginMod.F90 b/ldt/plugins/LDT_ANNdata_pluginMod.F90 index 1fd4d77b4..e632decd5 100644 --- a/ldt/plugins/LDT_ANNdata_pluginMod.F90 +++ b/ldt/plugins/LDT_ANNdata_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_DAobs_pluginMod.F90 b/ldt/plugins/LDT_DAobs_pluginMod.F90 index 105b70d7c..cc4779936 100644 --- a/ldt/plugins/LDT_DAobs_pluginMod.F90 +++ b/ldt/plugins/LDT_DAobs_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_NatureRunData_pluginMod.F90 b/ldt/plugins/LDT_NatureRunData_pluginMod.F90 index 84f1b008a..fed5ca096 100644 --- a/ldt/plugins/LDT_NatureRunData_pluginMod.F90 +++ b/ldt/plugins/LDT_NatureRunData_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_OSSEmaskData_pluginMod.F90 b/ldt/plugins/LDT_OSSEmaskData_pluginMod.F90 index 6ca256e08..5fef95fc1 100644 --- a/ldt/plugins/LDT_OSSEmaskData_pluginMod.F90 +++ b/ldt/plugins/LDT_OSSEmaskData_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_domain_pluginMod.F90 b/ldt/plugins/LDT_domain_pluginMod.F90 index e4262b829..39f06bc87 100644 --- a/ldt/plugins/LDT_domain_pluginMod.F90 +++ b/ldt/plugins/LDT_domain_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_metforcScale_pluginMod.F90 b/ldt/plugins/LDT_metforcScale_pluginMod.F90 index feda65403..f8477c05f 100644 --- a/ldt/plugins/LDT_metforcScale_pluginMod.F90 +++ b/ldt/plugins/LDT_metforcScale_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_metforcing_pluginMod.F90 b/ldt/plugins/LDT_metforcing_pluginMod.F90 index 012a62bc7..c056981e6 100644 --- a/ldt/plugins/LDT_metforcing_pluginMod.F90 +++ b/ldt/plugins/LDT_metforcing_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_param_pluginMod.F90 b/ldt/plugins/LDT_param_pluginMod.F90 index 1982e4d54..e8c37add0 100644 --- a/ldt/plugins/LDT_param_pluginMod.F90 +++ b/ldt/plugins/LDT_param_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_pluginIndices.F90 b/ldt/plugins/LDT_pluginIndices.F90 index 3d2c4f8eb..42cb0c232 100644 --- a/ldt/plugins/LDT_pluginIndices.F90 +++ b/ldt/plugins/LDT_pluginIndices.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_runmode_pluginMod.F90 b/ldt/plugins/LDT_runmode_pluginMod.F90 index dc9165e1b..c2675f487 100644 --- a/ldt/plugins/LDT_runmode_pluginMod.F90 +++ b/ldt/plugins/LDT_runmode_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/plugins/LDT_statDscale_pluginMod.F90 b/ldt/plugins/LDT_statDscale_pluginMod.F90 index 9786a64bf..ef249b501 100644 --- a/ldt/plugins/LDT_statDscale_pluginMod.F90 +++ b/ldt/plugins/LDT_statDscale_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/ANNproc/LDT_init_ANNproc.F90 b/ldt/runmodes/ANNproc/LDT_init_ANNproc.F90 index 34977ce75..6ef7224bd 100644 --- a/ldt/runmodes/ANNproc/LDT_init_ANNproc.F90 +++ b/ldt/runmodes/ANNproc/LDT_init_ANNproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/ANNproc/LDT_run_ANNproc.F90 b/ldt/runmodes/ANNproc/LDT_run_ANNproc.F90 index c3f86c75c..a095c87cc 100644 --- a/ldt/runmodes/ANNproc/LDT_run_ANNproc.F90 +++ b/ldt/runmodes/ANNproc/LDT_run_ANNproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/DApreproc/LDT_init_DApreproc.F90 b/ldt/runmodes/DApreproc/LDT_init_DApreproc.F90 index bda808686..ac34a7262 100644 --- a/ldt/runmodes/DApreproc/LDT_init_DApreproc.F90 +++ b/ldt/runmodes/DApreproc/LDT_init_DApreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/DApreproc/LDT_run_DApreproc.F90 b/ldt/runmodes/DApreproc/LDT_run_DApreproc.F90 index d0620c73a..7bf3ee77b 100644 --- a/ldt/runmodes/DApreproc/LDT_run_DApreproc.F90 +++ b/ldt/runmodes/DApreproc/LDT_run_DApreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/EnsRstpreproc/LDT_init_EnsRstpreproc.F90 b/ldt/runmodes/EnsRstpreproc/LDT_init_EnsRstpreproc.F90 index 8f01dfd24..aa3ad1ecc 100644 --- a/ldt/runmodes/EnsRstpreproc/LDT_init_EnsRstpreproc.F90 +++ b/ldt/runmodes/EnsRstpreproc/LDT_init_EnsRstpreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/EnsRstpreproc/LDT_run_EnsRstpreproc.F90 b/ldt/runmodes/EnsRstpreproc/LDT_run_EnsRstpreproc.F90 index a7e6f1d73..710adcf4c 100644 --- a/ldt/runmodes/EnsRstpreproc/LDT_run_EnsRstpreproc.F90 +++ b/ldt/runmodes/EnsRstpreproc/LDT_run_EnsRstpreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/LISHydropreproc/LDT_init_LISHydropreproc.F90 b/ldt/runmodes/LISHydropreproc/LDT_init_LISHydropreproc.F90 index aacabd3a1..8db60c1ae 100755 --- a/ldt/runmodes/LISHydropreproc/LDT_init_LISHydropreproc.F90 +++ b/ldt/runmodes/LISHydropreproc/LDT_init_LISHydropreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/LISHydropreproc/LDT_run_LISHydropreproc.F90 b/ldt/runmodes/LISHydropreproc/LDT_run_LISHydropreproc.F90 index c7aaede87..407259498 100755 --- a/ldt/runmodes/LISHydropreproc/LDT_run_LISHydropreproc.F90 +++ b/ldt/runmodes/LISHydropreproc/LDT_run_LISHydropreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/LSMparamproc/LDT_init_LSMparamproc.F90 b/ldt/runmodes/LSMparamproc/LDT_init_LSMparamproc.F90 index 629a9292c..886b4c15b 100644 --- a/ldt/runmodes/LSMparamproc/LDT_init_LSMparamproc.F90 +++ b/ldt/runmodes/LSMparamproc/LDT_init_LSMparamproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/LSMparamproc/LDT_run_LSMparamproc.F90 b/ldt/runmodes/LSMparamproc/LDT_run_LSMparamproc.F90 index a16eef36b..a16548899 100644 --- a/ldt/runmodes/LSMparamproc/LDT_run_LSMparamproc.F90 +++ b/ldt/runmodes/LSMparamproc/LDT_run_LSMparamproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/MetTimeDScale/LDT_init_MetTimeDScale.F90 b/ldt/runmodes/MetTimeDScale/LDT_init_MetTimeDScale.F90 index 70a67d6fe..15f24be52 100644 --- a/ldt/runmodes/MetTimeDScale/LDT_init_MetTimeDScale.F90 +++ b/ldt/runmodes/MetTimeDScale/LDT_init_MetTimeDScale.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/MetTimeDScale/LDT_run_MetTimeDScale.F90 b/ldt/runmodes/MetTimeDScale/LDT_run_MetTimeDScale.F90 index b76bc3093..46ddff60f 100644 --- a/ldt/runmodes/MetTimeDScale/LDT_run_MetTimeDScale.F90 +++ b/ldt/runmodes/MetTimeDScale/LDT_run_MetTimeDScale.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/Metforcproc/LDT_final_MetforcProc.F90 b/ldt/runmodes/Metforcproc/LDT_final_MetforcProc.F90 index 068c5f035..eb04064fa 100644 --- a/ldt/runmodes/Metforcproc/LDT_final_MetforcProc.F90 +++ b/ldt/runmodes/Metforcproc/LDT_final_MetforcProc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/Metforcproc/LDT_init_MetforcProc.F90 b/ldt/runmodes/Metforcproc/LDT_init_MetforcProc.F90 index 49b79c7d7..4d552886b 100644 --- a/ldt/runmodes/Metforcproc/LDT_init_MetforcProc.F90 +++ b/ldt/runmodes/Metforcproc/LDT_init_MetforcProc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/Metforcproc/LDT_run_MetforcProc.F90 b/ldt/runmodes/Metforcproc/LDT_run_MetforcProc.F90 index 6d58ad428..63c5c361f 100644 --- a/ldt/runmodes/Metforcproc/LDT_run_MetforcProc.F90 +++ b/ldt/runmodes/Metforcproc/LDT_run_MetforcProc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/NUWRFpreproc/LDT_init_NUWRFpreproc.F90 b/ldt/runmodes/NUWRFpreproc/LDT_init_NUWRFpreproc.F90 index 1d56a1135..16cdad526 100644 --- a/ldt/runmodes/NUWRFpreproc/LDT_init_NUWRFpreproc.F90 +++ b/ldt/runmodes/NUWRFpreproc/LDT_init_NUWRFpreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/NUWRFpreproc/LDT_run_NUWRFpreproc.F90 b/ldt/runmodes/NUWRFpreproc/LDT_run_NUWRFpreproc.F90 index 207b8d988..af98950fe 100644 --- a/ldt/runmodes/NUWRFpreproc/LDT_run_NUWRFpreproc.F90 +++ b/ldt/runmodes/NUWRFpreproc/LDT_run_NUWRFpreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/OPTUEproc/LDT_init_OPTUEparamproc.F90 b/ldt/runmodes/OPTUEproc/LDT_init_OPTUEparamproc.F90 index edcaea468..5cae0f270 100644 --- a/ldt/runmodes/OPTUEproc/LDT_init_OPTUEparamproc.F90 +++ b/ldt/runmodes/OPTUEproc/LDT_init_OPTUEparamproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/OPTUEproc/LDT_run_OPTUEparamproc.F90 b/ldt/runmodes/OPTUEproc/LDT_run_OPTUEparamproc.F90 index ed7f65dc1..abca8e8f9 100644 --- a/ldt/runmodes/OPTUEproc/LDT_run_OPTUEparamproc.F90 +++ b/ldt/runmodes/OPTUEproc/LDT_run_OPTUEparamproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/SMAP_E_OPL/LDT_init_smap_e_opl.F90 b/ldt/runmodes/SMAP_E_OPL/LDT_init_smap_e_opl.F90 index b1b95f6fe..fe2eeefdc 100644 --- a/ldt/runmodes/SMAP_E_OPL/LDT_init_smap_e_opl.F90 +++ b/ldt/runmodes/SMAP_E_OPL/LDT_init_smap_e_opl.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/SMAP_E_OPL/LDT_run_smap_e_opl.F90 b/ldt/runmodes/SMAP_E_OPL/LDT_run_smap_e_opl.F90 index 5dc1e95d2..4d09a29c2 100644 --- a/ldt/runmodes/SMAP_E_OPL/LDT_run_smap_e_opl.F90 +++ b/ldt/runmodes/SMAP_E_OPL/LDT_run_smap_e_opl.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/StatDscaleMetForc/LDT_init_StatDscaleMetForc.F90 b/ldt/runmodes/StatDscaleMetForc/LDT_init_StatDscaleMetForc.F90 index 77341f045..b6c7e4900 100644 --- a/ldt/runmodes/StatDscaleMetForc/LDT_init_StatDscaleMetForc.F90 +++ b/ldt/runmodes/StatDscaleMetForc/LDT_init_StatDscaleMetForc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/StatDscaleMetForc/LDT_run_StatDscaleMetForc.F90 b/ldt/runmodes/StatDscaleMetForc/LDT_run_StatDscaleMetForc.F90 index ce6b0e1b5..223c922fb 100644 --- a/ldt/runmodes/StatDscaleMetForc/LDT_run_StatDscaleMetForc.F90 +++ b/ldt/runmodes/StatDscaleMetForc/LDT_run_StatDscaleMetForc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/USAFSI/LDT_init_usafsi.F90 b/ldt/runmodes/USAFSI/LDT_init_usafsi.F90 index de2f0ac61..18e27116f 100644 --- a/ldt/runmodes/USAFSI/LDT_init_usafsi.F90 +++ b/ldt/runmodes/USAFSI/LDT_init_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/USAFSI/LDT_run_usafsi.F90 b/ldt/runmodes/USAFSI/LDT_run_usafsi.F90 index c400d15df..b82ea1690 100644 --- a/ldt/runmodes/USAFSI/LDT_run_usafsi.F90 +++ b/ldt/runmodes/USAFSI/LDT_run_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/climoRstproc/LDT_init_climoRstproc.F90 b/ldt/runmodes/climoRstproc/LDT_init_climoRstproc.F90 index 830a493b9..f6b6c375c 100755 --- a/ldt/runmodes/climoRstproc/LDT_init_climoRstproc.F90 +++ b/ldt/runmodes/climoRstproc/LDT_init_climoRstproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/climoRstproc/LDT_run_climoRstproc.F90 b/ldt/runmodes/climoRstproc/LDT_run_climoRstproc.F90 index 936069477..8ae5fb4d9 100755 --- a/ldt/runmodes/climoRstproc/LDT_run_climoRstproc.F90 +++ b/ldt/runmodes/climoRstproc/LDT_run_climoRstproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/obsSim/LDT_init_obsSim.F90 b/ldt/runmodes/obsSim/LDT_init_obsSim.F90 index a65c33ad6..61a711bb0 100644 --- a/ldt/runmodes/obsSim/LDT_init_obsSim.F90 +++ b/ldt/runmodes/obsSim/LDT_init_obsSim.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/obsSim/LDT_run_obsSim.F90 b/ldt/runmodes/obsSim/LDT_run_obsSim.F90 index 9aa39cea3..86e172528 100644 --- a/ldt/runmodes/obsSim/LDT_run_obsSim.F90 +++ b/ldt/runmodes/obsSim/LDT_run_obsSim.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/rstTransformProc/LDT_init_rstTransformProc.F90 b/ldt/runmodes/rstTransformProc/LDT_init_rstTransformProc.F90 index 65e8ace94..cc1448c25 100644 --- a/ldt/runmodes/rstTransformProc/LDT_init_rstTransformProc.F90 +++ b/ldt/runmodes/rstTransformProc/LDT_init_rstTransformProc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/runmodes/rstTransformProc/LDT_run_rstTransformProc.F90 b/ldt/runmodes/rstTransformProc/LDT_run_rstTransformProc.F90 index e1bf70bdf..568c9ea4f 100644 --- a/ldt/runmodes/rstTransformProc/LDT_run_rstTransformProc.F90 +++ b/ldt/runmodes/rstTransformProc/LDT_run_rstTransformProc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/statDscale/BayesianMerging/BayesianMergingMod.F90 b/ldt/statDscale/BayesianMerging/BayesianMergingMod.F90 index e4e91e01e..08518f46e 100644 --- a/ldt/statDscale/BayesianMerging/BayesianMergingMod.F90 +++ b/ldt/statDscale/BayesianMerging/BayesianMergingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/ldt/statDscale/Climo/forcingClimoMod.F90 b/ldt/statDscale/Climo/forcingClimoMod.F90 index 288870744..2d474f0b7 100644 --- a/ldt/statDscale/Climo/forcingClimoMod.F90 +++ b/ldt/statDscale/Climo/forcingClimoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- From 658497e66db9c1690f58d6b96bc88d211cdf0eb7 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 2 Jan 2024 13:08:21 -0500 Subject: [PATCH 257/328] Delete backup file --- ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ | 15 --------------- 1 file changed, 15 deletions(-) delete mode 100644 ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ diff --git a/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ b/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ deleted file mode 100644 index 8a261ad3b..000000000 --- a/ldt/testcases/DAobs_SMAP_pclimo_transfer/README~ +++ /dev/null @@ -1,15 +0,0 @@ -LSM Soil Moisture Test Case for Precip Climo and Relocating CDFs - -This testcase processes LIS LSM data (Noah.4.0.1) to generate a CDF. - -This directory contains: - -* This README file. -* The ldt.config file used for this test case. (This file should be - edited to make sure that the locations of the parameter and forcing - files are specified correctly.) - -To run this test case: -* Generate the LDT executable. -* Run the LDT executable using the ldt.config file and the sample input - data. From d239fba6df31603a8eec5176507ce6b4ca51cdab Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 2 Jan 2024 13:32:27 -0500 Subject: [PATCH 258/328] Update copyright notice on LVT files for LISF 7.5.0 public release --- lvt/arch/Config.pl | 4 ++-- lvt/compile | 4 ++-- lvt/configure | 4 ++-- lvt/core/FTable.c | 4 ++-- lvt/core/FTable.h | 4 ++-- lvt/core/LVT_CIMod.F90 | 4 ++-- lvt/core/LVT_DAMod.F90 | 4 ++-- lvt/core/LVT_DataStreamsMod.F90 | 4 ++-- lvt/core/LVT_InformationContentMod.F90 | 4 ++-- lvt/core/LVT_LISoutputHandlerMod.F90 | 4 ++-- lvt/core/LVT_LISpostMod.F90 | 4 ++-- lvt/core/LVT_LMLCMod.F90 | 4 ++-- lvt/core/LVT_NumericalRecipesMod.F90 | 4 ++-- lvt/core/LVT_PRIV_gridMod.F90 | 4 ++-- lvt/core/LVT_PRIV_rcMod.F90 | 4 ++-- lvt/core/LVT_PRIV_tileMod.F90 | 4 ++-- lvt/core/LVT_SortingMod.F90 | 4 ++-- lvt/core/LVT_StratStatsMod.F90 | 4 ++-- lvt/core/LVT_String_Utility.F90 | 4 ++-- lvt/core/LVT_TSMod.F90 | 4 ++-- lvt/core/LVT_constantsMod.F90 | 4 ++-- lvt/core/LVT_coreMod.F90 | 4 ++-- lvt/core/LVT_create_subdirs.c | 4 ++-- lvt/core/LVT_domainMod.F90 | 4 ++-- lvt/core/LVT_domain_FTable.c | 4 ++-- lvt/core/LVT_fileIOMod.F90 | 4 ++-- lvt/core/LVT_getADCIndex.F90 | 4 ++-- lvt/core/LVT_getSeasonalCycleIndex.F90 | 4 ++-- lvt/core/LVT_histDataMod.F90 | 4 ++-- lvt/core/LVT_historyMod.F90 | 4 ++-- lvt/core/LVT_logMod.F90 | 4 ++-- lvt/core/LVT_mapSurfaceModelType.F90 | 4 ++-- lvt/core/LVT_metric_FTable.c | 4 ++-- lvt/core/LVT_mpDecomp.c | 4 ++-- lvt/core/LVT_mpiMod.F90 | 4 ++-- lvt/core/LVT_navgemMod.F90 | 4 ++-- lvt/core/LVT_obs_FTable.c | 4 ++-- lvt/core/LVT_optUEMod.F90 | 4 ++-- lvt/core/LVT_readConfig.F90 | 4 ++-- lvt/core/LVT_readMetricsAttributes.F90 | 4 ++-- lvt/core/LVT_runmode_FTable.c | 4 ++-- lvt/core/LVT_soilsMod.F90 | 4 ++-- lvt/core/LVT_statsDataMod.F90 | 4 ++-- lvt/core/LVT_statsMod.F90 | 4 ++-- lvt/core/LVT_timeMgrMod.F90 | 4 ++-- lvt/core/LVT_topoMod.F90 | 4 ++-- lvt/core/LVT_trainingMod.F90 | 4 ++-- lvt/core/LVT_training_FTable.c | 4 ++-- lvt/core/bak/LVT_DataStream1Mod.F90 | 4 ++-- lvt/core/bak/LVT_DataStream2Mod.F90 | 4 ++-- lvt/datastreams/3B42V7/TRMM3B42V7_dataMod.F90 | 4 ++-- lvt/datastreams/3B42V7/readTRMM3B42V7data.F90 | 4 ++-- lvt/datastreams/AGRMET/AGRMET_dataMod.F90 | 4 ++-- lvt/datastreams/AGRMET/readAGRMETdata.F90 | 4 ++-- lvt/datastreams/ALEXI/ALEXI_obsMod.F90 | 4 ++-- lvt/datastreams/ALEXI/readALEXIObs.F90 | 4 ++-- lvt/datastreams/ALEXIesi/ALEXIesi_obsMod.F90 | 4 ++-- lvt/datastreams/ALEXIesi/readALEXIesiObs.F90 | 4 ++-- lvt/datastreams/ANSA_SNWD/ANSASNWD_obsMod.F90 | 4 ++-- lvt/datastreams/ANSA_SNWD/readANSASNWDobs.F90 | 4 ++-- lvt/datastreams/ANSA_SWE/ANSASWE_obsMod.F90 | 4 ++-- lvt/datastreams/ANSA_SWE/readANSASWEobs.F90 | 4 ++-- lvt/datastreams/APHRO_PRCP/APHROPRCP_obsMod.F90 | 4 ++-- lvt/datastreams/APHRO_PRCP/readAPHROPRCPObs.F90 | 4 ++-- lvt/datastreams/ARM/ARM_obsMod.F90 | 4 ++-- lvt/datastreams/ARM/readARMObs.F90 | 4 ++-- lvt/datastreams/ARSsm/ARSsm_obsMod.F90 | 4 ++-- lvt/datastreams/ARSsm/readARSsmobs.F90 | 4 ++-- lvt/datastreams/ASO_SWE/ASOSWE_obsMod.F90 | 4 ++-- lvt/datastreams/ASO_SWE/readASOSWEobs.F90 | 4 ++-- lvt/datastreams/Ameriflux/Ameriflux_obsMod.F90 | 4 ++-- lvt/datastreams/Ameriflux/readAmerifluxObs.F90 | 4 ++-- lvt/datastreams/CEOP/CEOP_obsMod.F90 | 4 ++-- lvt/datastreams/CEOP/readCEOP.F90 | 4 ++-- lvt/datastreams/CHIRPSv2/CHIRPSv2_dataMod.F90 | 4 ++-- lvt/datastreams/CHIRPSv2/readCHIRPSv2data.F90 | 4 ++-- lvt/datastreams/CMC_SNWD/CMCSNWD_obsMod.F90 | 4 ++-- lvt/datastreams/CMC_SNWD/readCMC_SNWDObs.F90 | 4 ++-- lvt/datastreams/CMORPH/CMORPH_dataMod.F90 | 4 ++-- lvt/datastreams/CMORPH/readCMORPHdata.F90 | 4 ++-- lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 | 4 ++-- lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 | 4 ++-- lvt/datastreams/CPC_PRCP/CPCPRCP_obsMod.F90 | 4 ++-- lvt/datastreams/CPC_PRCP/readCPCPRCPObs.F90 | 4 ++-- lvt/datastreams/Daymet/Daymet_obsMod.F90 | 4 ++-- lvt/datastreams/Daymet/readDaymetObs.F90 | 4 ++-- lvt/datastreams/ECMWFforc/ECMWFforc_dataMod.F90 | 4 ++-- lvt/datastreams/ECMWFforc/readECMWFforcdata.F90 | 4 ++-- lvt/datastreams/ERA5/ERA5obsMod.F90 | 4 ++-- lvt/datastreams/ERA5/readERA5obs.F90 | 4 ++-- lvt/datastreams/ERAinterimLand/ERAinterimLandobsMod.F90 | 4 ++-- lvt/datastreams/ERAinterimLand/readERAinterimLandobs.F90 | 4 ++-- lvt/datastreams/ESACCI_sm/ESACCIsm_obsMod.F90 | 4 ++-- lvt/datastreams/ESACCI_sm/readESACCIsmObs.F90 | 4 ++-- lvt/datastreams/FLUXCOM/FLUXCOM_obsMod.F90 | 4 ++-- lvt/datastreams/FLUXCOM/readFLUXCOMobs.F90 | 4 ++-- lvt/datastreams/FLUXNET2015/FLUXNET2015_obsMod.F90 | 4 ++-- lvt/datastreams/FLUXNET2015/readFLUXNET2015Obs.F90 | 4 ++-- lvt/datastreams/FLUXNET2015_NC/FLUXNET2015NC_obsMod.F90 | 4 ++-- lvt/datastreams/FLUXNET2015_NC/readFLUXNET2015NCObs.F90 | 4 ++-- lvt/datastreams/FLUXNETmte/FLUXNETmte_obsMod.F90 | 4 ++-- lvt/datastreams/FLUXNETmte/readFLUXNETmteObs.F90 | 4 ++-- lvt/datastreams/FMI_SWE/FMISWE_obsMod.F90 | 4 ++-- lvt/datastreams/FMI_SWE/readFMISWEobs.F90 | 4 ++-- lvt/datastreams/FluxSat_GPP/FluxSat_obsMod.F90 | 4 ++-- lvt/datastreams/FluxSat_GPP/readFluxSatobs.F90 | 4 ++-- lvt/datastreams/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 | 4 ++-- lvt/datastreams/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 | 4 ++-- lvt/datastreams/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 | 4 ++-- lvt/datastreams/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 | 4 ++-- lvt/datastreams/GDASforc/GDASforc_dataMod.F90 | 4 ++-- lvt/datastreams/GDASforc/readGDASforcdata.F90 | 4 ++-- lvt/datastreams/GHCN/GHCN_obsMod.F90 | 4 ++-- lvt/datastreams/GHCN/readGHCNObs.F90 | 4 ++-- lvt/datastreams/GIMMS_AVHRR_NDVI/GIMMSAVHRR_NDVIobsMod.F90 | 4 ++-- lvt/datastreams/GIMMS_AVHRR_NDVI/readGIMMSAVHRR_NDVIObs.F90 | 4 ++-- lvt/datastreams/GIMMS_MODIS_NDVI/GIMMSMODIS_NDVIobsMod.F90 | 4 ++-- lvt/datastreams/GIMMS_MODIS_NDVI/readGIMMSMODIS_NDVIObs.F90 | 4 ++-- lvt/datastreams/GLASSalbedo/GLASSalbedo_Mod.F90 | 4 ++-- lvt/datastreams/GLASSalbedo/readGLASSalbedoObs.F90 | 4 ++-- lvt/datastreams/GLASSlai/GLASSlai_obsMod.F90 | 4 ++-- lvt/datastreams/GLASSlai/readGLASSlaiObs.F90 | 4 ++-- lvt/datastreams/GLDAS1/GLDAS1obsMod.F90 | 4 ++-- lvt/datastreams/GLDAS1/readGLDAS1obs.F90 | 4 ++-- lvt/datastreams/GLDAS2/GLDAS2obsMod.F90 | 4 ++-- lvt/datastreams/GLDAS2/readGLDAS2obs.F90 | 4 ++-- lvt/datastreams/GLEAM/GLEAM_obsMod.F90 | 4 ++-- lvt/datastreams/GLEAM/readGLEAMObs.F90 | 4 ++-- lvt/datastreams/GLERL_HydroData/GLERL_dataMod.F90 | 4 ++-- lvt/datastreams/GLERL_HydroData/readGLERLobs.F90 | 4 ++-- lvt/datastreams/GOES_LST/GOES_LSTobsMod.F90 | 4 ++-- lvt/datastreams/GOES_LST/readGOES_LSTObs.F90 | 4 ++-- lvt/datastreams/GOME2_SIF/GOME2_SIFobsMod.F90 | 4 ++-- lvt/datastreams/GOME2_SIF/readGOME2_SIFObs.F90 | 4 ++-- lvt/datastreams/GRACE/GRACE_obsMod.F90 | 4 ++-- lvt/datastreams/GRACE/readGRACEObs.F90 | 4 ++-- lvt/datastreams/GRDC/GRDC_obsMod.F90 | 4 ++-- lvt/datastreams/GRDC/readGRDCobs.F90 | 4 ++-- lvt/datastreams/GRUNrunoff/GRUNrunoff_obsMod.F90 | 4 ++-- lvt/datastreams/GRUNrunoff/readGRUNrunoffobs.F90 | 4 ++-- lvt/datastreams/GlobSnow/GlobSnow_obsMod.F90 | 4 ++-- lvt/datastreams/GlobSnow/readGlobSnowObs.F90 | 4 ++-- lvt/datastreams/HAR/HAR_dataMod.F90 | 4 ++-- lvt/datastreams/HAR/readHARdata.F90 | 4 ++-- lvt/datastreams/IMD_PRCP/IMDPRCP_obsMod.F90 | 4 ++-- lvt/datastreams/IMD_PRCP/readIMDPRCPObs.F90 | 4 ++-- lvt/datastreams/IMERG/IMERG_dataMod.F90 | 4 ++-- lvt/datastreams/IMERG/readIMERGdata.F90 | 4 ++-- lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 | 4 ++-- lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 | 4 ++-- lvt/datastreams/ISCCP_Tskin/ISCCP_TskinobsMod.F90 | 4 ++-- lvt/datastreams/ISCCP_Tskin/readISCCP_TskinObs.F90 | 4 ++-- lvt/datastreams/ISMN/ISMN_obsMod.F90 | 4 ++-- lvt/datastreams/ISMN/readISMNObs.F90 | 4 ++-- lvt/datastreams/JULES2Ddata/JULES2D_obsMod.F90 | 4 ++-- lvt/datastreams/JULES2Ddata/readJULES2Dobs.F90 | 4 ++-- lvt/datastreams/JULESdata/JULES_obsMod.F90 | 4 ++-- lvt/datastreams/JULESdata/readJULESobs.F90 | 4 ++-- lvt/datastreams/LIS6out/LIS6outputMod.F90 | 4 ++-- lvt/datastreams/LIS6out/readLIS6output.F90 | 4 ++-- lvt/datastreams/LISDAdiag/LISDAdiagOutputMod.F90 | 4 ++-- lvt/datastreams/LISDAdiag/readLISDAdiagOutput.F90 | 4 ++-- lvt/datastreams/LISDAobs/LISda_obsMod.F90 | 4 ++-- lvt/datastreams/LISDAobs/readLISdaAsObs.F90 | 4 ++-- lvt/datastreams/LISout/LISoutputMod.F90 | 4 ++-- lvt/datastreams/LISout/readLISoutput.F90 | 4 ++-- lvt/datastreams/LPRM_AMSRE_sm/LPRM_AMSREsm_obsMod.F90 | 4 ++-- lvt/datastreams/LPRM_AMSRE_sm/readLPRM_AMSREsmObs.F90 | 4 ++-- lvt/datastreams/LPRMvod/LPRM_vodobsMod.F90 | 4 ++-- lvt/datastreams/LPRMvod/readLPRMvodobs.F90 | 4 ++-- lvt/datastreams/LSWG_Tb/LSWG_Tb_obsMod.F90 | 4 ++-- lvt/datastreams/LSWG_Tb/read_LSWG_Tb_Obs.F90 | 4 ++-- lvt/datastreams/LVTbenchmarkOUT/LVTbenchmarkOUT_obsMod.F90 | 4 ++-- lvt/datastreams/LVTbenchmarkOUT/readLVTbenchmarkOUTobs.F90 | 4 ++-- lvt/datastreams/LVTpercentile/LVTpercentile_obsMod.F90 | 4 ++-- lvt/datastreams/LVTpercentile/readLVTpercentileAsObs.F90 | 4 ++-- lvt/datastreams/MCD15A2H/MCD15A2H_obsMod.F90 | 4 ++-- lvt/datastreams/MCD15A2H/readMCD15A2Hobs.F90 | 4 ++-- lvt/datastreams/MERRA-Land/MERRAlandObsMod.F90 | 4 ++-- lvt/datastreams/MERRA-Land/readMERRAlandObs.F90 | 4 ++-- lvt/datastreams/MERRA2/MERRA2obsMod.F90 | 4 ++-- lvt/datastreams/MERRA2/readMERRA2obs.F90 | 4 ++-- lvt/datastreams/MERRA2asm/MERRA2asmobsMod.F90 | 4 ++-- lvt/datastreams/MERRA2asm/readMERRA2asmobs.F90 | 4 ++-- lvt/datastreams/MOD10A1/MOD10A1_obsMod.F90 | 4 ++-- lvt/datastreams/MOD10A1/readMOD10A1obs.F90 | 4 ++-- lvt/datastreams/MOD10A1V6/MOD10A1V6_obsMod.F90 | 4 ++-- lvt/datastreams/MOD10A1V6/readMOD10A1V6obs.F90 | 4 ++-- lvt/datastreams/MOD16A2/MOD16A2_obsMod.F90 | 4 ++-- lvt/datastreams/MOD16A2/readMOD16A2Obs.F90 | 4 ++-- lvt/datastreams/MODIS_LST/MODIS_LSTobsMod.F90 | 4 ++-- lvt/datastreams/MODIS_LST/readMODIS_LSTObs.F90 | 4 ++-- lvt/datastreams/MODISsportLAI/MODISsportLAIobsMod.F90 | 4 ++-- lvt/datastreams/MODISsportLAI/readMODISsportLAIObs.F90 | 4 ++-- lvt/datastreams/MODSCAG/MODSCAG_obsMod.F90 | 4 ++-- lvt/datastreams/MODSCAG/readMODSCAGobs.F90 | 4 ++-- lvt/datastreams/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 | 4 ++-- lvt/datastreams/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 | 4 ++-- lvt/datastreams/NASMD/NASMD_obsMod.F90 | 4 ++-- lvt/datastreams/NASMD/readNASMDObs.F90 | 4 ++-- lvt/datastreams/NLDAS2/NLDAS2_dataMod.F90 | 4 ++-- lvt/datastreams/NLDAS2/readNLDAS2data.F90 | 4 ++-- lvt/datastreams/Natural_streamflow/NatSF_obsMod.F90 | 4 ++-- lvt/datastreams/Natural_streamflow/readNatSFObs.F90 | 4 ++-- lvt/datastreams/OCO2_SIF/OCO2_SIFobsMod.F90 | 4 ++-- lvt/datastreams/OCO2_SIF/readOCO2_SIFObs.F90 | 4 ++-- lvt/datastreams/OzFlux/OzFlux_obsMod.F90 | 4 ++-- lvt/datastreams/OzFlux/readOzFluxObs.F90 | 4 ++-- lvt/datastreams/PBOH2O/PBOH2O_obsMod.F90 | 4 ++-- lvt/datastreams/PBOH2O/readPBOH2Oobs.F90 | 4 ++-- lvt/datastreams/SCAN/SCAN_obsMod.F90 | 4 ++-- lvt/datastreams/SCAN/readSCANObs.F90 | 4 ++-- lvt/datastreams/SCANGMAO/SCANGMAO_obsMod.F90 | 4 ++-- lvt/datastreams/SCANGMAO/readSCANGMAOObs.F90 | 4 ++-- lvt/datastreams/SMAPTB/SMAP_TBobsMod.F90 | 4 ++-- lvt/datastreams/SMAPTB/readSMAPTBobs.F90 | 4 ++-- lvt/datastreams/SMAP_E_OPL/SMAPEOPL_SM_obsMod.F90 | 2 +- lvt/datastreams/SMAP_E_OPL/readSMAPEOPL_SMObs.F90 | 2 +- lvt/datastreams/SMAP_L3TB/SMAP_L3TBMod.F90 | 4 ++-- lvt/datastreams/SMAP_L3TB/readSMAP_L3TB.F90 | 4 ++-- lvt/datastreams/SMAPsm/SMAP_smobsMod.F90 | 4 ++-- lvt/datastreams/SMAPsm/readSMAPsmobs.F90 | 4 ++-- lvt/datastreams/SMAPvod/SMAP_vodobsMod.F90 | 4 ++-- lvt/datastreams/SMAPvod/readSMAPvodobs.F90 | 4 ++-- lvt/datastreams/SMAPvwc/SMAP_vwcobsMod.F90 | 4 ++-- lvt/datastreams/SMAPvwc/readSMAPvwcobs.F90 | 4 ++-- lvt/datastreams/SMOPS/SMOPSsm_obsMod.F90 | 4 ++-- lvt/datastreams/SMOPS/readSMOPSsmObs.F90 | 4 ++-- lvt/datastreams/SMOSREX/SMOSREX_obsMod.F90 | 4 ++-- lvt/datastreams/SMOSREX/readSMOSREXObs.F90 | 4 ++-- lvt/datastreams/SMOS_CATDS_L3sm/SMOSCATDS_smobsMod.F90 | 4 ++-- lvt/datastreams/SMOS_CATDS_L3sm/readSMOSCATDSsmobs.F90 | 4 ++-- lvt/datastreams/SMOS_L1TB/SMOSL1TB_obsMod.F90 | 4 ++-- lvt/datastreams/SMOS_L1TB/readSMOSL1TBObs.F90 | 4 ++-- lvt/datastreams/SMOS_L2sm/SMOSL2sm_obsMod.F90 | 4 ++-- lvt/datastreams/SMOS_L2sm/readSMOSL2smObs.F90 | 4 ++-- lvt/datastreams/SMOS_NESDIS/SMOSNESDIS_smobsMod.F90 | 4 ++-- lvt/datastreams/SMOS_NESDIS/readSMOSNESDISsmobs.F90 | 4 ++-- lvt/datastreams/SNODAS/SNODAS_obsMod.F90 | 4 ++-- lvt/datastreams/SNODAS/readSNODASObs.F90 | 4 ++-- lvt/datastreams/SNODEP/SNODEP_obsMod.F90 | 4 ++-- lvt/datastreams/SNODEP/readSNODEPobs.F90 | 4 ++-- lvt/datastreams/SNODEPmetobs/SNODEP_metobsMod.F90 | 4 ++-- lvt/datastreams/SNODEPmetobs/readSNODEPmetobs.F90 | 4 ++-- lvt/datastreams/SNOTEL/SNOTEL_obsMod.F90 | 4 ++-- lvt/datastreams/SNOTEL/readSNOTELObs.F90 | 4 ++-- lvt/datastreams/SSEBop/SSEBop_obsMod.F90 | 4 ++-- lvt/datastreams/SSEBop/readSSEBopObs.F90 | 4 ++-- lvt/datastreams/SURFRAD/SURFRAD_obsMod.F90 | 4 ++-- lvt/datastreams/SURFRAD/readSURFRADObs.F90 | 4 ++-- lvt/datastreams/THySM/THySM_obsMod.F90 | 4 ++-- lvt/datastreams/THySM/readTHySMobs.F90 | 4 ++-- lvt/datastreams/UASMAP/UASMAP_obsMod.F90 | 4 ++-- lvt/datastreams/UASMAP/readUASMAPobs.F90 | 4 ++-- lvt/datastreams/UA_SNOW/UASNOW_obsMod.F90 | 4 ++-- lvt/datastreams/UA_SNOW/readUASNOWObs.F90 | 4 ++-- lvt/datastreams/UCLA_SWE_reanal/UCLASWEreanal_dataMod.F90 | 4 ++-- lvt/datastreams/UCLA_SWE_reanal/readUCLASWEreanal.F90 | 4 ++-- lvt/datastreams/USCRNsm/USCRNsm_obsMod.F90 | 4 ++-- lvt/datastreams/USCRNsm/readUSCRNsmObs.F90 | 4 ++-- lvt/datastreams/USDM/USDM_obsMod.F90 | 4 ++-- lvt/datastreams/USDM/readUSDMobs.F90 | 4 ++-- lvt/datastreams/USGS_GWwell/USGSGWwell_obsMod.F90 | 4 ++-- lvt/datastreams/USGS_GWwell/readUSGSGWwellobs.F90 | 4 ++-- lvt/datastreams/USGS_streamflow/USGSSF_obsMod.F90 | 4 ++-- lvt/datastreams/USGS_streamflow/readUSGSSFObs.F90 | 4 ++-- lvt/datastreams/USGS_streamflow_gridded/USGSSFgrid_obsMod.F90 | 4 ++-- lvt/datastreams/USGS_streamflow_gridded/readUSGSSFgridObs.F90 | 4 ++-- lvt/datastreams/UWET/UWET_obsMod.F90 | 4 ++-- lvt/datastreams/UWET/readUWETObs.F90 | 4 ++-- lvt/datastreams/WGPBMR/WGPBMRobsMod.F90 | 4 ++-- lvt/datastreams/WGPBMR/readWGPBMRObs.F90 | 4 ++-- lvt/datastreams/WGSWRC/WGSWRC_obsMod.F90 | 4 ++-- lvt/datastreams/WGSWRC/readWGSWRCobs.F90 | 4 ++-- lvt/datastreams/jasmin/JASMINsm_obsMod.F90 | 4 ++-- lvt/datastreams/jasmin/readJASMINsmObs.F90 | 4 ++-- lvt/datastreams/simGRACE/readsimGRACEObs.F90 | 4 ++-- lvt/datastreams/simGRACE/simGRACE_obsMod.F90 | 4 ++-- lvt/datastreams/template/readtemplateObs.F90 | 4 ++-- lvt/datastreams/template/template_obsMod.F90 | 4 ++-- lvt/domains/UTM/readinput_UTM.F90 | 4 ++-- lvt/domains/lambert/readinput_lambert.F90 | 4 ++-- lvt/domains/latlon/readinput_latlon.F90 | 4 ++-- lvt/interp/UTM_utils.F90 | 4 ++-- lvt/interp/bilinear_interp.F90 | 4 ++-- lvt/interp/bilinear_interp_input.F90 | 4 ++-- lvt/interp/breakpt_module.F90 | 4 ++-- lvt/interp/compute_earth_coord.F90 | 4 ++-- lvt/interp/compute_earth_coord_UTM.F90 | 4 ++-- lvt/interp/compute_earth_coord_ease.F90 | 4 ++-- lvt/interp/compute_earth_coord_gauss.F90 | 4 ++-- lvt/interp/compute_earth_coord_hrap.F90 | 4 ++-- lvt/interp/compute_earth_coord_lambert.F90 | 4 ++-- lvt/interp/compute_earth_coord_latlon.F90 | 4 ++-- lvt/interp/compute_earth_coord_latlon_ll.F90 | 4 ++-- lvt/interp/compute_earth_coord_latlon_ur.F90 | 4 ++-- lvt/interp/compute_earth_coord_ll.F90 | 4 ++-- lvt/interp/compute_earth_coord_merc.F90 | 4 ++-- lvt/interp/compute_earth_coord_polar.F90 | 4 ++-- lvt/interp/compute_earth_coord_ur.F90 | 4 ++-- lvt/interp/compute_grid_coord.F90 | 4 ++-- lvt/interp/compute_grid_coord_ease.F90 | 4 ++-- lvt/interp/compute_grid_coord_gauss.F90 | 4 ++-- lvt/interp/compute_grid_coord_hrap.F90 | 4 ++-- lvt/interp/compute_grid_coord_lambert.F90 | 4 ++-- lvt/interp/compute_grid_coord_latlon.F90 | 4 ++-- lvt/interp/compute_grid_coord_merc.F90 | 4 ++-- lvt/interp/compute_grid_coord_polar.F90 | 4 ++-- lvt/interp/compute_stnwts.F90 | 4 ++-- lvt/interp/compute_vinterp_weights.F90 | 4 ++-- lvt/interp/conserv_interp.F90 | 4 ++-- lvt/interp/conserv_interp_input.F90 | 4 ++-- lvt/interp/ezlh_convert.F90 | 4 ++-- lvt/interp/ezlh_inverse.F90 | 4 ++-- lvt/interp/gaussian_mod.F90 | 4 ++-- lvt/interp/gaussian_routines.F90 | 4 ++-- lvt/interp/gausslat.F90 | 4 ++-- lvt/interp/get_fieldpos.F90 | 4 ++-- lvt/interp/hrapToLatLon.F90 | 4 ++-- lvt/interp/idw_module.F90 | 4 ++-- lvt/interp/interp_stndata.F90 | 4 ++-- lvt/interp/latlonTohrap.F90 | 4 ++-- lvt/interp/latlonTopolar.F90 | 4 ++-- lvt/interp/lltops.F90 | 4 ++-- lvt/interp/map_utils.F90 | 4 ++-- lvt/interp/mqb_module.F90 | 4 ++-- lvt/interp/neighbor_interp.F90 | 4 ++-- lvt/interp/neighbor_interp_input.F90 | 4 ++-- lvt/interp/normalize_stnwts.F90 | 4 ++-- lvt/interp/polarToLatLon.F90 | 4 ++-- lvt/interp/polfixs.F90 | 4 ++-- lvt/interp/pstoll.F90 | 4 ++-- lvt/interp/stninterp_module.F90 | 4 ++-- lvt/interp/upscaleByAveraging.F90 | 4 ++-- lvt/interp/upscaleByAveraging_input.F90 | 4 ++-- lvt/interp/upscaleByAveraging_input_with_latlon.F90 | 4 ++-- lvt/interp/upscaleByMode.F90 | 4 ++-- lvt/interp/vinterp.F90 | 4 ++-- lvt/main/LVTmain.F90 | 4 ++-- lvt/make/makedep.py | 4 ++-- lvt/metrics/LVT_ACCMod.F90 | 4 ++-- lvt/metrics/LVT_AnomalyCorrMod.F90 | 4 ++-- lvt/metrics/LVT_AnomalyMod.F90 | 4 ++-- lvt/metrics/LVT_AnomalyRMSEMod.F90 | 4 ++-- lvt/metrics/LVT_AnomalyRnkCorrMod.F90 | 4 ++-- lvt/metrics/LVT_AreaMetricMod.F90 | 4 ++-- lvt/metrics/LVT_BIASMod.F90 | 4 ++-- lvt/metrics/LVT_CSIMod.F90 | 4 ++-- lvt/metrics/LVT_CSSMod.F90 | 4 ++-- lvt/metrics/LVT_ConditionalEntropyMod.F90 | 4 ++-- lvt/metrics/LVT_DFRMod.F90 | 4 ++-- lvt/metrics/LVT_EFMod.F90 | 4 ++-- lvt/metrics/LVT_ETSMod.F90 | 4 ++-- lvt/metrics/LVT_EffectiveComplexityMod.F90 | 4 ++-- lvt/metrics/LVT_FARMod.F90 | 4 ++-- lvt/metrics/LVT_FBIASMod.F90 | 4 ++-- lvt/metrics/LVT_FFMod.F90 | 4 ++-- lvt/metrics/LVT_FluctuationComplexityMod.F90 | 4 ++-- lvt/metrics/LVT_HNMod.F90 | 4 ++-- lvt/metrics/LVT_HSSMod.F90 | 4 ++-- lvt/metrics/LVT_InformationEntropyMod.F90 | 4 ++-- lvt/metrics/LVT_InformationGainMod.F90 | 4 ++-- lvt/metrics/LVT_JointEntropyMod.F90 | 4 ++-- lvt/metrics/LVT_KmeansMod.F90 | 4 ++-- lvt/metrics/LVT_MAEMod.F90 | 4 ++-- lvt/metrics/LVT_MEANMod.F90 | 4 ++-- lvt/metrics/LVT_MaxMod.F90 | 4 ++-- lvt/metrics/LVT_MaxTimeMod.F90 | 4 ++-- lvt/metrics/LVT_MetricEntropyMod.F90 | 4 ++-- lvt/metrics/LVT_MinMod.F90 | 4 ++-- lvt/metrics/LVT_MinTimeMod.F90 | 4 ++-- lvt/metrics/LVT_MutualInformationMod.F90 | 4 ++-- lvt/metrics/LVT_NSEMod.F90 | 4 ++-- lvt/metrics/LVT_PODNMod.F90 | 4 ++-- lvt/metrics/LVT_PODYMod.F90 | 4 ++-- lvt/metrics/LVT_POFDMod.F90 | 4 ++-- lvt/metrics/LVT_PSSMod.F90 | 4 ++-- lvt/metrics/LVT_RELMod.F90 | 4 ++-- lvt/metrics/LVT_RESMod.F90 | 4 ++-- lvt/metrics/LVT_RFVMod.F90 | 4 ++-- lvt/metrics/LVT_RMSEMod.F90 | 4 ++-- lvt/metrics/LVT_RawCorrMod.F90 | 4 ++-- lvt/metrics/LVT_RelativeEntropy.F90 | 4 ++-- lvt/metrics/LVT_RnkCorrMod.F90 | 4 ++-- lvt/metrics/LVT_SGWIMod.F90 | 4 ++-- lvt/metrics/LVT_SPIMod.F90 | 4 ++-- lvt/metrics/LVT_SRIMod.F90 | 4 ++-- lvt/metrics/LVT_SSWIMod.F90 | 4 ++-- lvt/metrics/LVT_SdSIMod.F90 | 4 ++-- lvt/metrics/LVT_StdevMod.F90 | 4 ++-- lvt/metrics/LVT_SumMod.F90 | 4 ++-- lvt/metrics/LVT_TCMod.F90 | 4 ++-- lvt/metrics/LVT_TFBMod.F90 | 4 ++-- lvt/metrics/LVT_THBMod.F90 | 4 ++-- lvt/metrics/LVT_TMBMod.F90 | 4 ++-- lvt/metrics/LVT_TendencyCorrMod.F90 | 4 ++-- lvt/metrics/LVT_TendencyMod.F90 | 4 ++-- lvt/metrics/LVT_TrendMod.F90 | 4 ++-- lvt/metrics/LVT_VULMod.F90 | 4 ++-- lvt/metrics/LVT_VarianceMod.F90 | 4 ++-- lvt/metrics/LVT_ZscoreMod.F90 | 4 ++-- lvt/metrics/LVT_percentileMod.F90 | 4 ++-- lvt/metrics/LVT_ubRMSEMod.F90 | 4 ++-- lvt/metrics/LVT_waveletStatMod.F90 | 4 ++-- lvt/plugins/LVT_datastream_pluginMod.F90 | 4 ++-- lvt/plugins/LVT_domain_pluginMod.F90 | 4 ++-- lvt/plugins/LVT_metric_pluginMod.F90 | 4 ++-- lvt/plugins/LVT_pluginIndices.F90 | 4 ++-- lvt/plugins/LVT_runmode_pluginMod.F90 | 4 ++-- lvt/plugins/LVT_trainingAlg_pluginMod.F90 | 4 ++-- lvt/runmodes/557post/LVT_557post_ps41_snowMod.F90 | 4 ++-- lvt/runmodes/557post/LVT_init_557post.F90 | 4 ++-- lvt/runmodes/557post/LVT_run_557post.F90 | 4 ++-- lvt/runmodes/557post/lis_jules_en_snow.F90 | 4 ++-- lvt/runmodes/Benchmarking/LVT_init_Benchmarking.F90 | 4 ++-- lvt/runmodes/Benchmarking/LVT_run_Benchmarking.F90 | 4 ++-- lvt/runmodes/DAobs/LVT_init_DAobs.F90 | 4 ++-- lvt/runmodes/DAobs/LVT_run_DAobs.F90 | 4 ++-- lvt/runmodes/DAstats/LVT_init_DAstats.F90 | 4 ++-- lvt/runmodes/DAstats/LVT_run_DAstats.F90 | 4 ++-- lvt/runmodes/DataComp/LVT_init_DataComp.F90 | 4 ++-- lvt/runmodes/DataComp/LVT_run_DataComp.F90 | 4 ++-- lvt/runmodes/LISpost/LVT_init_LISpost.F90 | 4 ++-- lvt/runmodes/LISpost/LVT_run_LISpost.F90 | 4 ++-- lvt/runmodes/USAFSIpost/LVT_USAFSIpostMod.F90 | 4 ++-- lvt/runmodes/USAFSIpost/LVT_gribWrapperMod.F90 | 4 ++-- lvt/runmodes/USAFSIpost/LVT_init_USAFSIpost.F90 | 4 ++-- lvt/runmodes/USAFSIpost/LVT_run_USAFSIpost.F90 | 4 ++-- lvt/runmodes/optUE/LVT_init_optUE.F90 | 4 ++-- lvt/runmodes/optUE/LVT_run_optUE.F90 | 4 ++-- lvt/training/LinearRegression/LinearRegressionMod.F90 | 4 ++-- lvt/utils/gnuplot/ADC/plotADC.F90 | 4 ++-- lvt/utils/gnuplot/scatter/plotScatter.F90 | 4 ++-- lvt/utils/gnuplot/timeseries/plotTS.F90 | 4 ++-- lvt/utils/gnuplot/timeseries/plotTS.py | 4 ++-- lvt/utils/input_proc/LVTpreproc.F90 | 4 ++-- lvt/utils/input_proc/map_utils.F90 | 4 ++-- lvt/utils/input_proc/preprocMod.F90 | 4 ++-- lvt/utils/input_proc/readConfigFile.F90 | 4 ++-- lvt/utils/input_proc/read_IGBP_MODISlc.F90 | 4 ++-- lvt/utils/input_proc/read_UMDlc.F90 | 4 ++-- lvt/utils/input_proc/read_USGSlc.F90 | 4 ++-- lvt/utils/input_proc/readinput_lambert.F90 | 4 ++-- lvt/utils/input_proc/readinput_latlon.F90 | 4 ++-- lvt/utils/input_proc/readinput_polar.F90 | 4 ++-- lvt/utils/ncl/ADC/plotADC.F90 | 4 ++-- lvt/utils/ncl/scatter/plotScatter.F90 | 4 ++-- lvt/utils/ncl/timeseries/plotTS.F90 | 4 ++-- lvt/utils/scripts/doc.csh | 4 ++-- lvt/utils/usaf/cat_lvt_grib2.py | 4 ++-- lvt/utils/usaf/convert_nc2surf.py | 4 ++-- lvt/utils/usaf/make_sm_geotiff.py | 4 ++-- lvt/utils/usaf/read_surf.py | 4 ++-- lvt/utils/usaf/run_ncks.py | 4 ++-- lvt/utils/usaf/run_ncks_galwem.py | 4 ++-- lvt/utils/usaf/surf2lisnc_3_10km.py | 4 ++-- lvt/utils/usaf/surf2lisnc_3_17km.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_24hr_jules.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_24hr_noah.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_24hr_noahmp.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_3hr_jules.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_3hr_jules_galwem.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_3hr_noah.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_3hr_noahmp.py | 4 ++-- lvt/utils/usaf/templates/make_lvt_config_sm_anomaly_00z.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_24hr_jules.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_24hr_noah.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_24hr_noahmp.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules.py | 4 ++-- .../usaf/templates/submit_lvt_discover_3hr_jules_galwem.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_3hr_noah.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_discover_3hr_noahmp.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_jules.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noah.py | 4 ++-- lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noahmp.py | 4 ++-- lvt/utils/usaf/usafsipost/make_lvt_config_usafsipost.py | 4 ++-- lvt/utils/usaf/usafsipost/submit_lvt_usafsipost_discover.py | 4 ++-- 477 files changed, 952 insertions(+), 952 deletions(-) diff --git a/lvt/arch/Config.pl b/lvt/arch/Config.pl index c912a9a3e..43e7b04b9 100755 --- a/lvt/arch/Config.pl +++ b/lvt/arch/Config.pl @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/compile b/lvt/compile index 7601ad546..62251d96b 100755 --- a/lvt/compile +++ b/lvt/compile @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/configure b/lvt/configure index 604747d0a..b9b5197b2 100755 --- a/lvt/configure +++ b/lvt/configure @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/FTable.c b/lvt/core/FTable.c index 32c1e02d5..016fbc30a 100644 --- a/lvt/core/FTable.c +++ b/lvt/core/FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/FTable.h b/lvt/core/FTable.h index 7e88eae1d..976dde057 100644 --- a/lvt/core/FTable.h +++ b/lvt/core/FTable.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_CIMod.F90 b/lvt/core/LVT_CIMod.F90 index 2e1f54a4b..81f46f8e4 100644 --- a/lvt/core/LVT_CIMod.F90 +++ b/lvt/core/LVT_CIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_DAMod.F90 b/lvt/core/LVT_DAMod.F90 index 7cd2937a3..af4d94736 100644 --- a/lvt/core/LVT_DAMod.F90 +++ b/lvt/core/LVT_DAMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_DataStreamsMod.F90 b/lvt/core/LVT_DataStreamsMod.F90 index 2bef51639..511434a37 100644 --- a/lvt/core/LVT_DataStreamsMod.F90 +++ b/lvt/core/LVT_DataStreamsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_InformationContentMod.F90 b/lvt/core/LVT_InformationContentMod.F90 index 18b76133d..9cc09f9c9 100644 --- a/lvt/core/LVT_InformationContentMod.F90 +++ b/lvt/core/LVT_InformationContentMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_LISoutputHandlerMod.F90 b/lvt/core/LVT_LISoutputHandlerMod.F90 index 35d0d6d6d..d454f0c09 100644 --- a/lvt/core/LVT_LISoutputHandlerMod.F90 +++ b/lvt/core/LVT_LISoutputHandlerMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_LISpostMod.F90 b/lvt/core/LVT_LISpostMod.F90 index 27bd46edd..42563c37d 100644 --- a/lvt/core/LVT_LISpostMod.F90 +++ b/lvt/core/LVT_LISpostMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_LMLCMod.F90 b/lvt/core/LVT_LMLCMod.F90 index 5fac9e0a1..a104ff950 100644 --- a/lvt/core/LVT_LMLCMod.F90 +++ b/lvt/core/LVT_LMLCMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_NumericalRecipesMod.F90 b/lvt/core/LVT_NumericalRecipesMod.F90 index fe8484a37..3f0d28729 100644 --- a/lvt/core/LVT_NumericalRecipesMod.F90 +++ b/lvt/core/LVT_NumericalRecipesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_PRIV_gridMod.F90 b/lvt/core/LVT_PRIV_gridMod.F90 index 921457404..9a3f70bca 100644 --- a/lvt/core/LVT_PRIV_gridMod.F90 +++ b/lvt/core/LVT_PRIV_gridMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_PRIV_rcMod.F90 b/lvt/core/LVT_PRIV_rcMod.F90 index ccd6736dc..46aa432ee 100644 --- a/lvt/core/LVT_PRIV_rcMod.F90 +++ b/lvt/core/LVT_PRIV_rcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_PRIV_tileMod.F90 b/lvt/core/LVT_PRIV_tileMod.F90 index 3d476109e..65c6804f1 100644 --- a/lvt/core/LVT_PRIV_tileMod.F90 +++ b/lvt/core/LVT_PRIV_tileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_SortingMod.F90 b/lvt/core/LVT_SortingMod.F90 index eb7c3c8d7..122d1c767 100644 --- a/lvt/core/LVT_SortingMod.F90 +++ b/lvt/core/LVT_SortingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_StratStatsMod.F90 b/lvt/core/LVT_StratStatsMod.F90 index ef36b554a..5c6f08c66 100644 --- a/lvt/core/LVT_StratStatsMod.F90 +++ b/lvt/core/LVT_StratStatsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_String_Utility.F90 b/lvt/core/LVT_String_Utility.F90 index 7c7d036b7..d80c7122f 100644 --- a/lvt/core/LVT_String_Utility.F90 +++ b/lvt/core/LVT_String_Utility.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_TSMod.F90 b/lvt/core/LVT_TSMod.F90 index 2b734d80f..3dc3d3f21 100644 --- a/lvt/core/LVT_TSMod.F90 +++ b/lvt/core/LVT_TSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_constantsMod.F90 b/lvt/core/LVT_constantsMod.F90 index f4886595b..0ed99fcb9 100644 --- a/lvt/core/LVT_constantsMod.F90 +++ b/lvt/core/LVT_constantsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_coreMod.F90 b/lvt/core/LVT_coreMod.F90 index 31502c6c9..f31908fea 100644 --- a/lvt/core/LVT_coreMod.F90 +++ b/lvt/core/LVT_coreMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_create_subdirs.c b/lvt/core/LVT_create_subdirs.c index 368f1af39..a9e33adf7 100644 --- a/lvt/core/LVT_create_subdirs.c +++ b/lvt/core/LVT_create_subdirs.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_domainMod.F90 b/lvt/core/LVT_domainMod.F90 index dd1561101..cb22789f2 100644 --- a/lvt/core/LVT_domainMod.F90 +++ b/lvt/core/LVT_domainMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_domain_FTable.c b/lvt/core/LVT_domain_FTable.c index fe6a9f1cf..066ad9691 100644 --- a/lvt/core/LVT_domain_FTable.c +++ b/lvt/core/LVT_domain_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_fileIOMod.F90 b/lvt/core/LVT_fileIOMod.F90 index d2d027072..57ec665c0 100644 --- a/lvt/core/LVT_fileIOMod.F90 +++ b/lvt/core/LVT_fileIOMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_getADCIndex.F90 b/lvt/core/LVT_getADCIndex.F90 index a5f0fd7e7..dba476c1a 100644 --- a/lvt/core/LVT_getADCIndex.F90 +++ b/lvt/core/LVT_getADCIndex.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_getSeasonalCycleIndex.F90 b/lvt/core/LVT_getSeasonalCycleIndex.F90 index 2818da97b..4434923e4 100644 --- a/lvt/core/LVT_getSeasonalCycleIndex.F90 +++ b/lvt/core/LVT_getSeasonalCycleIndex.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_histDataMod.F90 b/lvt/core/LVT_histDataMod.F90 index 28f1fe089..ca20525b2 100644 --- a/lvt/core/LVT_histDataMod.F90 +++ b/lvt/core/LVT_histDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_historyMod.F90 b/lvt/core/LVT_historyMod.F90 index f5c29d384..1cb312e47 100644 --- a/lvt/core/LVT_historyMod.F90 +++ b/lvt/core/LVT_historyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_logMod.F90 b/lvt/core/LVT_logMod.F90 index bca5a1e15..01cdc2cfd 100644 --- a/lvt/core/LVT_logMod.F90 +++ b/lvt/core/LVT_logMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_mapSurfaceModelType.F90 b/lvt/core/LVT_mapSurfaceModelType.F90 index 69fbf4635..69f1767a9 100644 --- a/lvt/core/LVT_mapSurfaceModelType.F90 +++ b/lvt/core/LVT_mapSurfaceModelType.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_metric_FTable.c b/lvt/core/LVT_metric_FTable.c index b37c486e7..46f0fcb53 100644 --- a/lvt/core/LVT_metric_FTable.c +++ b/lvt/core/LVT_metric_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_mpDecomp.c b/lvt/core/LVT_mpDecomp.c index 066acf831..afde6a35e 100644 --- a/lvt/core/LVT_mpDecomp.c +++ b/lvt/core/LVT_mpDecomp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_mpiMod.F90 b/lvt/core/LVT_mpiMod.F90 index 5b3f4b656..0ee6e1c2e 100644 --- a/lvt/core/LVT_mpiMod.F90 +++ b/lvt/core/LVT_mpiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_navgemMod.F90 b/lvt/core/LVT_navgemMod.F90 index fc8a40d45..bfc052939 100644 --- a/lvt/core/LVT_navgemMod.F90 +++ b/lvt/core/LVT_navgemMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_obs_FTable.c b/lvt/core/LVT_obs_FTable.c index 7a6c053e5..4b86af378 100644 --- a/lvt/core/LVT_obs_FTable.c +++ b/lvt/core/LVT_obs_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_optUEMod.F90 b/lvt/core/LVT_optUEMod.F90 index b5f73bd55..91f104365 100644 --- a/lvt/core/LVT_optUEMod.F90 +++ b/lvt/core/LVT_optUEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_readConfig.F90 b/lvt/core/LVT_readConfig.F90 index c1e11dfe7..49a1d4465 100644 --- a/lvt/core/LVT_readConfig.F90 +++ b/lvt/core/LVT_readConfig.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_readMetricsAttributes.F90 b/lvt/core/LVT_readMetricsAttributes.F90 index c99c166bd..0ceb5b094 100644 --- a/lvt/core/LVT_readMetricsAttributes.F90 +++ b/lvt/core/LVT_readMetricsAttributes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_runmode_FTable.c b/lvt/core/LVT_runmode_FTable.c index 7e77c2c94..f100105db 100644 --- a/lvt/core/LVT_runmode_FTable.c +++ b/lvt/core/LVT_runmode_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_soilsMod.F90 b/lvt/core/LVT_soilsMod.F90 index c2c678233..c8a02606f 100644 --- a/lvt/core/LVT_soilsMod.F90 +++ b/lvt/core/LVT_soilsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_statsDataMod.F90 b/lvt/core/LVT_statsDataMod.F90 index b1a7c4cf6..ceb72557e 100644 --- a/lvt/core/LVT_statsDataMod.F90 +++ b/lvt/core/LVT_statsDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_statsMod.F90 b/lvt/core/LVT_statsMod.F90 index bf4165bd0..7b21e433b 100644 --- a/lvt/core/LVT_statsMod.F90 +++ b/lvt/core/LVT_statsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_timeMgrMod.F90 b/lvt/core/LVT_timeMgrMod.F90 index d007d7e86..dc1c8dbc6 100644 --- a/lvt/core/LVT_timeMgrMod.F90 +++ b/lvt/core/LVT_timeMgrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_topoMod.F90 b/lvt/core/LVT_topoMod.F90 index 60531a8f9..f287308d9 100644 --- a/lvt/core/LVT_topoMod.F90 +++ b/lvt/core/LVT_topoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_trainingMod.F90 b/lvt/core/LVT_trainingMod.F90 index 978be77d8..6b634dd71 100644 --- a/lvt/core/LVT_trainingMod.F90 +++ b/lvt/core/LVT_trainingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/LVT_training_FTable.c b/lvt/core/LVT_training_FTable.c index 6641e0eb2..c4b3998bc 100644 --- a/lvt/core/LVT_training_FTable.c +++ b/lvt/core/LVT_training_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/bak/LVT_DataStream1Mod.F90 b/lvt/core/bak/LVT_DataStream1Mod.F90 index 9a5062b58..eef3006b7 100644 --- a/lvt/core/bak/LVT_DataStream1Mod.F90 +++ b/lvt/core/bak/LVT_DataStream1Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/core/bak/LVT_DataStream2Mod.F90 b/lvt/core/bak/LVT_DataStream2Mod.F90 index 0a3b6468c..0fc690257 100644 --- a/lvt/core/bak/LVT_DataStream2Mod.F90 +++ b/lvt/core/bak/LVT_DataStream2Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/3B42V7/TRMM3B42V7_dataMod.F90 b/lvt/datastreams/3B42V7/TRMM3B42V7_dataMod.F90 index c2b83740a..b7096810c 100644 --- a/lvt/datastreams/3B42V7/TRMM3B42V7_dataMod.F90 +++ b/lvt/datastreams/3B42V7/TRMM3B42V7_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/3B42V7/readTRMM3B42V7data.F90 b/lvt/datastreams/3B42V7/readTRMM3B42V7data.F90 index 399e277cc..89757947e 100644 --- a/lvt/datastreams/3B42V7/readTRMM3B42V7data.F90 +++ b/lvt/datastreams/3B42V7/readTRMM3B42V7data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/AGRMET/AGRMET_dataMod.F90 b/lvt/datastreams/AGRMET/AGRMET_dataMod.F90 index c199edf61..6f194afde 100644 --- a/lvt/datastreams/AGRMET/AGRMET_dataMod.F90 +++ b/lvt/datastreams/AGRMET/AGRMET_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/AGRMET/readAGRMETdata.F90 b/lvt/datastreams/AGRMET/readAGRMETdata.F90 index 768ea3c21..7f7f77903 100644 --- a/lvt/datastreams/AGRMET/readAGRMETdata.F90 +++ b/lvt/datastreams/AGRMET/readAGRMETdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ALEXI/ALEXI_obsMod.F90 b/lvt/datastreams/ALEXI/ALEXI_obsMod.F90 index 3f33a8707..bf858a738 100644 --- a/lvt/datastreams/ALEXI/ALEXI_obsMod.F90 +++ b/lvt/datastreams/ALEXI/ALEXI_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ALEXI/readALEXIObs.F90 b/lvt/datastreams/ALEXI/readALEXIObs.F90 index 83a8392fb..40a207c76 100644 --- a/lvt/datastreams/ALEXI/readALEXIObs.F90 +++ b/lvt/datastreams/ALEXI/readALEXIObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ALEXIesi/ALEXIesi_obsMod.F90 b/lvt/datastreams/ALEXIesi/ALEXIesi_obsMod.F90 index 120265f04..974d61068 100644 --- a/lvt/datastreams/ALEXIesi/ALEXIesi_obsMod.F90 +++ b/lvt/datastreams/ALEXIesi/ALEXIesi_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ALEXIesi/readALEXIesiObs.F90 b/lvt/datastreams/ALEXIesi/readALEXIesiObs.F90 index 27c2acf39..ec6e1e112 100644 --- a/lvt/datastreams/ALEXIesi/readALEXIesiObs.F90 +++ b/lvt/datastreams/ALEXIesi/readALEXIesiObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ANSA_SNWD/ANSASNWD_obsMod.F90 b/lvt/datastreams/ANSA_SNWD/ANSASNWD_obsMod.F90 index 4ff7c0627..4bb3553c5 100644 --- a/lvt/datastreams/ANSA_SNWD/ANSASNWD_obsMod.F90 +++ b/lvt/datastreams/ANSA_SNWD/ANSASNWD_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ANSA_SNWD/readANSASNWDobs.F90 b/lvt/datastreams/ANSA_SNWD/readANSASNWDobs.F90 index 5a67eba9c..928e2deaf 100644 --- a/lvt/datastreams/ANSA_SNWD/readANSASNWDobs.F90 +++ b/lvt/datastreams/ANSA_SNWD/readANSASNWDobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ANSA_SWE/ANSASWE_obsMod.F90 b/lvt/datastreams/ANSA_SWE/ANSASWE_obsMod.F90 index 8c75fc38c..95827ecfe 100644 --- a/lvt/datastreams/ANSA_SWE/ANSASWE_obsMod.F90 +++ b/lvt/datastreams/ANSA_SWE/ANSASWE_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ANSA_SWE/readANSASWEobs.F90 b/lvt/datastreams/ANSA_SWE/readANSASWEobs.F90 index 2207d0d87..4de7ea1cf 100644 --- a/lvt/datastreams/ANSA_SWE/readANSASWEobs.F90 +++ b/lvt/datastreams/ANSA_SWE/readANSASWEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/APHRO_PRCP/APHROPRCP_obsMod.F90 b/lvt/datastreams/APHRO_PRCP/APHROPRCP_obsMod.F90 index c0637d3a1..fec87d3ac 100644 --- a/lvt/datastreams/APHRO_PRCP/APHROPRCP_obsMod.F90 +++ b/lvt/datastreams/APHRO_PRCP/APHROPRCP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/APHRO_PRCP/readAPHROPRCPObs.F90 b/lvt/datastreams/APHRO_PRCP/readAPHROPRCPObs.F90 index 4777803c1..de09b015d 100644 --- a/lvt/datastreams/APHRO_PRCP/readAPHROPRCPObs.F90 +++ b/lvt/datastreams/APHRO_PRCP/readAPHROPRCPObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ARM/ARM_obsMod.F90 b/lvt/datastreams/ARM/ARM_obsMod.F90 index 4fdfdb056..868b6eeb0 100644 --- a/lvt/datastreams/ARM/ARM_obsMod.F90 +++ b/lvt/datastreams/ARM/ARM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ARM/readARMObs.F90 b/lvt/datastreams/ARM/readARMObs.F90 index a3f4a53e4..93b8b5a6c 100644 --- a/lvt/datastreams/ARM/readARMObs.F90 +++ b/lvt/datastreams/ARM/readARMObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ARSsm/ARSsm_obsMod.F90 b/lvt/datastreams/ARSsm/ARSsm_obsMod.F90 index 710994d5c..2d1194f3d 100644 --- a/lvt/datastreams/ARSsm/ARSsm_obsMod.F90 +++ b/lvt/datastreams/ARSsm/ARSsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ARSsm/readARSsmobs.F90 b/lvt/datastreams/ARSsm/readARSsmobs.F90 index 01d1057f0..02bd003a1 100644 --- a/lvt/datastreams/ARSsm/readARSsmobs.F90 +++ b/lvt/datastreams/ARSsm/readARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ASO_SWE/ASOSWE_obsMod.F90 b/lvt/datastreams/ASO_SWE/ASOSWE_obsMod.F90 index 66ccad988..8feae093d 100755 --- a/lvt/datastreams/ASO_SWE/ASOSWE_obsMod.F90 +++ b/lvt/datastreams/ASO_SWE/ASOSWE_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ASO_SWE/readASOSWEobs.F90 b/lvt/datastreams/ASO_SWE/readASOSWEobs.F90 index 4ef527c3a..56e280271 100755 --- a/lvt/datastreams/ASO_SWE/readASOSWEobs.F90 +++ b/lvt/datastreams/ASO_SWE/readASOSWEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Ameriflux/Ameriflux_obsMod.F90 b/lvt/datastreams/Ameriflux/Ameriflux_obsMod.F90 index 6d38d0342..544e75cf2 100644 --- a/lvt/datastreams/Ameriflux/Ameriflux_obsMod.F90 +++ b/lvt/datastreams/Ameriflux/Ameriflux_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Ameriflux/readAmerifluxObs.F90 b/lvt/datastreams/Ameriflux/readAmerifluxObs.F90 index 74dfc4b1c..720308d4c 100644 --- a/lvt/datastreams/Ameriflux/readAmerifluxObs.F90 +++ b/lvt/datastreams/Ameriflux/readAmerifluxObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CEOP/CEOP_obsMod.F90 b/lvt/datastreams/CEOP/CEOP_obsMod.F90 index fa07162ff..92603ac94 100644 --- a/lvt/datastreams/CEOP/CEOP_obsMod.F90 +++ b/lvt/datastreams/CEOP/CEOP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CEOP/readCEOP.F90 b/lvt/datastreams/CEOP/readCEOP.F90 index c62887d5e..ec9e9e64b 100644 --- a/lvt/datastreams/CEOP/readCEOP.F90 +++ b/lvt/datastreams/CEOP/readCEOP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CHIRPSv2/CHIRPSv2_dataMod.F90 b/lvt/datastreams/CHIRPSv2/CHIRPSv2_dataMod.F90 index cf541652a..b10990e76 100644 --- a/lvt/datastreams/CHIRPSv2/CHIRPSv2_dataMod.F90 +++ b/lvt/datastreams/CHIRPSv2/CHIRPSv2_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CHIRPSv2/readCHIRPSv2data.F90 b/lvt/datastreams/CHIRPSv2/readCHIRPSv2data.F90 index ca68b1c56..660843a2b 100644 --- a/lvt/datastreams/CHIRPSv2/readCHIRPSv2data.F90 +++ b/lvt/datastreams/CHIRPSv2/readCHIRPSv2data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CMC_SNWD/CMCSNWD_obsMod.F90 b/lvt/datastreams/CMC_SNWD/CMCSNWD_obsMod.F90 index 9b0e626d3..f16c731db 100644 --- a/lvt/datastreams/CMC_SNWD/CMCSNWD_obsMod.F90 +++ b/lvt/datastreams/CMC_SNWD/CMCSNWD_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CMC_SNWD/readCMC_SNWDObs.F90 b/lvt/datastreams/CMC_SNWD/readCMC_SNWDObs.F90 index 8b3611fb3..bc4ae5a29 100644 --- a/lvt/datastreams/CMC_SNWD/readCMC_SNWDObs.F90 +++ b/lvt/datastreams/CMC_SNWD/readCMC_SNWDObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CMORPH/CMORPH_dataMod.F90 b/lvt/datastreams/CMORPH/CMORPH_dataMod.F90 index de9f91329..55b253622 100644 --- a/lvt/datastreams/CMORPH/CMORPH_dataMod.F90 +++ b/lvt/datastreams/CMORPH/CMORPH_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CMORPH/readCMORPHdata.F90 b/lvt/datastreams/CMORPH/readCMORPHdata.F90 index 3a687b673..df1334862 100644 --- a/lvt/datastreams/CMORPH/readCMORPHdata.F90 +++ b/lvt/datastreams/CMORPH/readCMORPHdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 b/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 index cce030ec4..ce5253775 100644 --- a/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 +++ b/lvt/datastreams/COAMPSout/COAMPSout_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 index ff9936914..dc800575b 100644 --- a/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 +++ b/lvt/datastreams/COAMPSout/readCOAMPSoutdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CPC_PRCP/CPCPRCP_obsMod.F90 b/lvt/datastreams/CPC_PRCP/CPCPRCP_obsMod.F90 index 55527bd71..f05b58180 100644 --- a/lvt/datastreams/CPC_PRCP/CPCPRCP_obsMod.F90 +++ b/lvt/datastreams/CPC_PRCP/CPCPRCP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/CPC_PRCP/readCPCPRCPObs.F90 b/lvt/datastreams/CPC_PRCP/readCPCPRCPObs.F90 index 300dadfc1..03b2698d9 100644 --- a/lvt/datastreams/CPC_PRCP/readCPCPRCPObs.F90 +++ b/lvt/datastreams/CPC_PRCP/readCPCPRCPObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Daymet/Daymet_obsMod.F90 b/lvt/datastreams/Daymet/Daymet_obsMod.F90 index c1896258a..0c8486ef2 100644 --- a/lvt/datastreams/Daymet/Daymet_obsMod.F90 +++ b/lvt/datastreams/Daymet/Daymet_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Daymet/readDaymetObs.F90 b/lvt/datastreams/Daymet/readDaymetObs.F90 index e8cb0db41..c270973e2 100644 --- a/lvt/datastreams/Daymet/readDaymetObs.F90 +++ b/lvt/datastreams/Daymet/readDaymetObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ECMWFforc/ECMWFforc_dataMod.F90 b/lvt/datastreams/ECMWFforc/ECMWFforc_dataMod.F90 index 237d852b8..9a33c06f1 100755 --- a/lvt/datastreams/ECMWFforc/ECMWFforc_dataMod.F90 +++ b/lvt/datastreams/ECMWFforc/ECMWFforc_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ECMWFforc/readECMWFforcdata.F90 b/lvt/datastreams/ECMWFforc/readECMWFforcdata.F90 index 57897573e..41a368715 100755 --- a/lvt/datastreams/ECMWFforc/readECMWFforcdata.F90 +++ b/lvt/datastreams/ECMWFforc/readECMWFforcdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ERA5/ERA5obsMod.F90 b/lvt/datastreams/ERA5/ERA5obsMod.F90 index 16e97d06e..dda3718c9 100644 --- a/lvt/datastreams/ERA5/ERA5obsMod.F90 +++ b/lvt/datastreams/ERA5/ERA5obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ERA5/readERA5obs.F90 b/lvt/datastreams/ERA5/readERA5obs.F90 index 058d8f6a7..52f487f7e 100644 --- a/lvt/datastreams/ERA5/readERA5obs.F90 +++ b/lvt/datastreams/ERA5/readERA5obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ERAinterimLand/ERAinterimLandobsMod.F90 b/lvt/datastreams/ERAinterimLand/ERAinterimLandobsMod.F90 index 4b043b9e2..f84f8ff39 100644 --- a/lvt/datastreams/ERAinterimLand/ERAinterimLandobsMod.F90 +++ b/lvt/datastreams/ERAinterimLand/ERAinterimLandobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ERAinterimLand/readERAinterimLandobs.F90 b/lvt/datastreams/ERAinterimLand/readERAinterimLandobs.F90 index 4b082d009..557b3e5d6 100644 --- a/lvt/datastreams/ERAinterimLand/readERAinterimLandobs.F90 +++ b/lvt/datastreams/ERAinterimLand/readERAinterimLandobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ESACCI_sm/ESACCIsm_obsMod.F90 b/lvt/datastreams/ESACCI_sm/ESACCIsm_obsMod.F90 index dbdb075b6..2e965e923 100644 --- a/lvt/datastreams/ESACCI_sm/ESACCIsm_obsMod.F90 +++ b/lvt/datastreams/ESACCI_sm/ESACCIsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ESACCI_sm/readESACCIsmObs.F90 b/lvt/datastreams/ESACCI_sm/readESACCIsmObs.F90 index a00fc3d58..6cd03d1ef 100644 --- a/lvt/datastreams/ESACCI_sm/readESACCIsmObs.F90 +++ b/lvt/datastreams/ESACCI_sm/readESACCIsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXCOM/FLUXCOM_obsMod.F90 b/lvt/datastreams/FLUXCOM/FLUXCOM_obsMod.F90 index 3eee50eac..8ea39f761 100755 --- a/lvt/datastreams/FLUXCOM/FLUXCOM_obsMod.F90 +++ b/lvt/datastreams/FLUXCOM/FLUXCOM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXCOM/readFLUXCOMobs.F90 b/lvt/datastreams/FLUXCOM/readFLUXCOMobs.F90 index 41a0a9ef4..3c720de58 100755 --- a/lvt/datastreams/FLUXCOM/readFLUXCOMobs.F90 +++ b/lvt/datastreams/FLUXCOM/readFLUXCOMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNET2015/FLUXNET2015_obsMod.F90 b/lvt/datastreams/FLUXNET2015/FLUXNET2015_obsMod.F90 index eaea90d75..f15d0b1bb 100644 --- a/lvt/datastreams/FLUXNET2015/FLUXNET2015_obsMod.F90 +++ b/lvt/datastreams/FLUXNET2015/FLUXNET2015_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNET2015/readFLUXNET2015Obs.F90 b/lvt/datastreams/FLUXNET2015/readFLUXNET2015Obs.F90 index e1f4d58f3..989c0d3a9 100644 --- a/lvt/datastreams/FLUXNET2015/readFLUXNET2015Obs.F90 +++ b/lvt/datastreams/FLUXNET2015/readFLUXNET2015Obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNET2015_NC/FLUXNET2015NC_obsMod.F90 b/lvt/datastreams/FLUXNET2015_NC/FLUXNET2015NC_obsMod.F90 index 5f9d0577b..cef5784bb 100644 --- a/lvt/datastreams/FLUXNET2015_NC/FLUXNET2015NC_obsMod.F90 +++ b/lvt/datastreams/FLUXNET2015_NC/FLUXNET2015NC_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNET2015_NC/readFLUXNET2015NCObs.F90 b/lvt/datastreams/FLUXNET2015_NC/readFLUXNET2015NCObs.F90 index 5e122d6ec..43d639e42 100644 --- a/lvt/datastreams/FLUXNET2015_NC/readFLUXNET2015NCObs.F90 +++ b/lvt/datastreams/FLUXNET2015_NC/readFLUXNET2015NCObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNETmte/FLUXNETmte_obsMod.F90 b/lvt/datastreams/FLUXNETmte/FLUXNETmte_obsMod.F90 index 3087dcf11..5a7af3cce 100644 --- a/lvt/datastreams/FLUXNETmte/FLUXNETmte_obsMod.F90 +++ b/lvt/datastreams/FLUXNETmte/FLUXNETmte_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FLUXNETmte/readFLUXNETmteObs.F90 b/lvt/datastreams/FLUXNETmte/readFLUXNETmteObs.F90 index b247261a4..6c52184ba 100644 --- a/lvt/datastreams/FLUXNETmte/readFLUXNETmteObs.F90 +++ b/lvt/datastreams/FLUXNETmte/readFLUXNETmteObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FMI_SWE/FMISWE_obsMod.F90 b/lvt/datastreams/FMI_SWE/FMISWE_obsMod.F90 index 9e10b2028..dfdb8b1e3 100644 --- a/lvt/datastreams/FMI_SWE/FMISWE_obsMod.F90 +++ b/lvt/datastreams/FMI_SWE/FMISWE_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FMI_SWE/readFMISWEobs.F90 b/lvt/datastreams/FMI_SWE/readFMISWEobs.F90 index 4f6e54a8a..f6b8e1581 100644 --- a/lvt/datastreams/FMI_SWE/readFMISWEobs.F90 +++ b/lvt/datastreams/FMI_SWE/readFMISWEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FluxSat_GPP/FluxSat_obsMod.F90 b/lvt/datastreams/FluxSat_GPP/FluxSat_obsMod.F90 index ab083c869..b6af291c2 100755 --- a/lvt/datastreams/FluxSat_GPP/FluxSat_obsMod.F90 +++ b/lvt/datastreams/FluxSat_GPP/FluxSat_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/FluxSat_GPP/readFluxSatobs.F90 b/lvt/datastreams/FluxSat_GPP/readFluxSatobs.F90 index 3ed6d6412..ba689dbd2 100755 --- a/lvt/datastreams/FluxSat_GPP/readFluxSatobs.F90 +++ b/lvt/datastreams/FluxSat_GPP/readFluxSatobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 b/lvt/datastreams/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 index 7caa5e12e..f84f4ddf1 100644 --- a/lvt/datastreams/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 +++ b/lvt/datastreams/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 b/lvt/datastreams/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 index d99452105..c4088247b 100644 --- a/lvt/datastreams/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 +++ b/lvt/datastreams/GCOMW_AMSR2L3sm/readGCOMW_AMSR2L3smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 b/lvt/datastreams/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 index 56c01752a..0bf43d9e1 100644 --- a/lvt/datastreams/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 +++ b/lvt/datastreams/GCOMW_AMSR2L3snd/GCOMW_AMSR2L3snd_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 b/lvt/datastreams/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 index e5f918d72..12e84c79c 100644 --- a/lvt/datastreams/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 +++ b/lvt/datastreams/GCOMW_AMSR2L3snd/readGCOMW_AMSR2L3sndObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GDASforc/GDASforc_dataMod.F90 b/lvt/datastreams/GDASforc/GDASforc_dataMod.F90 index 4a83c9a12..678acbf66 100755 --- a/lvt/datastreams/GDASforc/GDASforc_dataMod.F90 +++ b/lvt/datastreams/GDASforc/GDASforc_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GDASforc/readGDASforcdata.F90 b/lvt/datastreams/GDASforc/readGDASforcdata.F90 index ad40faaef..47aee19b3 100755 --- a/lvt/datastreams/GDASforc/readGDASforcdata.F90 +++ b/lvt/datastreams/GDASforc/readGDASforcdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GHCN/GHCN_obsMod.F90 b/lvt/datastreams/GHCN/GHCN_obsMod.F90 index 87a14d13b..95286bae2 100644 --- a/lvt/datastreams/GHCN/GHCN_obsMod.F90 +++ b/lvt/datastreams/GHCN/GHCN_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GHCN/readGHCNObs.F90 b/lvt/datastreams/GHCN/readGHCNObs.F90 index 141bc2866..ff21561b3 100644 --- a/lvt/datastreams/GHCN/readGHCNObs.F90 +++ b/lvt/datastreams/GHCN/readGHCNObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GIMMS_AVHRR_NDVI/GIMMSAVHRR_NDVIobsMod.F90 b/lvt/datastreams/GIMMS_AVHRR_NDVI/GIMMSAVHRR_NDVIobsMod.F90 index 39bdde526..1c997acb2 100644 --- a/lvt/datastreams/GIMMS_AVHRR_NDVI/GIMMSAVHRR_NDVIobsMod.F90 +++ b/lvt/datastreams/GIMMS_AVHRR_NDVI/GIMMSAVHRR_NDVIobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GIMMS_AVHRR_NDVI/readGIMMSAVHRR_NDVIObs.F90 b/lvt/datastreams/GIMMS_AVHRR_NDVI/readGIMMSAVHRR_NDVIObs.F90 index 34a261375..1afc3a595 100644 --- a/lvt/datastreams/GIMMS_AVHRR_NDVI/readGIMMSAVHRR_NDVIObs.F90 +++ b/lvt/datastreams/GIMMS_AVHRR_NDVI/readGIMMSAVHRR_NDVIObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GIMMS_MODIS_NDVI/GIMMSMODIS_NDVIobsMod.F90 b/lvt/datastreams/GIMMS_MODIS_NDVI/GIMMSMODIS_NDVIobsMod.F90 index 8c56ce60a..0c6159efd 100644 --- a/lvt/datastreams/GIMMS_MODIS_NDVI/GIMMSMODIS_NDVIobsMod.F90 +++ b/lvt/datastreams/GIMMS_MODIS_NDVI/GIMMSMODIS_NDVIobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GIMMS_MODIS_NDVI/readGIMMSMODIS_NDVIObs.F90 b/lvt/datastreams/GIMMS_MODIS_NDVI/readGIMMSMODIS_NDVIObs.F90 index 29b838738..861f08900 100644 --- a/lvt/datastreams/GIMMS_MODIS_NDVI/readGIMMSMODIS_NDVIObs.F90 +++ b/lvt/datastreams/GIMMS_MODIS_NDVI/readGIMMSMODIS_NDVIObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLASSalbedo/GLASSalbedo_Mod.F90 b/lvt/datastreams/GLASSalbedo/GLASSalbedo_Mod.F90 index 05e60dbf5..feccd0d47 100755 --- a/lvt/datastreams/GLASSalbedo/GLASSalbedo_Mod.F90 +++ b/lvt/datastreams/GLASSalbedo/GLASSalbedo_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLASSalbedo/readGLASSalbedoObs.F90 b/lvt/datastreams/GLASSalbedo/readGLASSalbedoObs.F90 index e7689b733..8569fa273 100755 --- a/lvt/datastreams/GLASSalbedo/readGLASSalbedoObs.F90 +++ b/lvt/datastreams/GLASSalbedo/readGLASSalbedoObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLASSlai/GLASSlai_obsMod.F90 b/lvt/datastreams/GLASSlai/GLASSlai_obsMod.F90 index b56c0a887..d36b86034 100644 --- a/lvt/datastreams/GLASSlai/GLASSlai_obsMod.F90 +++ b/lvt/datastreams/GLASSlai/GLASSlai_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLASSlai/readGLASSlaiObs.F90 b/lvt/datastreams/GLASSlai/readGLASSlaiObs.F90 index ec83fcd37..fb86ded6b 100644 --- a/lvt/datastreams/GLASSlai/readGLASSlaiObs.F90 +++ b/lvt/datastreams/GLASSlai/readGLASSlaiObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLDAS1/GLDAS1obsMod.F90 b/lvt/datastreams/GLDAS1/GLDAS1obsMod.F90 index 9c8db9087..0e9ab163e 100644 --- a/lvt/datastreams/GLDAS1/GLDAS1obsMod.F90 +++ b/lvt/datastreams/GLDAS1/GLDAS1obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLDAS1/readGLDAS1obs.F90 b/lvt/datastreams/GLDAS1/readGLDAS1obs.F90 index 41ec94bce..bb5899c50 100644 --- a/lvt/datastreams/GLDAS1/readGLDAS1obs.F90 +++ b/lvt/datastreams/GLDAS1/readGLDAS1obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLDAS2/GLDAS2obsMod.F90 b/lvt/datastreams/GLDAS2/GLDAS2obsMod.F90 index 1aa4ab95c..24902b149 100644 --- a/lvt/datastreams/GLDAS2/GLDAS2obsMod.F90 +++ b/lvt/datastreams/GLDAS2/GLDAS2obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLDAS2/readGLDAS2obs.F90 b/lvt/datastreams/GLDAS2/readGLDAS2obs.F90 index 385f2965b..4a704aae6 100644 --- a/lvt/datastreams/GLDAS2/readGLDAS2obs.F90 +++ b/lvt/datastreams/GLDAS2/readGLDAS2obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLEAM/GLEAM_obsMod.F90 b/lvt/datastreams/GLEAM/GLEAM_obsMod.F90 index 0df666d84..52442910a 100644 --- a/lvt/datastreams/GLEAM/GLEAM_obsMod.F90 +++ b/lvt/datastreams/GLEAM/GLEAM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLEAM/readGLEAMObs.F90 b/lvt/datastreams/GLEAM/readGLEAMObs.F90 index 99ed217cc..b7c83daa1 100644 --- a/lvt/datastreams/GLEAM/readGLEAMObs.F90 +++ b/lvt/datastreams/GLEAM/readGLEAMObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLERL_HydroData/GLERL_dataMod.F90 b/lvt/datastreams/GLERL_HydroData/GLERL_dataMod.F90 index 251d4a24f..6677a57f9 100644 --- a/lvt/datastreams/GLERL_HydroData/GLERL_dataMod.F90 +++ b/lvt/datastreams/GLERL_HydroData/GLERL_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GLERL_HydroData/readGLERLobs.F90 b/lvt/datastreams/GLERL_HydroData/readGLERLobs.F90 index a52a1e906..2e835f5ab 100644 --- a/lvt/datastreams/GLERL_HydroData/readGLERLobs.F90 +++ b/lvt/datastreams/GLERL_HydroData/readGLERLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GOES_LST/GOES_LSTobsMod.F90 b/lvt/datastreams/GOES_LST/GOES_LSTobsMod.F90 index 8fccdd16d..5268a4385 100644 --- a/lvt/datastreams/GOES_LST/GOES_LSTobsMod.F90 +++ b/lvt/datastreams/GOES_LST/GOES_LSTobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GOES_LST/readGOES_LSTObs.F90 b/lvt/datastreams/GOES_LST/readGOES_LSTObs.F90 index 2a2fe2c9f..a84de441f 100644 --- a/lvt/datastreams/GOES_LST/readGOES_LSTObs.F90 +++ b/lvt/datastreams/GOES_LST/readGOES_LSTObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GOME2_SIF/GOME2_SIFobsMod.F90 b/lvt/datastreams/GOME2_SIF/GOME2_SIFobsMod.F90 index 04a464b79..bf8972728 100644 --- a/lvt/datastreams/GOME2_SIF/GOME2_SIFobsMod.F90 +++ b/lvt/datastreams/GOME2_SIF/GOME2_SIFobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GOME2_SIF/readGOME2_SIFObs.F90 b/lvt/datastreams/GOME2_SIF/readGOME2_SIFObs.F90 index 27aeb0611..e6bd1eb28 100644 --- a/lvt/datastreams/GOME2_SIF/readGOME2_SIFObs.F90 +++ b/lvt/datastreams/GOME2_SIF/readGOME2_SIFObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRACE/GRACE_obsMod.F90 b/lvt/datastreams/GRACE/GRACE_obsMod.F90 index 7cae3fd51..aee5663c6 100644 --- a/lvt/datastreams/GRACE/GRACE_obsMod.F90 +++ b/lvt/datastreams/GRACE/GRACE_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRACE/readGRACEObs.F90 b/lvt/datastreams/GRACE/readGRACEObs.F90 index 1a81ce130..83fffed4a 100644 --- a/lvt/datastreams/GRACE/readGRACEObs.F90 +++ b/lvt/datastreams/GRACE/readGRACEObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRDC/GRDC_obsMod.F90 b/lvt/datastreams/GRDC/GRDC_obsMod.F90 index 62581749d..583a09250 100644 --- a/lvt/datastreams/GRDC/GRDC_obsMod.F90 +++ b/lvt/datastreams/GRDC/GRDC_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRDC/readGRDCobs.F90 b/lvt/datastreams/GRDC/readGRDCobs.F90 index 710bf8768..92ef9e220 100644 --- a/lvt/datastreams/GRDC/readGRDCobs.F90 +++ b/lvt/datastreams/GRDC/readGRDCobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRUNrunoff/GRUNrunoff_obsMod.F90 b/lvt/datastreams/GRUNrunoff/GRUNrunoff_obsMod.F90 index 69c403387..12e3387a9 100644 --- a/lvt/datastreams/GRUNrunoff/GRUNrunoff_obsMod.F90 +++ b/lvt/datastreams/GRUNrunoff/GRUNrunoff_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GRUNrunoff/readGRUNrunoffobs.F90 b/lvt/datastreams/GRUNrunoff/readGRUNrunoffobs.F90 index b598f7582..75cbb04ff 100644 --- a/lvt/datastreams/GRUNrunoff/readGRUNrunoffobs.F90 +++ b/lvt/datastreams/GRUNrunoff/readGRUNrunoffobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GlobSnow/GlobSnow_obsMod.F90 b/lvt/datastreams/GlobSnow/GlobSnow_obsMod.F90 index 5b5fe0163..969762d92 100644 --- a/lvt/datastreams/GlobSnow/GlobSnow_obsMod.F90 +++ b/lvt/datastreams/GlobSnow/GlobSnow_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/GlobSnow/readGlobSnowObs.F90 b/lvt/datastreams/GlobSnow/readGlobSnowObs.F90 index 636ef3b79..7dc10c50a 100644 --- a/lvt/datastreams/GlobSnow/readGlobSnowObs.F90 +++ b/lvt/datastreams/GlobSnow/readGlobSnowObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/HAR/HAR_dataMod.F90 b/lvt/datastreams/HAR/HAR_dataMod.F90 index e68ed2142..51967756e 100755 --- a/lvt/datastreams/HAR/HAR_dataMod.F90 +++ b/lvt/datastreams/HAR/HAR_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/HAR/readHARdata.F90 b/lvt/datastreams/HAR/readHARdata.F90 index b1a714072..1711bfbb8 100755 --- a/lvt/datastreams/HAR/readHARdata.F90 +++ b/lvt/datastreams/HAR/readHARdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMD_PRCP/IMDPRCP_obsMod.F90 b/lvt/datastreams/IMD_PRCP/IMDPRCP_obsMod.F90 index ea30f84c8..d5c9ef3ce 100644 --- a/lvt/datastreams/IMD_PRCP/IMDPRCP_obsMod.F90 +++ b/lvt/datastreams/IMD_PRCP/IMDPRCP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMD_PRCP/readIMDPRCPObs.F90 b/lvt/datastreams/IMD_PRCP/readIMDPRCPObs.F90 index 72b0d69d7..203abbef2 100644 --- a/lvt/datastreams/IMD_PRCP/readIMDPRCPObs.F90 +++ b/lvt/datastreams/IMD_PRCP/readIMDPRCPObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMERG/IMERG_dataMod.F90 b/lvt/datastreams/IMERG/IMERG_dataMod.F90 index 80fa515c9..4af34c156 100644 --- a/lvt/datastreams/IMERG/IMERG_dataMod.F90 +++ b/lvt/datastreams/IMERG/IMERG_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMERG/readIMERGdata.F90 b/lvt/datastreams/IMERG/readIMERGdata.F90 index ba5c14ea5..6764ef614 100644 --- a/lvt/datastreams/IMERG/readIMERGdata.F90 +++ b/lvt/datastreams/IMERG/readIMERGdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 index 9a98a1c91..e4d007120 100644 --- a/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 +++ b/lvt/datastreams/IMERG_monthly/IMERG_monthly_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 index b0da4236e..e1d04e85f 100644 --- a/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 +++ b/lvt/datastreams/IMERG_monthly/readIMERGmonthlydata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ISCCP_Tskin/ISCCP_TskinobsMod.F90 b/lvt/datastreams/ISCCP_Tskin/ISCCP_TskinobsMod.F90 index 1ee6031ad..3e7b362bb 100644 --- a/lvt/datastreams/ISCCP_Tskin/ISCCP_TskinobsMod.F90 +++ b/lvt/datastreams/ISCCP_Tskin/ISCCP_TskinobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ISCCP_Tskin/readISCCP_TskinObs.F90 b/lvt/datastreams/ISCCP_Tskin/readISCCP_TskinObs.F90 index ce907cf74..98ce3aef9 100644 --- a/lvt/datastreams/ISCCP_Tskin/readISCCP_TskinObs.F90 +++ b/lvt/datastreams/ISCCP_Tskin/readISCCP_TskinObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ISMN/ISMN_obsMod.F90 b/lvt/datastreams/ISMN/ISMN_obsMod.F90 index a614c5c92..de468e1fc 100644 --- a/lvt/datastreams/ISMN/ISMN_obsMod.F90 +++ b/lvt/datastreams/ISMN/ISMN_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/ISMN/readISMNObs.F90 b/lvt/datastreams/ISMN/readISMNObs.F90 index 3a3565226..f1a073b20 100644 --- a/lvt/datastreams/ISMN/readISMNObs.F90 +++ b/lvt/datastreams/ISMN/readISMNObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/JULES2Ddata/JULES2D_obsMod.F90 b/lvt/datastreams/JULES2Ddata/JULES2D_obsMod.F90 index 4a2ccd0a3..5ddec6720 100755 --- a/lvt/datastreams/JULES2Ddata/JULES2D_obsMod.F90 +++ b/lvt/datastreams/JULES2Ddata/JULES2D_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/JULES2Ddata/readJULES2Dobs.F90 b/lvt/datastreams/JULES2Ddata/readJULES2Dobs.F90 index 4bc5305c0..3e04c85f3 100755 --- a/lvt/datastreams/JULES2Ddata/readJULES2Dobs.F90 +++ b/lvt/datastreams/JULES2Ddata/readJULES2Dobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/JULESdata/JULES_obsMod.F90 b/lvt/datastreams/JULESdata/JULES_obsMod.F90 index b02a81262..c19983762 100644 --- a/lvt/datastreams/JULESdata/JULES_obsMod.F90 +++ b/lvt/datastreams/JULESdata/JULES_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/JULESdata/readJULESobs.F90 b/lvt/datastreams/JULESdata/readJULESobs.F90 index cbdc2d95a..ff6898783 100644 --- a/lvt/datastreams/JULESdata/readJULESobs.F90 +++ b/lvt/datastreams/JULESdata/readJULESobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LIS6out/LIS6outputMod.F90 b/lvt/datastreams/LIS6out/LIS6outputMod.F90 index 085739fda..3df6a379c 100644 --- a/lvt/datastreams/LIS6out/LIS6outputMod.F90 +++ b/lvt/datastreams/LIS6out/LIS6outputMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LIS6out/readLIS6output.F90 b/lvt/datastreams/LIS6out/readLIS6output.F90 index 392604089..b1bd39fdd 100644 --- a/lvt/datastreams/LIS6out/readLIS6output.F90 +++ b/lvt/datastreams/LIS6out/readLIS6output.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISDAdiag/LISDAdiagOutputMod.F90 b/lvt/datastreams/LISDAdiag/LISDAdiagOutputMod.F90 index 02593fd7d..d5728ac07 100644 --- a/lvt/datastreams/LISDAdiag/LISDAdiagOutputMod.F90 +++ b/lvt/datastreams/LISDAdiag/LISDAdiagOutputMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISDAdiag/readLISDAdiagOutput.F90 b/lvt/datastreams/LISDAdiag/readLISDAdiagOutput.F90 index e3258a52c..3d6eee860 100644 --- a/lvt/datastreams/LISDAdiag/readLISDAdiagOutput.F90 +++ b/lvt/datastreams/LISDAdiag/readLISDAdiagOutput.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISDAobs/LISda_obsMod.F90 b/lvt/datastreams/LISDAobs/LISda_obsMod.F90 index fd5829c93..fc5992227 100644 --- a/lvt/datastreams/LISDAobs/LISda_obsMod.F90 +++ b/lvt/datastreams/LISDAobs/LISda_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISDAobs/readLISdaAsObs.F90 b/lvt/datastreams/LISDAobs/readLISdaAsObs.F90 index 9bbd5bafe..dd78e1e9e 100644 --- a/lvt/datastreams/LISDAobs/readLISdaAsObs.F90 +++ b/lvt/datastreams/LISDAobs/readLISdaAsObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISout/LISoutputMod.F90 b/lvt/datastreams/LISout/LISoutputMod.F90 index af7f541f0..7e5054db9 100644 --- a/lvt/datastreams/LISout/LISoutputMod.F90 +++ b/lvt/datastreams/LISout/LISoutputMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LISout/readLISoutput.F90 b/lvt/datastreams/LISout/readLISoutput.F90 index 465725d46..4a9a2b4e4 100644 --- a/lvt/datastreams/LISout/readLISoutput.F90 +++ b/lvt/datastreams/LISout/readLISoutput.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LPRM_AMSRE_sm/LPRM_AMSREsm_obsMod.F90 b/lvt/datastreams/LPRM_AMSRE_sm/LPRM_AMSREsm_obsMod.F90 index 8b6b893b1..bdaa9eb86 100644 --- a/lvt/datastreams/LPRM_AMSRE_sm/LPRM_AMSREsm_obsMod.F90 +++ b/lvt/datastreams/LPRM_AMSRE_sm/LPRM_AMSREsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LPRM_AMSRE_sm/readLPRM_AMSREsmObs.F90 b/lvt/datastreams/LPRM_AMSRE_sm/readLPRM_AMSREsmObs.F90 index d5742c402..abca44501 100644 --- a/lvt/datastreams/LPRM_AMSRE_sm/readLPRM_AMSREsmObs.F90 +++ b/lvt/datastreams/LPRM_AMSRE_sm/readLPRM_AMSREsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LPRMvod/LPRM_vodobsMod.F90 b/lvt/datastreams/LPRMvod/LPRM_vodobsMod.F90 index 0c49ec379..31a4afe02 100644 --- a/lvt/datastreams/LPRMvod/LPRM_vodobsMod.F90 +++ b/lvt/datastreams/LPRMvod/LPRM_vodobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LPRMvod/readLPRMvodobs.F90 b/lvt/datastreams/LPRMvod/readLPRMvodobs.F90 index 38257792f..6e69a2696 100644 --- a/lvt/datastreams/LPRMvod/readLPRMvodobs.F90 +++ b/lvt/datastreams/LPRMvod/readLPRMvodobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LSWG_Tb/LSWG_Tb_obsMod.F90 b/lvt/datastreams/LSWG_Tb/LSWG_Tb_obsMod.F90 index f30ca1515..a07bad8ef 100755 --- a/lvt/datastreams/LSWG_Tb/LSWG_Tb_obsMod.F90 +++ b/lvt/datastreams/LSWG_Tb/LSWG_Tb_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LSWG_Tb/read_LSWG_Tb_Obs.F90 b/lvt/datastreams/LSWG_Tb/read_LSWG_Tb_Obs.F90 index 83ebb2aa3..7ab8e33fe 100755 --- a/lvt/datastreams/LSWG_Tb/read_LSWG_Tb_Obs.F90 +++ b/lvt/datastreams/LSWG_Tb/read_LSWG_Tb_Obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LVTbenchmarkOUT/LVTbenchmarkOUT_obsMod.F90 b/lvt/datastreams/LVTbenchmarkOUT/LVTbenchmarkOUT_obsMod.F90 index cc5d4c6d8..f5e2ca562 100644 --- a/lvt/datastreams/LVTbenchmarkOUT/LVTbenchmarkOUT_obsMod.F90 +++ b/lvt/datastreams/LVTbenchmarkOUT/LVTbenchmarkOUT_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LVTbenchmarkOUT/readLVTbenchmarkOUTobs.F90 b/lvt/datastreams/LVTbenchmarkOUT/readLVTbenchmarkOUTobs.F90 index 40ecd85d9..b3873daa8 100644 --- a/lvt/datastreams/LVTbenchmarkOUT/readLVTbenchmarkOUTobs.F90 +++ b/lvt/datastreams/LVTbenchmarkOUT/readLVTbenchmarkOUTobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LVTpercentile/LVTpercentile_obsMod.F90 b/lvt/datastreams/LVTpercentile/LVTpercentile_obsMod.F90 index 593fea45f..5f5c49f55 100644 --- a/lvt/datastreams/LVTpercentile/LVTpercentile_obsMod.F90 +++ b/lvt/datastreams/LVTpercentile/LVTpercentile_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/LVTpercentile/readLVTpercentileAsObs.F90 b/lvt/datastreams/LVTpercentile/readLVTpercentileAsObs.F90 index 61f33a265..42f28addb 100644 --- a/lvt/datastreams/LVTpercentile/readLVTpercentileAsObs.F90 +++ b/lvt/datastreams/LVTpercentile/readLVTpercentileAsObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MCD15A2H/MCD15A2H_obsMod.F90 b/lvt/datastreams/MCD15A2H/MCD15A2H_obsMod.F90 index 9e545230d..2ad2977ed 100755 --- a/lvt/datastreams/MCD15A2H/MCD15A2H_obsMod.F90 +++ b/lvt/datastreams/MCD15A2H/MCD15A2H_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MCD15A2H/readMCD15A2Hobs.F90 b/lvt/datastreams/MCD15A2H/readMCD15A2Hobs.F90 index ec1179d23..ebf8eba9a 100755 --- a/lvt/datastreams/MCD15A2H/readMCD15A2Hobs.F90 +++ b/lvt/datastreams/MCD15A2H/readMCD15A2Hobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA-Land/MERRAlandObsMod.F90 b/lvt/datastreams/MERRA-Land/MERRAlandObsMod.F90 index 08c54f340..6a3f1c3ca 100644 --- a/lvt/datastreams/MERRA-Land/MERRAlandObsMod.F90 +++ b/lvt/datastreams/MERRA-Land/MERRAlandObsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA-Land/readMERRAlandObs.F90 b/lvt/datastreams/MERRA-Land/readMERRAlandObs.F90 index 8be497ebc..e6f794e42 100644 --- a/lvt/datastreams/MERRA-Land/readMERRAlandObs.F90 +++ b/lvt/datastreams/MERRA-Land/readMERRAlandObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA2/MERRA2obsMod.F90 b/lvt/datastreams/MERRA2/MERRA2obsMod.F90 index 241586f21..a335a0fb5 100644 --- a/lvt/datastreams/MERRA2/MERRA2obsMod.F90 +++ b/lvt/datastreams/MERRA2/MERRA2obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA2/readMERRA2obs.F90 b/lvt/datastreams/MERRA2/readMERRA2obs.F90 index dc529d745..1cad8ce73 100644 --- a/lvt/datastreams/MERRA2/readMERRA2obs.F90 +++ b/lvt/datastreams/MERRA2/readMERRA2obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA2asm/MERRA2asmobsMod.F90 b/lvt/datastreams/MERRA2asm/MERRA2asmobsMod.F90 index dc72f32c3..26c67618f 100644 --- a/lvt/datastreams/MERRA2asm/MERRA2asmobsMod.F90 +++ b/lvt/datastreams/MERRA2asm/MERRA2asmobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MERRA2asm/readMERRA2asmobs.F90 b/lvt/datastreams/MERRA2asm/readMERRA2asmobs.F90 index 3d998bb80..54b2eec95 100644 --- a/lvt/datastreams/MERRA2asm/readMERRA2asmobs.F90 +++ b/lvt/datastreams/MERRA2asm/readMERRA2asmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD10A1/MOD10A1_obsMod.F90 b/lvt/datastreams/MOD10A1/MOD10A1_obsMod.F90 index d6fcc4d39..e67eef6f5 100644 --- a/lvt/datastreams/MOD10A1/MOD10A1_obsMod.F90 +++ b/lvt/datastreams/MOD10A1/MOD10A1_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD10A1/readMOD10A1obs.F90 b/lvt/datastreams/MOD10A1/readMOD10A1obs.F90 index 339b9d760..f345439c7 100644 --- a/lvt/datastreams/MOD10A1/readMOD10A1obs.F90 +++ b/lvt/datastreams/MOD10A1/readMOD10A1obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD10A1V6/MOD10A1V6_obsMod.F90 b/lvt/datastreams/MOD10A1V6/MOD10A1V6_obsMod.F90 index 9001f39d4..1144b82f5 100644 --- a/lvt/datastreams/MOD10A1V6/MOD10A1V6_obsMod.F90 +++ b/lvt/datastreams/MOD10A1V6/MOD10A1V6_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD10A1V6/readMOD10A1V6obs.F90 b/lvt/datastreams/MOD10A1V6/readMOD10A1V6obs.F90 index 32e80c43b..3cf69059f 100644 --- a/lvt/datastreams/MOD10A1V6/readMOD10A1V6obs.F90 +++ b/lvt/datastreams/MOD10A1V6/readMOD10A1V6obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD16A2/MOD16A2_obsMod.F90 b/lvt/datastreams/MOD16A2/MOD16A2_obsMod.F90 index 5ab9060d9..0d0bb726d 100644 --- a/lvt/datastreams/MOD16A2/MOD16A2_obsMod.F90 +++ b/lvt/datastreams/MOD16A2/MOD16A2_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MOD16A2/readMOD16A2Obs.F90 b/lvt/datastreams/MOD16A2/readMOD16A2Obs.F90 index 027e76661..8bf51db08 100644 --- a/lvt/datastreams/MOD16A2/readMOD16A2Obs.F90 +++ b/lvt/datastreams/MOD16A2/readMOD16A2Obs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODIS_LST/MODIS_LSTobsMod.F90 b/lvt/datastreams/MODIS_LST/MODIS_LSTobsMod.F90 index 49900a390..46c0e1547 100644 --- a/lvt/datastreams/MODIS_LST/MODIS_LSTobsMod.F90 +++ b/lvt/datastreams/MODIS_LST/MODIS_LSTobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODIS_LST/readMODIS_LSTObs.F90 b/lvt/datastreams/MODIS_LST/readMODIS_LSTObs.F90 index 4a1ebbb66..c00ddac2f 100644 --- a/lvt/datastreams/MODIS_LST/readMODIS_LSTObs.F90 +++ b/lvt/datastreams/MODIS_LST/readMODIS_LSTObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODISsportLAI/MODISsportLAIobsMod.F90 b/lvt/datastreams/MODISsportLAI/MODISsportLAIobsMod.F90 index edf90f7be..7a51e6df6 100755 --- a/lvt/datastreams/MODISsportLAI/MODISsportLAIobsMod.F90 +++ b/lvt/datastreams/MODISsportLAI/MODISsportLAIobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODISsportLAI/readMODISsportLAIObs.F90 b/lvt/datastreams/MODISsportLAI/readMODISsportLAIObs.F90 index be9a9abed..f49addb17 100755 --- a/lvt/datastreams/MODISsportLAI/readMODISsportLAIObs.F90 +++ b/lvt/datastreams/MODISsportLAI/readMODISsportLAIObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODSCAG/MODSCAG_obsMod.F90 b/lvt/datastreams/MODSCAG/MODSCAG_obsMod.F90 index 694fb04c2..7331ad449 100755 --- a/lvt/datastreams/MODSCAG/MODSCAG_obsMod.F90 +++ b/lvt/datastreams/MODSCAG/MODSCAG_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/MODSCAG/readMODSCAGobs.F90 b/lvt/datastreams/MODSCAG/readMODSCAGobs.F90 index 219cdd306..11882d35c 100755 --- a/lvt/datastreams/MODSCAG/readMODSCAGobs.F90 +++ b/lvt/datastreams/MODSCAG/readMODSCAGobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 b/lvt/datastreams/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 index baed1c883..6299b7953 100644 --- a/lvt/datastreams/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 +++ b/lvt/datastreams/NASA_AMSRE_sm/NASA_AMSREsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 b/lvt/datastreams/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 index a04a437a9..f7681b55b 100644 --- a/lvt/datastreams/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 +++ b/lvt/datastreams/NASA_AMSRE_sm/readNASA_AMSREsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NASMD/NASMD_obsMod.F90 b/lvt/datastreams/NASMD/NASMD_obsMod.F90 index 615464ddb..3c5610d0f 100644 --- a/lvt/datastreams/NASMD/NASMD_obsMod.F90 +++ b/lvt/datastreams/NASMD/NASMD_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NASMD/readNASMDObs.F90 b/lvt/datastreams/NASMD/readNASMDObs.F90 index ea45da9db..0f5bf09a0 100644 --- a/lvt/datastreams/NASMD/readNASMDObs.F90 +++ b/lvt/datastreams/NASMD/readNASMDObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NLDAS2/NLDAS2_dataMod.F90 b/lvt/datastreams/NLDAS2/NLDAS2_dataMod.F90 index 3c61dd598..2474ba850 100644 --- a/lvt/datastreams/NLDAS2/NLDAS2_dataMod.F90 +++ b/lvt/datastreams/NLDAS2/NLDAS2_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/NLDAS2/readNLDAS2data.F90 b/lvt/datastreams/NLDAS2/readNLDAS2data.F90 index 7bd6c4a43..9f4002cb2 100644 --- a/lvt/datastreams/NLDAS2/readNLDAS2data.F90 +++ b/lvt/datastreams/NLDAS2/readNLDAS2data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Natural_streamflow/NatSF_obsMod.F90 b/lvt/datastreams/Natural_streamflow/NatSF_obsMod.F90 index f7fc93e0f..d5a86da33 100644 --- a/lvt/datastreams/Natural_streamflow/NatSF_obsMod.F90 +++ b/lvt/datastreams/Natural_streamflow/NatSF_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/Natural_streamflow/readNatSFObs.F90 b/lvt/datastreams/Natural_streamflow/readNatSFObs.F90 index cbdaa83c0..3d1842156 100644 --- a/lvt/datastreams/Natural_streamflow/readNatSFObs.F90 +++ b/lvt/datastreams/Natural_streamflow/readNatSFObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/OCO2_SIF/OCO2_SIFobsMod.F90 b/lvt/datastreams/OCO2_SIF/OCO2_SIFobsMod.F90 index 59e2d9456..a0ea8e959 100755 --- a/lvt/datastreams/OCO2_SIF/OCO2_SIFobsMod.F90 +++ b/lvt/datastreams/OCO2_SIF/OCO2_SIFobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/OCO2_SIF/readOCO2_SIFObs.F90 b/lvt/datastreams/OCO2_SIF/readOCO2_SIFObs.F90 index 1f60c55b3..19036722b 100755 --- a/lvt/datastreams/OCO2_SIF/readOCO2_SIFObs.F90 +++ b/lvt/datastreams/OCO2_SIF/readOCO2_SIFObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/OzFlux/OzFlux_obsMod.F90 b/lvt/datastreams/OzFlux/OzFlux_obsMod.F90 index 61e7ad9e7..9bcb6133f 100644 --- a/lvt/datastreams/OzFlux/OzFlux_obsMod.F90 +++ b/lvt/datastreams/OzFlux/OzFlux_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/OzFlux/readOzFluxObs.F90 b/lvt/datastreams/OzFlux/readOzFluxObs.F90 index f3cbacd92..cf26cb542 100644 --- a/lvt/datastreams/OzFlux/readOzFluxObs.F90 +++ b/lvt/datastreams/OzFlux/readOzFluxObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/PBOH2O/PBOH2O_obsMod.F90 b/lvt/datastreams/PBOH2O/PBOH2O_obsMod.F90 index e5e399383..2d1860a25 100644 --- a/lvt/datastreams/PBOH2O/PBOH2O_obsMod.F90 +++ b/lvt/datastreams/PBOH2O/PBOH2O_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/PBOH2O/readPBOH2Oobs.F90 b/lvt/datastreams/PBOH2O/readPBOH2Oobs.F90 index d8df3e084..6ec710f4d 100644 --- a/lvt/datastreams/PBOH2O/readPBOH2Oobs.F90 +++ b/lvt/datastreams/PBOH2O/readPBOH2Oobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SCAN/SCAN_obsMod.F90 b/lvt/datastreams/SCAN/SCAN_obsMod.F90 index f1cc8781a..dc9a8fa07 100644 --- a/lvt/datastreams/SCAN/SCAN_obsMod.F90 +++ b/lvt/datastreams/SCAN/SCAN_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SCAN/readSCANObs.F90 b/lvt/datastreams/SCAN/readSCANObs.F90 index 42319f67a..70691de66 100644 --- a/lvt/datastreams/SCAN/readSCANObs.F90 +++ b/lvt/datastreams/SCAN/readSCANObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SCANGMAO/SCANGMAO_obsMod.F90 b/lvt/datastreams/SCANGMAO/SCANGMAO_obsMod.F90 index bcac5ae84..68c73d060 100644 --- a/lvt/datastreams/SCANGMAO/SCANGMAO_obsMod.F90 +++ b/lvt/datastreams/SCANGMAO/SCANGMAO_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SCANGMAO/readSCANGMAOObs.F90 b/lvt/datastreams/SCANGMAO/readSCANGMAOObs.F90 index 35cfd4f47..8b031df3e 100644 --- a/lvt/datastreams/SCANGMAO/readSCANGMAOObs.F90 +++ b/lvt/datastreams/SCANGMAO/readSCANGMAOObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPTB/SMAP_TBobsMod.F90 b/lvt/datastreams/SMAPTB/SMAP_TBobsMod.F90 index 5da0a9e67..d38434a87 100644 --- a/lvt/datastreams/SMAPTB/SMAP_TBobsMod.F90 +++ b/lvt/datastreams/SMAPTB/SMAP_TBobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPTB/readSMAPTBobs.F90 b/lvt/datastreams/SMAPTB/readSMAPTBobs.F90 index 861f57431..34a7c7cd0 100644 --- a/lvt/datastreams/SMAPTB/readSMAPTBobs.F90 +++ b/lvt/datastreams/SMAPTB/readSMAPTBobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAP_E_OPL/SMAPEOPL_SM_obsMod.F90 b/lvt/datastreams/SMAP_E_OPL/SMAPEOPL_SM_obsMod.F90 index eb10c2d94..bdf04c1ff 100644 --- a/lvt/datastreams/SMAP_E_OPL/SMAPEOPL_SM_obsMod.F90 +++ b/lvt/datastreams/SMAP_E_OPL/SMAPEOPL_SM_obsMod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAP_E_OPL/readSMAPEOPL_SMObs.F90 b/lvt/datastreams/SMAP_E_OPL/readSMAPEOPL_SMObs.F90 index c0a0621f5..201af9d40 100644 --- a/lvt/datastreams/SMAP_E_OPL/readSMAPEOPL_SMObs.F90 +++ b/lvt/datastreams/SMAP_E_OPL/readSMAPEOPL_SMObs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAP_L3TB/SMAP_L3TBMod.F90 b/lvt/datastreams/SMAP_L3TB/SMAP_L3TBMod.F90 index 877365487..069f9025a 100755 --- a/lvt/datastreams/SMAP_L3TB/SMAP_L3TBMod.F90 +++ b/lvt/datastreams/SMAP_L3TB/SMAP_L3TBMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAP_L3TB/readSMAP_L3TB.F90 b/lvt/datastreams/SMAP_L3TB/readSMAP_L3TB.F90 index de05747d8..7f24835ae 100755 --- a/lvt/datastreams/SMAP_L3TB/readSMAP_L3TB.F90 +++ b/lvt/datastreams/SMAP_L3TB/readSMAP_L3TB.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPsm/SMAP_smobsMod.F90 b/lvt/datastreams/SMAPsm/SMAP_smobsMod.F90 index 3ac631fa9..7c86f12db 100644 --- a/lvt/datastreams/SMAPsm/SMAP_smobsMod.F90 +++ b/lvt/datastreams/SMAPsm/SMAP_smobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPsm/readSMAPsmobs.F90 b/lvt/datastreams/SMAPsm/readSMAPsmobs.F90 index 5288491d2..8d3c7573f 100644 --- a/lvt/datastreams/SMAPsm/readSMAPsmobs.F90 +++ b/lvt/datastreams/SMAPsm/readSMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPvod/SMAP_vodobsMod.F90 b/lvt/datastreams/SMAPvod/SMAP_vodobsMod.F90 index 357e2bb2c..c328a991a 100644 --- a/lvt/datastreams/SMAPvod/SMAP_vodobsMod.F90 +++ b/lvt/datastreams/SMAPvod/SMAP_vodobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPvod/readSMAPvodobs.F90 b/lvt/datastreams/SMAPvod/readSMAPvodobs.F90 index dbcb3b59c..968195969 100644 --- a/lvt/datastreams/SMAPvod/readSMAPvodobs.F90 +++ b/lvt/datastreams/SMAPvod/readSMAPvodobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPvwc/SMAP_vwcobsMod.F90 b/lvt/datastreams/SMAPvwc/SMAP_vwcobsMod.F90 index 2f7406148..39fcbef6e 100644 --- a/lvt/datastreams/SMAPvwc/SMAP_vwcobsMod.F90 +++ b/lvt/datastreams/SMAPvwc/SMAP_vwcobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMAPvwc/readSMAPvwcobs.F90 b/lvt/datastreams/SMAPvwc/readSMAPvwcobs.F90 index ab535db76..f4a8f5894 100644 --- a/lvt/datastreams/SMAPvwc/readSMAPvwcobs.F90 +++ b/lvt/datastreams/SMAPvwc/readSMAPvwcobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOPS/SMOPSsm_obsMod.F90 b/lvt/datastreams/SMOPS/SMOPSsm_obsMod.F90 index 7135422fd..a9de6ebe2 100644 --- a/lvt/datastreams/SMOPS/SMOPSsm_obsMod.F90 +++ b/lvt/datastreams/SMOPS/SMOPSsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOPS/readSMOPSsmObs.F90 b/lvt/datastreams/SMOPS/readSMOPSsmObs.F90 index 5f8c1a8c5..987fd6131 100755 --- a/lvt/datastreams/SMOPS/readSMOPSsmObs.F90 +++ b/lvt/datastreams/SMOPS/readSMOPSsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOSREX/SMOSREX_obsMod.F90 b/lvt/datastreams/SMOSREX/SMOSREX_obsMod.F90 index 2488695ac..ba7dade4c 100644 --- a/lvt/datastreams/SMOSREX/SMOSREX_obsMod.F90 +++ b/lvt/datastreams/SMOSREX/SMOSREX_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOSREX/readSMOSREXObs.F90 b/lvt/datastreams/SMOSREX/readSMOSREXObs.F90 index 9f743febb..ba38b4c4c 100644 --- a/lvt/datastreams/SMOSREX/readSMOSREXObs.F90 +++ b/lvt/datastreams/SMOSREX/readSMOSREXObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_CATDS_L3sm/SMOSCATDS_smobsMod.F90 b/lvt/datastreams/SMOS_CATDS_L3sm/SMOSCATDS_smobsMod.F90 index 54b86bdb1..52ad1e584 100644 --- a/lvt/datastreams/SMOS_CATDS_L3sm/SMOSCATDS_smobsMod.F90 +++ b/lvt/datastreams/SMOS_CATDS_L3sm/SMOSCATDS_smobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_CATDS_L3sm/readSMOSCATDSsmobs.F90 b/lvt/datastreams/SMOS_CATDS_L3sm/readSMOSCATDSsmobs.F90 index 1e11cb27d..3c5b06903 100644 --- a/lvt/datastreams/SMOS_CATDS_L3sm/readSMOSCATDSsmobs.F90 +++ b/lvt/datastreams/SMOS_CATDS_L3sm/readSMOSCATDSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_L1TB/SMOSL1TB_obsMod.F90 b/lvt/datastreams/SMOS_L1TB/SMOSL1TB_obsMod.F90 index fdd3557d2..fc739de09 100644 --- a/lvt/datastreams/SMOS_L1TB/SMOSL1TB_obsMod.F90 +++ b/lvt/datastreams/SMOS_L1TB/SMOSL1TB_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_L1TB/readSMOSL1TBObs.F90 b/lvt/datastreams/SMOS_L1TB/readSMOSL1TBObs.F90 index 892751c2b..7afb970ce 100644 --- a/lvt/datastreams/SMOS_L1TB/readSMOSL1TBObs.F90 +++ b/lvt/datastreams/SMOS_L1TB/readSMOSL1TBObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_L2sm/SMOSL2sm_obsMod.F90 b/lvt/datastreams/SMOS_L2sm/SMOSL2sm_obsMod.F90 index 19f793412..c77e5a9bb 100644 --- a/lvt/datastreams/SMOS_L2sm/SMOSL2sm_obsMod.F90 +++ b/lvt/datastreams/SMOS_L2sm/SMOSL2sm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_L2sm/readSMOSL2smObs.F90 b/lvt/datastreams/SMOS_L2sm/readSMOSL2smObs.F90 index 6449cc425..978234f61 100644 --- a/lvt/datastreams/SMOS_L2sm/readSMOSL2smObs.F90 +++ b/lvt/datastreams/SMOS_L2sm/readSMOSL2smObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_NESDIS/SMOSNESDIS_smobsMod.F90 b/lvt/datastreams/SMOS_NESDIS/SMOSNESDIS_smobsMod.F90 index 309d59a97..4416cbd32 100644 --- a/lvt/datastreams/SMOS_NESDIS/SMOSNESDIS_smobsMod.F90 +++ b/lvt/datastreams/SMOS_NESDIS/SMOSNESDIS_smobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SMOS_NESDIS/readSMOSNESDISsmobs.F90 b/lvt/datastreams/SMOS_NESDIS/readSMOSNESDISsmobs.F90 index 47d13bc08..c4b2916a9 100644 --- a/lvt/datastreams/SMOS_NESDIS/readSMOSNESDISsmobs.F90 +++ b/lvt/datastreams/SMOS_NESDIS/readSMOSNESDISsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODAS/SNODAS_obsMod.F90 b/lvt/datastreams/SNODAS/SNODAS_obsMod.F90 index 87b8a1b4c..958986132 100644 --- a/lvt/datastreams/SNODAS/SNODAS_obsMod.F90 +++ b/lvt/datastreams/SNODAS/SNODAS_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODAS/readSNODASObs.F90 b/lvt/datastreams/SNODAS/readSNODASObs.F90 index d75dbf2ac..a6fe9aa94 100644 --- a/lvt/datastreams/SNODAS/readSNODASObs.F90 +++ b/lvt/datastreams/SNODAS/readSNODASObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODEP/SNODEP_obsMod.F90 b/lvt/datastreams/SNODEP/SNODEP_obsMod.F90 index 40fdf7cfe..74ae92755 100644 --- a/lvt/datastreams/SNODEP/SNODEP_obsMod.F90 +++ b/lvt/datastreams/SNODEP/SNODEP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODEP/readSNODEPobs.F90 b/lvt/datastreams/SNODEP/readSNODEPobs.F90 index 8c1d324e1..86257887b 100644 --- a/lvt/datastreams/SNODEP/readSNODEPobs.F90 +++ b/lvt/datastreams/SNODEP/readSNODEPobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODEPmetobs/SNODEP_metobsMod.F90 b/lvt/datastreams/SNODEPmetobs/SNODEP_metobsMod.F90 index 11366491c..68dd63217 100644 --- a/lvt/datastreams/SNODEPmetobs/SNODEP_metobsMod.F90 +++ b/lvt/datastreams/SNODEPmetobs/SNODEP_metobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNODEPmetobs/readSNODEPmetobs.F90 b/lvt/datastreams/SNODEPmetobs/readSNODEPmetobs.F90 index 64cab849d..59d47ebcf 100644 --- a/lvt/datastreams/SNODEPmetobs/readSNODEPmetobs.F90 +++ b/lvt/datastreams/SNODEPmetobs/readSNODEPmetobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNOTEL/SNOTEL_obsMod.F90 b/lvt/datastreams/SNOTEL/SNOTEL_obsMod.F90 index 3dced2324..8a1eb9c95 100644 --- a/lvt/datastreams/SNOTEL/SNOTEL_obsMod.F90 +++ b/lvt/datastreams/SNOTEL/SNOTEL_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SNOTEL/readSNOTELObs.F90 b/lvt/datastreams/SNOTEL/readSNOTELObs.F90 index b32e27d19..e920ae9a5 100644 --- a/lvt/datastreams/SNOTEL/readSNOTELObs.F90 +++ b/lvt/datastreams/SNOTEL/readSNOTELObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SSEBop/SSEBop_obsMod.F90 b/lvt/datastreams/SSEBop/SSEBop_obsMod.F90 index 9f65e5001..1f8be924d 100644 --- a/lvt/datastreams/SSEBop/SSEBop_obsMod.F90 +++ b/lvt/datastreams/SSEBop/SSEBop_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SSEBop/readSSEBopObs.F90 b/lvt/datastreams/SSEBop/readSSEBopObs.F90 index aaf4d32cf..ea409a189 100644 --- a/lvt/datastreams/SSEBop/readSSEBopObs.F90 +++ b/lvt/datastreams/SSEBop/readSSEBopObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SURFRAD/SURFRAD_obsMod.F90 b/lvt/datastreams/SURFRAD/SURFRAD_obsMod.F90 index 230d1e46a..44bfee3c5 100644 --- a/lvt/datastreams/SURFRAD/SURFRAD_obsMod.F90 +++ b/lvt/datastreams/SURFRAD/SURFRAD_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/SURFRAD/readSURFRADObs.F90 b/lvt/datastreams/SURFRAD/readSURFRADObs.F90 index ccfc328e4..a9c3f5e6c 100644 --- a/lvt/datastreams/SURFRAD/readSURFRADObs.F90 +++ b/lvt/datastreams/SURFRAD/readSURFRADObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/THySM/THySM_obsMod.F90 b/lvt/datastreams/THySM/THySM_obsMod.F90 index b649f5a61..fc1b38b8a 100644 --- a/lvt/datastreams/THySM/THySM_obsMod.F90 +++ b/lvt/datastreams/THySM/THySM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/THySM/readTHySMobs.F90 b/lvt/datastreams/THySM/readTHySMobs.F90 index 11c29a665..81dc64a37 100644 --- a/lvt/datastreams/THySM/readTHySMobs.F90 +++ b/lvt/datastreams/THySM/readTHySMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UASMAP/UASMAP_obsMod.F90 b/lvt/datastreams/UASMAP/UASMAP_obsMod.F90 index b7a27a35d..f355c5866 100644 --- a/lvt/datastreams/UASMAP/UASMAP_obsMod.F90 +++ b/lvt/datastreams/UASMAP/UASMAP_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UASMAP/readUASMAPobs.F90 b/lvt/datastreams/UASMAP/readUASMAPobs.F90 index ad7461c26..5da0c2b8b 100644 --- a/lvt/datastreams/UASMAP/readUASMAPobs.F90 +++ b/lvt/datastreams/UASMAP/readUASMAPobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UA_SNOW/UASNOW_obsMod.F90 b/lvt/datastreams/UA_SNOW/UASNOW_obsMod.F90 index ead041c54..31f80cf9e 100755 --- a/lvt/datastreams/UA_SNOW/UASNOW_obsMod.F90 +++ b/lvt/datastreams/UA_SNOW/UASNOW_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UA_SNOW/readUASNOWObs.F90 b/lvt/datastreams/UA_SNOW/readUASNOWObs.F90 index 37ef3f1a3..537a46012 100755 --- a/lvt/datastreams/UA_SNOW/readUASNOWObs.F90 +++ b/lvt/datastreams/UA_SNOW/readUASNOWObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UCLA_SWE_reanal/UCLASWEreanal_dataMod.F90 b/lvt/datastreams/UCLA_SWE_reanal/UCLASWEreanal_dataMod.F90 index d97660fbb..4eeb544fc 100644 --- a/lvt/datastreams/UCLA_SWE_reanal/UCLASWEreanal_dataMod.F90 +++ b/lvt/datastreams/UCLA_SWE_reanal/UCLASWEreanal_dataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UCLA_SWE_reanal/readUCLASWEreanal.F90 b/lvt/datastreams/UCLA_SWE_reanal/readUCLASWEreanal.F90 index a8756c98d..855221143 100644 --- a/lvt/datastreams/UCLA_SWE_reanal/readUCLASWEreanal.F90 +++ b/lvt/datastreams/UCLA_SWE_reanal/readUCLASWEreanal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USCRNsm/USCRNsm_obsMod.F90 b/lvt/datastreams/USCRNsm/USCRNsm_obsMod.F90 index abc100235..16aa9b9b6 100644 --- a/lvt/datastreams/USCRNsm/USCRNsm_obsMod.F90 +++ b/lvt/datastreams/USCRNsm/USCRNsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USCRNsm/readUSCRNsmObs.F90 b/lvt/datastreams/USCRNsm/readUSCRNsmObs.F90 index b12fe0ece..501e996be 100644 --- a/lvt/datastreams/USCRNsm/readUSCRNsmObs.F90 +++ b/lvt/datastreams/USCRNsm/readUSCRNsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USDM/USDM_obsMod.F90 b/lvt/datastreams/USDM/USDM_obsMod.F90 index 5e574f70b..79c0dd40c 100644 --- a/lvt/datastreams/USDM/USDM_obsMod.F90 +++ b/lvt/datastreams/USDM/USDM_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USDM/readUSDMobs.F90 b/lvt/datastreams/USDM/readUSDMobs.F90 index 66db3d3b7..75378ea8d 100644 --- a/lvt/datastreams/USDM/readUSDMobs.F90 +++ b/lvt/datastreams/USDM/readUSDMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_GWwell/USGSGWwell_obsMod.F90 b/lvt/datastreams/USGS_GWwell/USGSGWwell_obsMod.F90 index 3e3a900f1..7d76a0ebf 100644 --- a/lvt/datastreams/USGS_GWwell/USGSGWwell_obsMod.F90 +++ b/lvt/datastreams/USGS_GWwell/USGSGWwell_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_GWwell/readUSGSGWwellobs.F90 b/lvt/datastreams/USGS_GWwell/readUSGSGWwellobs.F90 index 561515943..16ca41f50 100644 --- a/lvt/datastreams/USGS_GWwell/readUSGSGWwellobs.F90 +++ b/lvt/datastreams/USGS_GWwell/readUSGSGWwellobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_streamflow/USGSSF_obsMod.F90 b/lvt/datastreams/USGS_streamflow/USGSSF_obsMod.F90 index 82b27fec2..433e399ff 100644 --- a/lvt/datastreams/USGS_streamflow/USGSSF_obsMod.F90 +++ b/lvt/datastreams/USGS_streamflow/USGSSF_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_streamflow/readUSGSSFObs.F90 b/lvt/datastreams/USGS_streamflow/readUSGSSFObs.F90 index 138f632c9..02c40fa4c 100644 --- a/lvt/datastreams/USGS_streamflow/readUSGSSFObs.F90 +++ b/lvt/datastreams/USGS_streamflow/readUSGSSFObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_streamflow_gridded/USGSSFgrid_obsMod.F90 b/lvt/datastreams/USGS_streamflow_gridded/USGSSFgrid_obsMod.F90 index 5e4ecb443..353d4529d 100644 --- a/lvt/datastreams/USGS_streamflow_gridded/USGSSFgrid_obsMod.F90 +++ b/lvt/datastreams/USGS_streamflow_gridded/USGSSFgrid_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/USGS_streamflow_gridded/readUSGSSFgridObs.F90 b/lvt/datastreams/USGS_streamflow_gridded/readUSGSSFgridObs.F90 index 551afc66d..78220cb66 100644 --- a/lvt/datastreams/USGS_streamflow_gridded/readUSGSSFgridObs.F90 +++ b/lvt/datastreams/USGS_streamflow_gridded/readUSGSSFgridObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UWET/UWET_obsMod.F90 b/lvt/datastreams/UWET/UWET_obsMod.F90 index ac60cb942..9f884b68b 100644 --- a/lvt/datastreams/UWET/UWET_obsMod.F90 +++ b/lvt/datastreams/UWET/UWET_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/UWET/readUWETObs.F90 b/lvt/datastreams/UWET/readUWETObs.F90 index e1eed31bd..6531e3b8f 100644 --- a/lvt/datastreams/UWET/readUWETObs.F90 +++ b/lvt/datastreams/UWET/readUWETObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/WGPBMR/WGPBMRobsMod.F90 b/lvt/datastreams/WGPBMR/WGPBMRobsMod.F90 index 6c9870736..cbb58d2c3 100644 --- a/lvt/datastreams/WGPBMR/WGPBMRobsMod.F90 +++ b/lvt/datastreams/WGPBMR/WGPBMRobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/WGPBMR/readWGPBMRObs.F90 b/lvt/datastreams/WGPBMR/readWGPBMRObs.F90 index eb7353ce5..a4e8ae464 100644 --- a/lvt/datastreams/WGPBMR/readWGPBMRObs.F90 +++ b/lvt/datastreams/WGPBMR/readWGPBMRObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/WGSWRC/WGSWRC_obsMod.F90 b/lvt/datastreams/WGSWRC/WGSWRC_obsMod.F90 index 9ca6a689e..df3c6b77c 100644 --- a/lvt/datastreams/WGSWRC/WGSWRC_obsMod.F90 +++ b/lvt/datastreams/WGSWRC/WGSWRC_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/WGSWRC/readWGSWRCobs.F90 b/lvt/datastreams/WGSWRC/readWGSWRCobs.F90 index dac99c2f7..d803b81d8 100644 --- a/lvt/datastreams/WGSWRC/readWGSWRCobs.F90 +++ b/lvt/datastreams/WGSWRC/readWGSWRCobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/jasmin/JASMINsm_obsMod.F90 b/lvt/datastreams/jasmin/JASMINsm_obsMod.F90 index 11e31a701..4b9872949 100644 --- a/lvt/datastreams/jasmin/JASMINsm_obsMod.F90 +++ b/lvt/datastreams/jasmin/JASMINsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/jasmin/readJASMINsmObs.F90 b/lvt/datastreams/jasmin/readJASMINsmObs.F90 index 40516a780..a052bd5c2 100644 --- a/lvt/datastreams/jasmin/readJASMINsmObs.F90 +++ b/lvt/datastreams/jasmin/readJASMINsmObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/simGRACE/readsimGRACEObs.F90 b/lvt/datastreams/simGRACE/readsimGRACEObs.F90 index 0a7ec3dfc..2850d6c43 100644 --- a/lvt/datastreams/simGRACE/readsimGRACEObs.F90 +++ b/lvt/datastreams/simGRACE/readsimGRACEObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/simGRACE/simGRACE_obsMod.F90 b/lvt/datastreams/simGRACE/simGRACE_obsMod.F90 index a4ca13984..25d0b0940 100644 --- a/lvt/datastreams/simGRACE/simGRACE_obsMod.F90 +++ b/lvt/datastreams/simGRACE/simGRACE_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/template/readtemplateObs.F90 b/lvt/datastreams/template/readtemplateObs.F90 index bdfeeb267..8eb175012 100644 --- a/lvt/datastreams/template/readtemplateObs.F90 +++ b/lvt/datastreams/template/readtemplateObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/datastreams/template/template_obsMod.F90 b/lvt/datastreams/template/template_obsMod.F90 index 48000e0c4..95882303f 100644 --- a/lvt/datastreams/template/template_obsMod.F90 +++ b/lvt/datastreams/template/template_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/domains/UTM/readinput_UTM.F90 b/lvt/domains/UTM/readinput_UTM.F90 index b7d50a486..bea531244 100644 --- a/lvt/domains/UTM/readinput_UTM.F90 +++ b/lvt/domains/UTM/readinput_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/domains/lambert/readinput_lambert.F90 b/lvt/domains/lambert/readinput_lambert.F90 index d5a5ed364..913aaef00 100644 --- a/lvt/domains/lambert/readinput_lambert.F90 +++ b/lvt/domains/lambert/readinput_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/domains/latlon/readinput_latlon.F90 b/lvt/domains/latlon/readinput_latlon.F90 index c886056f3..ed0bd2d77 100644 --- a/lvt/domains/latlon/readinput_latlon.F90 +++ b/lvt/domains/latlon/readinput_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/UTM_utils.F90 b/lvt/interp/UTM_utils.F90 index 9f3d55e21..11a07d791 100755 --- a/lvt/interp/UTM_utils.F90 +++ b/lvt/interp/UTM_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/bilinear_interp.F90 b/lvt/interp/bilinear_interp.F90 index 021621ef8..4936568d6 100644 --- a/lvt/interp/bilinear_interp.F90 +++ b/lvt/interp/bilinear_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/bilinear_interp_input.F90 b/lvt/interp/bilinear_interp_input.F90 index 38ffaab00..f9675d4bc 100644 --- a/lvt/interp/bilinear_interp_input.F90 +++ b/lvt/interp/bilinear_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/breakpt_module.F90 b/lvt/interp/breakpt_module.F90 index db5cfca4d..1e687cc86 100644 --- a/lvt/interp/breakpt_module.F90 +++ b/lvt/interp/breakpt_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord.F90 b/lvt/interp/compute_earth_coord.F90 index d64477330..a54d0aa13 100644 --- a/lvt/interp/compute_earth_coord.F90 +++ b/lvt/interp/compute_earth_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_UTM.F90 b/lvt/interp/compute_earth_coord_UTM.F90 index cefa79e6a..a2d549438 100644 --- a/lvt/interp/compute_earth_coord_UTM.F90 +++ b/lvt/interp/compute_earth_coord_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_ease.F90 b/lvt/interp/compute_earth_coord_ease.F90 index 49cb4737e..7980c0262 100644 --- a/lvt/interp/compute_earth_coord_ease.F90 +++ b/lvt/interp/compute_earth_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_gauss.F90 b/lvt/interp/compute_earth_coord_gauss.F90 index 151a805ec..3b85e3779 100644 --- a/lvt/interp/compute_earth_coord_gauss.F90 +++ b/lvt/interp/compute_earth_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_hrap.F90 b/lvt/interp/compute_earth_coord_hrap.F90 index efb8a316c..92215d135 100644 --- a/lvt/interp/compute_earth_coord_hrap.F90 +++ b/lvt/interp/compute_earth_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_lambert.F90 b/lvt/interp/compute_earth_coord_lambert.F90 index 6f56268fc..4f535d6b2 100644 --- a/lvt/interp/compute_earth_coord_lambert.F90 +++ b/lvt/interp/compute_earth_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_latlon.F90 b/lvt/interp/compute_earth_coord_latlon.F90 index c07897557..74b5f10ee 100644 --- a/lvt/interp/compute_earth_coord_latlon.F90 +++ b/lvt/interp/compute_earth_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_latlon_ll.F90 b/lvt/interp/compute_earth_coord_latlon_ll.F90 index b1a130c04..0983b2928 100644 --- a/lvt/interp/compute_earth_coord_latlon_ll.F90 +++ b/lvt/interp/compute_earth_coord_latlon_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_latlon_ur.F90 b/lvt/interp/compute_earth_coord_latlon_ur.F90 index 373361c83..b008f7c7d 100644 --- a/lvt/interp/compute_earth_coord_latlon_ur.F90 +++ b/lvt/interp/compute_earth_coord_latlon_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_ll.F90 b/lvt/interp/compute_earth_coord_ll.F90 index 9a1d0796f..ef99eb7a3 100644 --- a/lvt/interp/compute_earth_coord_ll.F90 +++ b/lvt/interp/compute_earth_coord_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_merc.F90 b/lvt/interp/compute_earth_coord_merc.F90 index f76ba8562..0a784223e 100644 --- a/lvt/interp/compute_earth_coord_merc.F90 +++ b/lvt/interp/compute_earth_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_polar.F90 b/lvt/interp/compute_earth_coord_polar.F90 index c599d0808..a36ad02d9 100644 --- a/lvt/interp/compute_earth_coord_polar.F90 +++ b/lvt/interp/compute_earth_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_earth_coord_ur.F90 b/lvt/interp/compute_earth_coord_ur.F90 index 32746d58d..2e716dda7 100644 --- a/lvt/interp/compute_earth_coord_ur.F90 +++ b/lvt/interp/compute_earth_coord_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord.F90 b/lvt/interp/compute_grid_coord.F90 index 07d4dc473..00d2d2eb1 100644 --- a/lvt/interp/compute_grid_coord.F90 +++ b/lvt/interp/compute_grid_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_ease.F90 b/lvt/interp/compute_grid_coord_ease.F90 index 637db923a..0027ce505 100644 --- a/lvt/interp/compute_grid_coord_ease.F90 +++ b/lvt/interp/compute_grid_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_gauss.F90 b/lvt/interp/compute_grid_coord_gauss.F90 index a6bf78dff..1a5c7c94a 100644 --- a/lvt/interp/compute_grid_coord_gauss.F90 +++ b/lvt/interp/compute_grid_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_hrap.F90 b/lvt/interp/compute_grid_coord_hrap.F90 index 892ab48ae..23ea81447 100644 --- a/lvt/interp/compute_grid_coord_hrap.F90 +++ b/lvt/interp/compute_grid_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_lambert.F90 b/lvt/interp/compute_grid_coord_lambert.F90 index 47769572b..d6e16c8cd 100644 --- a/lvt/interp/compute_grid_coord_lambert.F90 +++ b/lvt/interp/compute_grid_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_latlon.F90 b/lvt/interp/compute_grid_coord_latlon.F90 index 6854f32b9..8a4c9e50a 100644 --- a/lvt/interp/compute_grid_coord_latlon.F90 +++ b/lvt/interp/compute_grid_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_merc.F90 b/lvt/interp/compute_grid_coord_merc.F90 index 841a221ca..5744e2a40 100644 --- a/lvt/interp/compute_grid_coord_merc.F90 +++ b/lvt/interp/compute_grid_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_grid_coord_polar.F90 b/lvt/interp/compute_grid_coord_polar.F90 index cf851e277..73116747a 100644 --- a/lvt/interp/compute_grid_coord_polar.F90 +++ b/lvt/interp/compute_grid_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_stnwts.F90 b/lvt/interp/compute_stnwts.F90 index 51f541a4b..54fc5ebd6 100644 --- a/lvt/interp/compute_stnwts.F90 +++ b/lvt/interp/compute_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/compute_vinterp_weights.F90 b/lvt/interp/compute_vinterp_weights.F90 index 5b9067395..09daafaa1 100644 --- a/lvt/interp/compute_vinterp_weights.F90 +++ b/lvt/interp/compute_vinterp_weights.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/conserv_interp.F90 b/lvt/interp/conserv_interp.F90 index 3f4847dc1..129013f23 100644 --- a/lvt/interp/conserv_interp.F90 +++ b/lvt/interp/conserv_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/conserv_interp_input.F90 b/lvt/interp/conserv_interp_input.F90 index c94b4d934..6381b85cc 100644 --- a/lvt/interp/conserv_interp_input.F90 +++ b/lvt/interp/conserv_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/ezlh_convert.F90 b/lvt/interp/ezlh_convert.F90 index 3176d8c28..56b617705 100755 --- a/lvt/interp/ezlh_convert.F90 +++ b/lvt/interp/ezlh_convert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/ezlh_inverse.F90 b/lvt/interp/ezlh_inverse.F90 index bc1765ffa..7b685d711 100755 --- a/lvt/interp/ezlh_inverse.F90 +++ b/lvt/interp/ezlh_inverse.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/gaussian_mod.F90 b/lvt/interp/gaussian_mod.F90 index 5ce6f3f8e..c09308cd6 100644 --- a/lvt/interp/gaussian_mod.F90 +++ b/lvt/interp/gaussian_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/gaussian_routines.F90 b/lvt/interp/gaussian_routines.F90 index 50caf12ad..0222e5a7d 100644 --- a/lvt/interp/gaussian_routines.F90 +++ b/lvt/interp/gaussian_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/gausslat.F90 b/lvt/interp/gausslat.F90 index 2cf20fc9a..16ce6b639 100644 --- a/lvt/interp/gausslat.F90 +++ b/lvt/interp/gausslat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/get_fieldpos.F90 b/lvt/interp/get_fieldpos.F90 index 7e56d18bb..8730f8697 100644 --- a/lvt/interp/get_fieldpos.F90 +++ b/lvt/interp/get_fieldpos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/hrapToLatLon.F90 b/lvt/interp/hrapToLatLon.F90 index e8582887e..945b58dc7 100644 --- a/lvt/interp/hrapToLatLon.F90 +++ b/lvt/interp/hrapToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/idw_module.F90 b/lvt/interp/idw_module.F90 index 72e789e15..8eb4123a5 100644 --- a/lvt/interp/idw_module.F90 +++ b/lvt/interp/idw_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/interp_stndata.F90 b/lvt/interp/interp_stndata.F90 index 461b110e5..9df10f2cc 100644 --- a/lvt/interp/interp_stndata.F90 +++ b/lvt/interp/interp_stndata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/latlonTohrap.F90 b/lvt/interp/latlonTohrap.F90 index 9145872e2..cedc672a8 100644 --- a/lvt/interp/latlonTohrap.F90 +++ b/lvt/interp/latlonTohrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/latlonTopolar.F90 b/lvt/interp/latlonTopolar.F90 index c0e26a297..5bb9f68de 100644 --- a/lvt/interp/latlonTopolar.F90 +++ b/lvt/interp/latlonTopolar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/lltops.F90 b/lvt/interp/lltops.F90 index c579e375c..f960ddeec 100644 --- a/lvt/interp/lltops.F90 +++ b/lvt/interp/lltops.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/map_utils.F90 b/lvt/interp/map_utils.F90 index 65477cd24..e54080e81 100644 --- a/lvt/interp/map_utils.F90 +++ b/lvt/interp/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/mqb_module.F90 b/lvt/interp/mqb_module.F90 index dbe17038a..0cb3f7392 100644 --- a/lvt/interp/mqb_module.F90 +++ b/lvt/interp/mqb_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/neighbor_interp.F90 b/lvt/interp/neighbor_interp.F90 index f5bf12888..cabf19e99 100644 --- a/lvt/interp/neighbor_interp.F90 +++ b/lvt/interp/neighbor_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/neighbor_interp_input.F90 b/lvt/interp/neighbor_interp_input.F90 index 1809760ad..314c44a34 100644 --- a/lvt/interp/neighbor_interp_input.F90 +++ b/lvt/interp/neighbor_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/normalize_stnwts.F90 b/lvt/interp/normalize_stnwts.F90 index 6fdd0d643..0668fabde 100644 --- a/lvt/interp/normalize_stnwts.F90 +++ b/lvt/interp/normalize_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/polarToLatLon.F90 b/lvt/interp/polarToLatLon.F90 index 62c41af6c..91918bc16 100644 --- a/lvt/interp/polarToLatLon.F90 +++ b/lvt/interp/polarToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/polfixs.F90 b/lvt/interp/polfixs.F90 index 49bb15a44..c378fc476 100644 --- a/lvt/interp/polfixs.F90 +++ b/lvt/interp/polfixs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/pstoll.F90 b/lvt/interp/pstoll.F90 index 0a8818363..165f0cd44 100644 --- a/lvt/interp/pstoll.F90 +++ b/lvt/interp/pstoll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/stninterp_module.F90 b/lvt/interp/stninterp_module.F90 index 6b4fb45d4..9295773a4 100644 --- a/lvt/interp/stninterp_module.F90 +++ b/lvt/interp/stninterp_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/upscaleByAveraging.F90 b/lvt/interp/upscaleByAveraging.F90 index 58f454a2f..b81bfade3 100644 --- a/lvt/interp/upscaleByAveraging.F90 +++ b/lvt/interp/upscaleByAveraging.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/upscaleByAveraging_input.F90 b/lvt/interp/upscaleByAveraging_input.F90 index bac9b7380..f8b6d2181 100644 --- a/lvt/interp/upscaleByAveraging_input.F90 +++ b/lvt/interp/upscaleByAveraging_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/upscaleByAveraging_input_with_latlon.F90 b/lvt/interp/upscaleByAveraging_input_with_latlon.F90 index bdcc1c526..b2e1cf0e3 100644 --- a/lvt/interp/upscaleByAveraging_input_with_latlon.F90 +++ b/lvt/interp/upscaleByAveraging_input_with_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/upscaleByMode.F90 b/lvt/interp/upscaleByMode.F90 index c15ef30a6..6fd8f62ac 100644 --- a/lvt/interp/upscaleByMode.F90 +++ b/lvt/interp/upscaleByMode.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/interp/vinterp.F90 b/lvt/interp/vinterp.F90 index 593ed3fcf..f54428c91 100644 --- a/lvt/interp/vinterp.F90 +++ b/lvt/interp/vinterp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/main/LVTmain.F90 b/lvt/main/LVTmain.F90 index 152c384d6..7b089f433 100644 --- a/lvt/main/LVTmain.F90 +++ b/lvt/main/LVTmain.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/make/makedep.py b/lvt/make/makedep.py index a7d033e9c..daec48a11 100755 --- a/lvt/make/makedep.py +++ b/lvt/make/makedep.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_ACCMod.F90 b/lvt/metrics/LVT_ACCMod.F90 index 98f72afe5..665eb3eb1 100644 --- a/lvt/metrics/LVT_ACCMod.F90 +++ b/lvt/metrics/LVT_ACCMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_AnomalyCorrMod.F90 b/lvt/metrics/LVT_AnomalyCorrMod.F90 index f02cd3ce0..6aa6d44d2 100644 --- a/lvt/metrics/LVT_AnomalyCorrMod.F90 +++ b/lvt/metrics/LVT_AnomalyCorrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_AnomalyMod.F90 b/lvt/metrics/LVT_AnomalyMod.F90 index c2297e9f3..19aba8740 100644 --- a/lvt/metrics/LVT_AnomalyMod.F90 +++ b/lvt/metrics/LVT_AnomalyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_AnomalyRMSEMod.F90 b/lvt/metrics/LVT_AnomalyRMSEMod.F90 index 21f24d016..951e282e4 100644 --- a/lvt/metrics/LVT_AnomalyRMSEMod.F90 +++ b/lvt/metrics/LVT_AnomalyRMSEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_AnomalyRnkCorrMod.F90 b/lvt/metrics/LVT_AnomalyRnkCorrMod.F90 index ec347ec32..e81cd5963 100644 --- a/lvt/metrics/LVT_AnomalyRnkCorrMod.F90 +++ b/lvt/metrics/LVT_AnomalyRnkCorrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_AreaMetricMod.F90 b/lvt/metrics/LVT_AreaMetricMod.F90 index 36af1a76b..de9867b59 100644 --- a/lvt/metrics/LVT_AreaMetricMod.F90 +++ b/lvt/metrics/LVT_AreaMetricMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_BIASMod.F90 b/lvt/metrics/LVT_BIASMod.F90 index 2ced85843..539661b01 100644 --- a/lvt/metrics/LVT_BIASMod.F90 +++ b/lvt/metrics/LVT_BIASMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_CSIMod.F90 b/lvt/metrics/LVT_CSIMod.F90 index fcb129c8e..e394a41b3 100644 --- a/lvt/metrics/LVT_CSIMod.F90 +++ b/lvt/metrics/LVT_CSIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_CSSMod.F90 b/lvt/metrics/LVT_CSSMod.F90 index 0f367c316..39b9512d9 100644 --- a/lvt/metrics/LVT_CSSMod.F90 +++ b/lvt/metrics/LVT_CSSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_ConditionalEntropyMod.F90 b/lvt/metrics/LVT_ConditionalEntropyMod.F90 index 8f2b65747..5e4ba7ce5 100644 --- a/lvt/metrics/LVT_ConditionalEntropyMod.F90 +++ b/lvt/metrics/LVT_ConditionalEntropyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_DFRMod.F90 b/lvt/metrics/LVT_DFRMod.F90 index fee9671c6..3f2e76f03 100644 --- a/lvt/metrics/LVT_DFRMod.F90 +++ b/lvt/metrics/LVT_DFRMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_EFMod.F90 b/lvt/metrics/LVT_EFMod.F90 index 16cb3fbe5..b6f59c957 100644 --- a/lvt/metrics/LVT_EFMod.F90 +++ b/lvt/metrics/LVT_EFMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_ETSMod.F90 b/lvt/metrics/LVT_ETSMod.F90 index 7d24ec2b8..26aa71307 100644 --- a/lvt/metrics/LVT_ETSMod.F90 +++ b/lvt/metrics/LVT_ETSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_EffectiveComplexityMod.F90 b/lvt/metrics/LVT_EffectiveComplexityMod.F90 index 0d15a51e8..9c468e46d 100644 --- a/lvt/metrics/LVT_EffectiveComplexityMod.F90 +++ b/lvt/metrics/LVT_EffectiveComplexityMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_FARMod.F90 b/lvt/metrics/LVT_FARMod.F90 index 5e4d0f947..5c01d89ba 100644 --- a/lvt/metrics/LVT_FARMod.F90 +++ b/lvt/metrics/LVT_FARMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_FBIASMod.F90 b/lvt/metrics/LVT_FBIASMod.F90 index 26957450f..1295f4aa9 100644 --- a/lvt/metrics/LVT_FBIASMod.F90 +++ b/lvt/metrics/LVT_FBIASMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_FFMod.F90 b/lvt/metrics/LVT_FFMod.F90 index db4056eb6..6b5b55986 100644 --- a/lvt/metrics/LVT_FFMod.F90 +++ b/lvt/metrics/LVT_FFMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_FluctuationComplexityMod.F90 b/lvt/metrics/LVT_FluctuationComplexityMod.F90 index c4036c7ae..c098ef00a 100644 --- a/lvt/metrics/LVT_FluctuationComplexityMod.F90 +++ b/lvt/metrics/LVT_FluctuationComplexityMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_HNMod.F90 b/lvt/metrics/LVT_HNMod.F90 index 630edcf5d..f1e506de1 100644 --- a/lvt/metrics/LVT_HNMod.F90 +++ b/lvt/metrics/LVT_HNMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_HSSMod.F90 b/lvt/metrics/LVT_HSSMod.F90 index 16d0aa3d4..ccc02effc 100644 --- a/lvt/metrics/LVT_HSSMod.F90 +++ b/lvt/metrics/LVT_HSSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_InformationEntropyMod.F90 b/lvt/metrics/LVT_InformationEntropyMod.F90 index e3e772674..6db0c1d01 100644 --- a/lvt/metrics/LVT_InformationEntropyMod.F90 +++ b/lvt/metrics/LVT_InformationEntropyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_InformationGainMod.F90 b/lvt/metrics/LVT_InformationGainMod.F90 index abef9ab88..1a105e3a3 100644 --- a/lvt/metrics/LVT_InformationGainMod.F90 +++ b/lvt/metrics/LVT_InformationGainMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_JointEntropyMod.F90 b/lvt/metrics/LVT_JointEntropyMod.F90 index fdcc9c5f2..5352fa0f9 100644 --- a/lvt/metrics/LVT_JointEntropyMod.F90 +++ b/lvt/metrics/LVT_JointEntropyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_KmeansMod.F90 b/lvt/metrics/LVT_KmeansMod.F90 index 15594a863..bc69dc03b 100644 --- a/lvt/metrics/LVT_KmeansMod.F90 +++ b/lvt/metrics/LVT_KmeansMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MAEMod.F90 b/lvt/metrics/LVT_MAEMod.F90 index b8ad588df..cd5045a8d 100644 --- a/lvt/metrics/LVT_MAEMod.F90 +++ b/lvt/metrics/LVT_MAEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MEANMod.F90 b/lvt/metrics/LVT_MEANMod.F90 index 76256fec4..ed34a16dd 100644 --- a/lvt/metrics/LVT_MEANMod.F90 +++ b/lvt/metrics/LVT_MEANMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MaxMod.F90 b/lvt/metrics/LVT_MaxMod.F90 index d4d24cf26..542c2b87a 100644 --- a/lvt/metrics/LVT_MaxMod.F90 +++ b/lvt/metrics/LVT_MaxMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MaxTimeMod.F90 b/lvt/metrics/LVT_MaxTimeMod.F90 index 4b9d70f87..4a11444f9 100644 --- a/lvt/metrics/LVT_MaxTimeMod.F90 +++ b/lvt/metrics/LVT_MaxTimeMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MetricEntropyMod.F90 b/lvt/metrics/LVT_MetricEntropyMod.F90 index 48f2c0b5c..df45cca66 100644 --- a/lvt/metrics/LVT_MetricEntropyMod.F90 +++ b/lvt/metrics/LVT_MetricEntropyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MinMod.F90 b/lvt/metrics/LVT_MinMod.F90 index 1c49788bf..24c67237d 100644 --- a/lvt/metrics/LVT_MinMod.F90 +++ b/lvt/metrics/LVT_MinMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MinTimeMod.F90 b/lvt/metrics/LVT_MinTimeMod.F90 index c5804b0cf..9bd886e1a 100644 --- a/lvt/metrics/LVT_MinTimeMod.F90 +++ b/lvt/metrics/LVT_MinTimeMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_MutualInformationMod.F90 b/lvt/metrics/LVT_MutualInformationMod.F90 index 396a41242..c5feb72a7 100644 --- a/lvt/metrics/LVT_MutualInformationMod.F90 +++ b/lvt/metrics/LVT_MutualInformationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_NSEMod.F90 b/lvt/metrics/LVT_NSEMod.F90 index ce51d9fac..c00e47580 100644 --- a/lvt/metrics/LVT_NSEMod.F90 +++ b/lvt/metrics/LVT_NSEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_PODNMod.F90 b/lvt/metrics/LVT_PODNMod.F90 index c17e81ee1..e3b681e5b 100644 --- a/lvt/metrics/LVT_PODNMod.F90 +++ b/lvt/metrics/LVT_PODNMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_PODYMod.F90 b/lvt/metrics/LVT_PODYMod.F90 index e987a1b19..8bf4d8ec3 100644 --- a/lvt/metrics/LVT_PODYMod.F90 +++ b/lvt/metrics/LVT_PODYMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_POFDMod.F90 b/lvt/metrics/LVT_POFDMod.F90 index d8a0ff3a1..0633845df 100644 --- a/lvt/metrics/LVT_POFDMod.F90 +++ b/lvt/metrics/LVT_POFDMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_PSSMod.F90 b/lvt/metrics/LVT_PSSMod.F90 index ab7e9714a..666275943 100644 --- a/lvt/metrics/LVT_PSSMod.F90 +++ b/lvt/metrics/LVT_PSSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RELMod.F90 b/lvt/metrics/LVT_RELMod.F90 index cc5a29689..ce04bd1ad 100644 --- a/lvt/metrics/LVT_RELMod.F90 +++ b/lvt/metrics/LVT_RELMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RESMod.F90 b/lvt/metrics/LVT_RESMod.F90 index 9b95d7df0..f011bd80f 100644 --- a/lvt/metrics/LVT_RESMod.F90 +++ b/lvt/metrics/LVT_RESMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RFVMod.F90 b/lvt/metrics/LVT_RFVMod.F90 index c551d1229..1a237640c 100644 --- a/lvt/metrics/LVT_RFVMod.F90 +++ b/lvt/metrics/LVT_RFVMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RMSEMod.F90 b/lvt/metrics/LVT_RMSEMod.F90 index 17c0cbc89..039e3a191 100644 --- a/lvt/metrics/LVT_RMSEMod.F90 +++ b/lvt/metrics/LVT_RMSEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RawCorrMod.F90 b/lvt/metrics/LVT_RawCorrMod.F90 index 9eb0738af..25fec1cdd 100644 --- a/lvt/metrics/LVT_RawCorrMod.F90 +++ b/lvt/metrics/LVT_RawCorrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RelativeEntropy.F90 b/lvt/metrics/LVT_RelativeEntropy.F90 index ad3bf56d4..ff9ca097a 100644 --- a/lvt/metrics/LVT_RelativeEntropy.F90 +++ b/lvt/metrics/LVT_RelativeEntropy.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_RnkCorrMod.F90 b/lvt/metrics/LVT_RnkCorrMod.F90 index 37d13955f..78d5a1601 100644 --- a/lvt/metrics/LVT_RnkCorrMod.F90 +++ b/lvt/metrics/LVT_RnkCorrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SGWIMod.F90 b/lvt/metrics/LVT_SGWIMod.F90 index 62127077b..b342bb88d 100644 --- a/lvt/metrics/LVT_SGWIMod.F90 +++ b/lvt/metrics/LVT_SGWIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SPIMod.F90 b/lvt/metrics/LVT_SPIMod.F90 index 9a27cbf7e..6dd614c3c 100644 --- a/lvt/metrics/LVT_SPIMod.F90 +++ b/lvt/metrics/LVT_SPIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SRIMod.F90 b/lvt/metrics/LVT_SRIMod.F90 index 24bc08209..b14aef521 100644 --- a/lvt/metrics/LVT_SRIMod.F90 +++ b/lvt/metrics/LVT_SRIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SSWIMod.F90 b/lvt/metrics/LVT_SSWIMod.F90 index 1577e8d4d..affe88546 100644 --- a/lvt/metrics/LVT_SSWIMod.F90 +++ b/lvt/metrics/LVT_SSWIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SdSIMod.F90 b/lvt/metrics/LVT_SdSIMod.F90 index c95ba816e..55eb9fe90 100644 --- a/lvt/metrics/LVT_SdSIMod.F90 +++ b/lvt/metrics/LVT_SdSIMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_StdevMod.F90 b/lvt/metrics/LVT_StdevMod.F90 index 485ffef63..7fffb8a6e 100644 --- a/lvt/metrics/LVT_StdevMod.F90 +++ b/lvt/metrics/LVT_StdevMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_SumMod.F90 b/lvt/metrics/LVT_SumMod.F90 index a455b5fa0..57259908c 100644 --- a/lvt/metrics/LVT_SumMod.F90 +++ b/lvt/metrics/LVT_SumMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TCMod.F90 b/lvt/metrics/LVT_TCMod.F90 index 7b8bda8c6..783bbf9b2 100644 --- a/lvt/metrics/LVT_TCMod.F90 +++ b/lvt/metrics/LVT_TCMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TFBMod.F90 b/lvt/metrics/LVT_TFBMod.F90 index 6fe4ffb39..39b18e0c4 100644 --- a/lvt/metrics/LVT_TFBMod.F90 +++ b/lvt/metrics/LVT_TFBMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_THBMod.F90 b/lvt/metrics/LVT_THBMod.F90 index 6cfffd682..4d878bd13 100644 --- a/lvt/metrics/LVT_THBMod.F90 +++ b/lvt/metrics/LVT_THBMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TMBMod.F90 b/lvt/metrics/LVT_TMBMod.F90 index 2ad1e6e17..bfe91f276 100644 --- a/lvt/metrics/LVT_TMBMod.F90 +++ b/lvt/metrics/LVT_TMBMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TendencyCorrMod.F90 b/lvt/metrics/LVT_TendencyCorrMod.F90 index a129d2b7d..bee9b1c96 100644 --- a/lvt/metrics/LVT_TendencyCorrMod.F90 +++ b/lvt/metrics/LVT_TendencyCorrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TendencyMod.F90 b/lvt/metrics/LVT_TendencyMod.F90 index 5b99177e4..a9eaa914f 100644 --- a/lvt/metrics/LVT_TendencyMod.F90 +++ b/lvt/metrics/LVT_TendencyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_TrendMod.F90 b/lvt/metrics/LVT_TrendMod.F90 index efd7cfef7..2dca55aef 100644 --- a/lvt/metrics/LVT_TrendMod.F90 +++ b/lvt/metrics/LVT_TrendMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_VULMod.F90 b/lvt/metrics/LVT_VULMod.F90 index 8c1905887..7fdb98881 100644 --- a/lvt/metrics/LVT_VULMod.F90 +++ b/lvt/metrics/LVT_VULMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_VarianceMod.F90 b/lvt/metrics/LVT_VarianceMod.F90 index 7f521cb4e..7a1e70ac7 100644 --- a/lvt/metrics/LVT_VarianceMod.F90 +++ b/lvt/metrics/LVT_VarianceMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_ZscoreMod.F90 b/lvt/metrics/LVT_ZscoreMod.F90 index 62748ecba..83ab98661 100644 --- a/lvt/metrics/LVT_ZscoreMod.F90 +++ b/lvt/metrics/LVT_ZscoreMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_percentileMod.F90 b/lvt/metrics/LVT_percentileMod.F90 index 70bd7da70..a9b1f8869 100644 --- a/lvt/metrics/LVT_percentileMod.F90 +++ b/lvt/metrics/LVT_percentileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_ubRMSEMod.F90 b/lvt/metrics/LVT_ubRMSEMod.F90 index 07c04c2ac..e039f935e 100644 --- a/lvt/metrics/LVT_ubRMSEMod.F90 +++ b/lvt/metrics/LVT_ubRMSEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/metrics/LVT_waveletStatMod.F90 b/lvt/metrics/LVT_waveletStatMod.F90 index 53ff03b06..de73da6cb 100644 --- a/lvt/metrics/LVT_waveletStatMod.F90 +++ b/lvt/metrics/LVT_waveletStatMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_datastream_pluginMod.F90 b/lvt/plugins/LVT_datastream_pluginMod.F90 index 8a5302abc..e2a06819a 100644 --- a/lvt/plugins/LVT_datastream_pluginMod.F90 +++ b/lvt/plugins/LVT_datastream_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_domain_pluginMod.F90 b/lvt/plugins/LVT_domain_pluginMod.F90 index 3ecb1b63d..a6845074d 100644 --- a/lvt/plugins/LVT_domain_pluginMod.F90 +++ b/lvt/plugins/LVT_domain_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_metric_pluginMod.F90 b/lvt/plugins/LVT_metric_pluginMod.F90 index 8edf8a291..5655899db 100644 --- a/lvt/plugins/LVT_metric_pluginMod.F90 +++ b/lvt/plugins/LVT_metric_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_pluginIndices.F90 b/lvt/plugins/LVT_pluginIndices.F90 index e596e60eb..7a75c38af 100644 --- a/lvt/plugins/LVT_pluginIndices.F90 +++ b/lvt/plugins/LVT_pluginIndices.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_runmode_pluginMod.F90 b/lvt/plugins/LVT_runmode_pluginMod.F90 index b119bae03..aeab63bc2 100644 --- a/lvt/plugins/LVT_runmode_pluginMod.F90 +++ b/lvt/plugins/LVT_runmode_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/plugins/LVT_trainingAlg_pluginMod.F90 b/lvt/plugins/LVT_trainingAlg_pluginMod.F90 index 4ae13f199..5e34051cf 100644 --- a/lvt/plugins/LVT_trainingAlg_pluginMod.F90 +++ b/lvt/plugins/LVT_trainingAlg_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/557post/LVT_557post_ps41_snowMod.F90 b/lvt/runmodes/557post/LVT_557post_ps41_snowMod.F90 index d466d486c..91732482a 100644 --- a/lvt/runmodes/557post/LVT_557post_ps41_snowMod.F90 +++ b/lvt/runmodes/557post/LVT_557post_ps41_snowMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/557post/LVT_init_557post.F90 b/lvt/runmodes/557post/LVT_init_557post.F90 index 1c84c92b8..032a8770a 100644 --- a/lvt/runmodes/557post/LVT_init_557post.F90 +++ b/lvt/runmodes/557post/LVT_init_557post.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/557post/LVT_run_557post.F90 b/lvt/runmodes/557post/LVT_run_557post.F90 index a053755f1..1891d37dc 100644 --- a/lvt/runmodes/557post/LVT_run_557post.F90 +++ b/lvt/runmodes/557post/LVT_run_557post.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/557post/lis_jules_en_snow.F90 b/lvt/runmodes/557post/lis_jules_en_snow.F90 index 01345a578..d679f82c8 100644 --- a/lvt/runmodes/557post/lis_jules_en_snow.F90 +++ b/lvt/runmodes/557post/lis_jules_en_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/Benchmarking/LVT_init_Benchmarking.F90 b/lvt/runmodes/Benchmarking/LVT_init_Benchmarking.F90 index b605e039e..72201935f 100644 --- a/lvt/runmodes/Benchmarking/LVT_init_Benchmarking.F90 +++ b/lvt/runmodes/Benchmarking/LVT_init_Benchmarking.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/Benchmarking/LVT_run_Benchmarking.F90 b/lvt/runmodes/Benchmarking/LVT_run_Benchmarking.F90 index fbdb130d8..cb5f7927d 100644 --- a/lvt/runmodes/Benchmarking/LVT_run_Benchmarking.F90 +++ b/lvt/runmodes/Benchmarking/LVT_run_Benchmarking.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DAobs/LVT_init_DAobs.F90 b/lvt/runmodes/DAobs/LVT_init_DAobs.F90 index 85e8fab99..495d378b3 100644 --- a/lvt/runmodes/DAobs/LVT_init_DAobs.F90 +++ b/lvt/runmodes/DAobs/LVT_init_DAobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DAobs/LVT_run_DAobs.F90 b/lvt/runmodes/DAobs/LVT_run_DAobs.F90 index a165aa58d..34d0dbfde 100644 --- a/lvt/runmodes/DAobs/LVT_run_DAobs.F90 +++ b/lvt/runmodes/DAobs/LVT_run_DAobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DAstats/LVT_init_DAstats.F90 b/lvt/runmodes/DAstats/LVT_init_DAstats.F90 index 5548aebda..6221f01b2 100644 --- a/lvt/runmodes/DAstats/LVT_init_DAstats.F90 +++ b/lvt/runmodes/DAstats/LVT_init_DAstats.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DAstats/LVT_run_DAstats.F90 b/lvt/runmodes/DAstats/LVT_run_DAstats.F90 index 971720c09..e91988718 100644 --- a/lvt/runmodes/DAstats/LVT_run_DAstats.F90 +++ b/lvt/runmodes/DAstats/LVT_run_DAstats.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DataComp/LVT_init_DataComp.F90 b/lvt/runmodes/DataComp/LVT_init_DataComp.F90 index 7e31233fe..193e3f0ce 100644 --- a/lvt/runmodes/DataComp/LVT_init_DataComp.F90 +++ b/lvt/runmodes/DataComp/LVT_init_DataComp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/DataComp/LVT_run_DataComp.F90 b/lvt/runmodes/DataComp/LVT_run_DataComp.F90 index 65c26e196..cca9a9276 100644 --- a/lvt/runmodes/DataComp/LVT_run_DataComp.F90 +++ b/lvt/runmodes/DataComp/LVT_run_DataComp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/LISpost/LVT_init_LISpost.F90 b/lvt/runmodes/LISpost/LVT_init_LISpost.F90 index 5928ecbaa..d3c27d088 100644 --- a/lvt/runmodes/LISpost/LVT_init_LISpost.F90 +++ b/lvt/runmodes/LISpost/LVT_init_LISpost.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/LISpost/LVT_run_LISpost.F90 b/lvt/runmodes/LISpost/LVT_run_LISpost.F90 index 0d1cfb4db..7947877df 100644 --- a/lvt/runmodes/LISpost/LVT_run_LISpost.F90 +++ b/lvt/runmodes/LISpost/LVT_run_LISpost.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/USAFSIpost/LVT_USAFSIpostMod.F90 b/lvt/runmodes/USAFSIpost/LVT_USAFSIpostMod.F90 index 5d9ee37dd..ae7a2b87b 100644 --- a/lvt/runmodes/USAFSIpost/LVT_USAFSIpostMod.F90 +++ b/lvt/runmodes/USAFSIpost/LVT_USAFSIpostMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/USAFSIpost/LVT_gribWrapperMod.F90 b/lvt/runmodes/USAFSIpost/LVT_gribWrapperMod.F90 index ea8f81373..3dd88bd1d 100644 --- a/lvt/runmodes/USAFSIpost/LVT_gribWrapperMod.F90 +++ b/lvt/runmodes/USAFSIpost/LVT_gribWrapperMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/USAFSIpost/LVT_init_USAFSIpost.F90 b/lvt/runmodes/USAFSIpost/LVT_init_USAFSIpost.F90 index 2abc2bf87..cf3676f62 100644 --- a/lvt/runmodes/USAFSIpost/LVT_init_USAFSIpost.F90 +++ b/lvt/runmodes/USAFSIpost/LVT_init_USAFSIpost.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/USAFSIpost/LVT_run_USAFSIpost.F90 b/lvt/runmodes/USAFSIpost/LVT_run_USAFSIpost.F90 index 55a924817..75843bc18 100644 --- a/lvt/runmodes/USAFSIpost/LVT_run_USAFSIpost.F90 +++ b/lvt/runmodes/USAFSIpost/LVT_run_USAFSIpost.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/optUE/LVT_init_optUE.F90 b/lvt/runmodes/optUE/LVT_init_optUE.F90 index 9960542d7..38f1815ac 100644 --- a/lvt/runmodes/optUE/LVT_init_optUE.F90 +++ b/lvt/runmodes/optUE/LVT_init_optUE.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/runmodes/optUE/LVT_run_optUE.F90 b/lvt/runmodes/optUE/LVT_run_optUE.F90 index ba7e4dd6b..c0f66a70c 100644 --- a/lvt/runmodes/optUE/LVT_run_optUE.F90 +++ b/lvt/runmodes/optUE/LVT_run_optUE.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/training/LinearRegression/LinearRegressionMod.F90 b/lvt/training/LinearRegression/LinearRegressionMod.F90 index 18b646bef..caef00533 100644 --- a/lvt/training/LinearRegression/LinearRegressionMod.F90 +++ b/lvt/training/LinearRegression/LinearRegressionMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/gnuplot/ADC/plotADC.F90 b/lvt/utils/gnuplot/ADC/plotADC.F90 index 906532f8c..1e801a9ae 100644 --- a/lvt/utils/gnuplot/ADC/plotADC.F90 +++ b/lvt/utils/gnuplot/ADC/plotADC.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/gnuplot/scatter/plotScatter.F90 b/lvt/utils/gnuplot/scatter/plotScatter.F90 index 87624ea40..8eec13ff9 100644 --- a/lvt/utils/gnuplot/scatter/plotScatter.F90 +++ b/lvt/utils/gnuplot/scatter/plotScatter.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/gnuplot/timeseries/plotTS.F90 b/lvt/utils/gnuplot/timeseries/plotTS.F90 index a364bb296..a659af6dc 100644 --- a/lvt/utils/gnuplot/timeseries/plotTS.F90 +++ b/lvt/utils/gnuplot/timeseries/plotTS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/gnuplot/timeseries/plotTS.py b/lvt/utils/gnuplot/timeseries/plotTS.py index b369c04d5..4f311cc97 100755 --- a/lvt/utils/gnuplot/timeseries/plotTS.py +++ b/lvt/utils/gnuplot/timeseries/plotTS.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/LVTpreproc.F90 b/lvt/utils/input_proc/LVTpreproc.F90 index 718f13c81..e30e8c358 100755 --- a/lvt/utils/input_proc/LVTpreproc.F90 +++ b/lvt/utils/input_proc/LVTpreproc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/map_utils.F90 b/lvt/utils/input_proc/map_utils.F90 index 1da5c928d..226f86bd3 100755 --- a/lvt/utils/input_proc/map_utils.F90 +++ b/lvt/utils/input_proc/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/preprocMod.F90 b/lvt/utils/input_proc/preprocMod.F90 index 9bd8ecde2..8cf2dfd42 100644 --- a/lvt/utils/input_proc/preprocMod.F90 +++ b/lvt/utils/input_proc/preprocMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/readConfigFile.F90 b/lvt/utils/input_proc/readConfigFile.F90 index 432141e1f..c6708ce9b 100755 --- a/lvt/utils/input_proc/readConfigFile.F90 +++ b/lvt/utils/input_proc/readConfigFile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/read_IGBP_MODISlc.F90 b/lvt/utils/input_proc/read_IGBP_MODISlc.F90 index a5cb085d0..86fcd84cb 100755 --- a/lvt/utils/input_proc/read_IGBP_MODISlc.F90 +++ b/lvt/utils/input_proc/read_IGBP_MODISlc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/read_UMDlc.F90 b/lvt/utils/input_proc/read_UMDlc.F90 index 3da546b0c..fd3df05eb 100755 --- a/lvt/utils/input_proc/read_UMDlc.F90 +++ b/lvt/utils/input_proc/read_UMDlc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/read_USGSlc.F90 b/lvt/utils/input_proc/read_USGSlc.F90 index 799b7e40e..0f80f05dd 100755 --- a/lvt/utils/input_proc/read_USGSlc.F90 +++ b/lvt/utils/input_proc/read_USGSlc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/readinput_lambert.F90 b/lvt/utils/input_proc/readinput_lambert.F90 index 781becb16..c51a94f42 100755 --- a/lvt/utils/input_proc/readinput_lambert.F90 +++ b/lvt/utils/input_proc/readinput_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/readinput_latlon.F90 b/lvt/utils/input_proc/readinput_latlon.F90 index f5e82055b..b636f0eba 100755 --- a/lvt/utils/input_proc/readinput_latlon.F90 +++ b/lvt/utils/input_proc/readinput_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/input_proc/readinput_polar.F90 b/lvt/utils/input_proc/readinput_polar.F90 index ca3d3a5b0..1ea01a2f0 100755 --- a/lvt/utils/input_proc/readinput_polar.F90 +++ b/lvt/utils/input_proc/readinput_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/ncl/ADC/plotADC.F90 b/lvt/utils/ncl/ADC/plotADC.F90 index ebc9a4663..9602357ed 100644 --- a/lvt/utils/ncl/ADC/plotADC.F90 +++ b/lvt/utils/ncl/ADC/plotADC.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/ncl/scatter/plotScatter.F90 b/lvt/utils/ncl/scatter/plotScatter.F90 index e1e24faf9..58d6ba741 100644 --- a/lvt/utils/ncl/scatter/plotScatter.F90 +++ b/lvt/utils/ncl/scatter/plotScatter.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/ncl/timeseries/plotTS.F90 b/lvt/utils/ncl/timeseries/plotTS.F90 index 42ff615a3..ca0178695 100644 --- a/lvt/utils/ncl/timeseries/plotTS.F90 +++ b/lvt/utils/ncl/timeseries/plotTS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/scripts/doc.csh b/lvt/utils/scripts/doc.csh index 8d7cfb3ed..a1104ca60 100755 --- a/lvt/utils/scripts/doc.csh +++ b/lvt/utils/scripts/doc.csh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/cat_lvt_grib2.py b/lvt/utils/usaf/cat_lvt_grib2.py index 8311ca10d..3793b5ecd 100755 --- a/lvt/utils/usaf/cat_lvt_grib2.py +++ b/lvt/utils/usaf/cat_lvt_grib2.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/convert_nc2surf.py b/lvt/utils/usaf/convert_nc2surf.py index b1d3d765d..dd017a547 100755 --- a/lvt/utils/usaf/convert_nc2surf.py +++ b/lvt/utils/usaf/convert_nc2surf.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/make_sm_geotiff.py b/lvt/utils/usaf/make_sm_geotiff.py index ae37eb34c..7f27f4c35 100755 --- a/lvt/utils/usaf/make_sm_geotiff.py +++ b/lvt/utils/usaf/make_sm_geotiff.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/read_surf.py b/lvt/utils/usaf/read_surf.py index fc64e538a..3c189e4ee 100755 --- a/lvt/utils/usaf/read_surf.py +++ b/lvt/utils/usaf/read_surf.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/run_ncks.py b/lvt/utils/usaf/run_ncks.py index dd823cb77..bd90f847a 100755 --- a/lvt/utils/usaf/run_ncks.py +++ b/lvt/utils/usaf/run_ncks.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/run_ncks_galwem.py b/lvt/utils/usaf/run_ncks_galwem.py index ed40209c2..268998a28 100755 --- a/lvt/utils/usaf/run_ncks_galwem.py +++ b/lvt/utils/usaf/run_ncks_galwem.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/surf2lisnc_3_10km.py b/lvt/utils/usaf/surf2lisnc_3_10km.py index 760c4ca39..a4a6123a0 100755 --- a/lvt/utils/usaf/surf2lisnc_3_10km.py +++ b/lvt/utils/usaf/surf2lisnc_3_10km.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/surf2lisnc_3_17km.py b/lvt/utils/usaf/surf2lisnc_3_17km.py index 263fc635e..46f981dfd 100755 --- a/lvt/utils/usaf/surf2lisnc_3_17km.py +++ b/lvt/utils/usaf/surf2lisnc_3_17km.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_24hr_jules.py b/lvt/utils/usaf/templates/make_lvt_config_24hr_jules.py index 5337283bf..20a42c683 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_24hr_jules.py +++ b/lvt/utils/usaf/templates/make_lvt_config_24hr_jules.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_24hr_noah.py b/lvt/utils/usaf/templates/make_lvt_config_24hr_noah.py index 8870eb841..a0bbcea04 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_24hr_noah.py +++ b/lvt/utils/usaf/templates/make_lvt_config_24hr_noah.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_24hr_noahmp.py b/lvt/utils/usaf/templates/make_lvt_config_24hr_noahmp.py index 4defa1c92..953d95772 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_24hr_noahmp.py +++ b/lvt/utils/usaf/templates/make_lvt_config_24hr_noahmp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_3hr_jules.py b/lvt/utils/usaf/templates/make_lvt_config_3hr_jules.py index 0353f2450..6db6b4c97 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_3hr_jules.py +++ b/lvt/utils/usaf/templates/make_lvt_config_3hr_jules.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_3hr_jules_galwem.py b/lvt/utils/usaf/templates/make_lvt_config_3hr_jules_galwem.py index aa2fb275c..2b934b00e 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_3hr_jules_galwem.py +++ b/lvt/utils/usaf/templates/make_lvt_config_3hr_jules_galwem.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_3hr_noah.py b/lvt/utils/usaf/templates/make_lvt_config_3hr_noah.py index 1245d232d..2c427bd35 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_3hr_noah.py +++ b/lvt/utils/usaf/templates/make_lvt_config_3hr_noah.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_3hr_noahmp.py b/lvt/utils/usaf/templates/make_lvt_config_3hr_noahmp.py index b6210e4ef..ce295bad5 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_3hr_noahmp.py +++ b/lvt/utils/usaf/templates/make_lvt_config_3hr_noahmp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/make_lvt_config_sm_anomaly_00z.py b/lvt/utils/usaf/templates/make_lvt_config_sm_anomaly_00z.py index b8b0d4a99..94d004fcb 100755 --- a/lvt/utils/usaf/templates/make_lvt_config_sm_anomaly_00z.py +++ b/lvt/utils/usaf/templates/make_lvt_config_sm_anomaly_00z.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_jules.py b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_jules.py index 27cba0e98..9ffa8ae5c 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_jules.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_jules.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noah.py b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noah.py index d06b383dd..fd8ae973a 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noah.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noah.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noahmp.py b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noahmp.py index 2a43a9646..8566d31ef 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noahmp.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_24hr_noahmp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules.py b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules.py index 218620797..3986e8c2e 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules_galwem.py b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules_galwem.py index 25f40ae79..16866fc28 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules_galwem.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_jules_galwem.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noah.py b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noah.py index d82f903cf..0fe10292d 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noah.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noah.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noahmp.py b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noahmp.py index fd0d9d401..d8281dc98 100755 --- a/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noahmp.py +++ b/lvt/utils/usaf/templates/submit_lvt_discover_3hr_noahmp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_jules.py b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_jules.py index 6cb33cb42..6e25c7614 100755 --- a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_jules.py +++ b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_jules.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noah.py b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noah.py index 5d6ec65ec..c2766ef9c 100755 --- a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noah.py +++ b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noah.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noahmp.py b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noahmp.py index 7ec60ccc3..b3dbb1bef 100755 --- a/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noahmp.py +++ b/lvt/utils/usaf/templates/submit_lvt_hpc11_3hr_noahmp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/usafsipost/make_lvt_config_usafsipost.py b/lvt/utils/usaf/usafsipost/make_lvt_config_usafsipost.py index b7865ce7c..25ca4f0a5 100755 --- a/lvt/utils/usaf/usafsipost/make_lvt_config_usafsipost.py +++ b/lvt/utils/usaf/usafsipost/make_lvt_config_usafsipost.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lvt/utils/usaf/usafsipost/submit_lvt_usafsipost_discover.py b/lvt/utils/usaf/usafsipost/submit_lvt_usafsipost_discover.py index 71239fedf..e78430915 100755 --- a/lvt/utils/usaf/usafsipost/submit_lvt_usafsipost_discover.py +++ b/lvt/utils/usaf/usafsipost/submit_lvt_usafsipost_discover.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- From 80e3cf9452e296bb4fc487d467e3e44173e12aec Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 2 Jan 2024 15:26:20 -0500 Subject: [PATCH 259/328] Update copyright notice on LIS files for LISF 7.5.0 public release --- lis/apps/landslide/GLS/GLSMod.F90 | 4 ++-- .../landslide/GLS/pe_raint/GLS_getpeobspred_raint.F90 | 4 ++-- lis/apps/landslide/GLS/pe_raint/GLS_param_reset.F90 | 4 ++-- lis/apps/landslide/GLS/pe_raint/GLS_qcdec_raint.F90 | 4 ++-- lis/apps/landslide/GLS/pe_raint/GLS_setdec_raint.F90 | 4 ++-- .../landslide/GLS/pe_raint/GLS_setupobspred_raint.F90 | 4 ++-- lis/apps/landslide/TRIGRS/TRIGRSMod.F90 | 4 ++-- lis/apps/landslide/TRIGRS/grids.F90 | 4 ++-- lis/apps/landslide/TRIGRS/input_file_defs.F90 | 4 ++-- lis/apps/landslide/TRIGRS/input_vars.F90 | 4 ++-- lis/apps/landslide/TRIGRS/model_vars.F90 | 4 ++-- lis/arch/Config.pl | 4 ++-- lis/compile | 4 ++-- .../557WW-7.3-FOC/JULES/single_snow_layer/gen_time.py | 4 ++-- .../NRT_GLOBAL/JULES/single_snow_layer/gen_time.py | 4 ++-- .../NRT_GLOBAL/JULES/single_snow_layer/gen_time.py | 4 ++-- .../NRT_STREAMFLOW/JULES/single_snow_layer/gen_time.py | 4 ++-- lis/configure | 4 ++-- lis/core/0Intro_core.txt | 4 ++-- lis/core/FTable.c | 4 ++-- lis/core/FTable.h | 4 ++-- lis/core/LIS_DAobservationsMod.F90 | 4 ++-- lis/core/LIS_FORC_AttributesMod.F90 | 4 ++-- lis/core/LIS_LMLCMod.F90 | 4 ++-- lis/core/LIS_PE_HandlerMod.F90 | 4 ++-- lis/core/LIS_PRIV_gridMod.F90 | 4 ++-- lis/core/LIS_PRIV_rcMod.F90 | 4 ++-- lis/core/LIS_PRIV_tileMod.F90 | 4 ++-- lis/core/LIS_RTMMod.F90 | 4 ++-- lis/core/LIS_RTM_FTable.c | 4 ++-- lis/core/LIS_String_Utility.F90 | 4 ++-- lis/core/LIS_XMRG_Reader.F90 | 4 ++-- lis/core/LIS_alb_FTable.c | 4 ++-- lis/core/LIS_albedoMod.F90 | 4 ++-- lis/core/LIS_appMod.F90 | 4 ++-- lis/core/LIS_biasestim_FTable.c | 4 ++-- lis/core/LIS_constantsMod.F90 | 4 ++-- lis/core/LIS_coreMod.F90 | 4 ++-- lis/core/LIS_create_subdirs.c | 4 ++-- lis/core/LIS_dataAssimMod.F90 | 4 ++-- lis/core/LIS_dataassim_FTable.c | 4 ++-- lis/core/LIS_domainMod.F90 | 4 ++-- lis/core/LIS_domain_FTable.c | 4 ++-- lis/core/LIS_emissMod.F90 | 4 ++-- lis/core/LIS_emiss_FTable.c | 4 ++-- lis/core/LIS_fileIOMod.F90 | 4 ++-- lis/core/LIS_forecastAlg_FTable.c | 4 ++-- lis/core/LIS_forecastMod.F90 | 4 ++-- lis/core/LIS_gfrac_FTable.c | 4 ++-- lis/core/LIS_glacierModelMod.F90 | 4 ++-- lis/core/LIS_glaciermodel_FTable.c | 4 ++-- lis/core/LIS_gridmappingMod.F90 | 4 ++-- lis/core/LIS_gswpMod.F90 | 4 ++-- lis/core/LIS_histDataMod.F90 | 4 ++-- lis/core/LIS_historyMod.F90 | 4 ++-- lis/core/LIS_initialize_registries.F90 | 4 ++-- lis/core/LIS_irrigationMod.F90 | 4 ++-- lis/core/LIS_irrigation_FTable.c | 4 ++-- lis/core/LIS_laisai_FTable.c | 4 ++-- lis/core/LIS_lakemodelMod.F90 | 4 ++-- lis/core/LIS_lakemodel_FTable.c | 4 ++-- lis/core/LIS_landslideMod.F90 | 4 ++-- lis/core/LIS_landslide_FTable.c | 4 ++-- lis/core/LIS_logMod.F90 | 4 ++-- lis/core/LIS_log_msgC.c | 4 ++-- lis/core/LIS_lsmMod.F90 | 4 ++-- lis/core/LIS_lsm_FTable.c | 4 ++-- lis/core/LIS_mapSoilType.F90 | 4 ++-- lis/core/LIS_mapSurfaceModelType.F90 | 4 ++-- lis/core/LIS_memory_managementC.c | 4 ++-- lis/core/LIS_metforcingMod.F90 | 4 ++-- lis/core/LIS_metforcing_FTable.c | 4 ++-- lis/core/LIS_microMetCorrection.F90 | 4 ++-- lis/core/LIS_mpDecomp.c | 4 ++-- lis/core/LIS_mpiMod.F90 | 4 ++-- lis/core/LIS_numerRecipesMod.F90 | 4 ++-- lis/core/LIS_openwater_FTable.c | 4 ++-- lis/core/LIS_openwatermodelMod.F90 | 4 ++-- lis/core/LIS_optUEMod.F90 | 4 ++-- lis/core/LIS_optUE_FTable.c | 4 ++-- lis/core/LIS_paramsMod.F90 | 4 ++-- lis/core/LIS_perturbMod.F90 | 4 ++-- lis/core/LIS_perturb_FTable.c | 4 ++-- lis/core/LIS_precisionMod.F90 | 4 ++-- lis/core/LIS_process_cmd_args.F90 | 4 ++-- lis/core/LIS_ran2_gasdev.F90 | 4 ++-- lis/core/LIS_readConfig.F90 | 4 ++-- lis/core/LIS_readDAObsAttributes.F90 | 4 ++-- lis/core/LIS_readPEDecSpaceAttributes.F90 | 4 ++-- lis/core/LIS_roughness_FTable.c | 4 ++-- lis/core/LIS_routingMod.F90 | 4 ++-- lis/core/LIS_routing_FTable.c | 4 ++-- lis/core/LIS_runmode_FTable.c | 4 ++-- lis/core/LIS_runoffdata_FTable.c | 4 ++-- lis/core/LIS_snowMod.F90 | 4 ++-- lis/core/LIS_soilsMod.F90 | 4 ++-- lis/core/LIS_spatialDownscalingMod.F90 | 4 ++-- lis/core/LIS_sublsm_FTable.c | 4 ++-- lis/core/LIS_surfaceModelDataMod.F90 | 4 ++-- lis/core/LIS_surfaceModelMod.F90 | 4 ++-- lis/core/LIS_tbotAdjustMod.F90 | 4 ++-- lis/core/LIS_timeMgrMod.F90 | 4 ++-- lis/core/LIS_topoMod.F90 | 4 ++-- lis/core/LIS_vegDataMod.F90 | 4 ++-- lis/core/fbil_module.F90 | 4 ++-- lis/core/readzipf.c | 4 ++-- lis/core/xmrg_read_data_c.c | 4 ++-- lis/core/xmrg_read_header_c.c | 4 ++-- lis/core/xmrg_reverse_byte.c | 4 ++-- lis/core/xmrg_reverse_byte.h | 4 ++-- lis/dataassim/algorithm/0Intro_algorithms.txt | 4 ++-- lis/dataassim/algorithm/di/0Intro_di.txt | 4 ++-- lis/dataassim/algorithm/di/directInsertion_Mod.F90 | 4 ++-- lis/dataassim/algorithm/ekf/ekf_Mod.F90 | 4 ++-- lis/dataassim/algorithm/enkf/0Intro_gmaoenkf.txt | 4 ++-- lis/dataassim/algorithm/enkf/enkf_Mod.F90 | 4 ++-- lis/dataassim/algorithm/enkf/enkf_general.F90 | 4 ++-- lis/dataassim/algorithm/enkf/enkf_types.F90 | 4 ++-- lis/dataassim/algorithm/enkf/gmaoenkf_module.F90.public | 4 ++-- lis/dataassim/algorithm/enkf/my_lu_decomp.F90 | 4 ++-- lis/dataassim/algorithm/enkf/my_matrix_functions.F90 | 4 ++-- lis/dataassim/algorithm/enkf/nr_sort.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/enks_general.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/enks_lu_decomp.F90 | 4 ++-- .../algorithm/enksgrace/enks_matrix_functions.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/enks_types.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/enksgrace_Mod.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/nr_fft.F90 | 4 ++-- lis/dataassim/algorithm/enksgrace/random_fields.F90.old | 4 ++-- lis/dataassim/algorithm/ensrf/ensrf_Mod.F90 | 4 ++-- lis/dataassim/algorithm/ensrf/ensrf_general.F90 | 4 ++-- lis/dataassim/algorithm/ensrf/ensrf_types.F90 | 4 ++-- lis/dataassim/algorithm/pf/pf_Mod.F90 | 4 ++-- lis/dataassim/algorithm/pf/pf_general.F90 | 4 ++-- lis/dataassim/algorithm/pf/pf_types.F90 | 4 ++-- lis/dataassim/biasEstimation/0Intro_biasest.txt | 4 ++-- .../biasEstimation/gmaoBE/gmaobias_estimationMod.F90 | 4 ++-- lis/dataassim/obs/0Intro_obs.txt | 4 ++-- lis/dataassim/obs/AMSRE_SWE/AMSRE_SWE_Mod.F90 | 4 ++-- lis/dataassim/obs/AMSRE_SWE/read_AMSRE_SWE.F90 | 4 ++-- lis/dataassim/obs/AMSRE_SWE/write_AMSRE_SWEobs.F90 | 4 ++-- lis/dataassim/obs/ANSA_SCF/0Intro_ansascf.txt | 4 ++-- lis/dataassim/obs/ANSA_SCF/ANSASCFsnow_Mod.F90 | 4 ++-- lis/dataassim/obs/ANSA_SCF/read_ANSASCFsnow.F90 | 4 ++-- lis/dataassim/obs/ANSA_SCF/write_ANSASCFsnow.F90 | 4 ++-- lis/dataassim/obs/ANSA_SNWD/ANSASNWDsnow_Mod.F90 | 4 ++-- lis/dataassim/obs/ANSA_SNWD/read_ANSASNWDsnow.F90 | 4 ++-- lis/dataassim/obs/ANSA_SNWD/write_ANSASNWDsnow.F90 | 4 ++-- lis/dataassim/obs/ANSA_SWE/ANSASWEsnow_Mod.F90 | 4 ++-- lis/dataassim/obs/ANSA_SWE/read_ANSASWEsnow.F90 | 4 ++-- lis/dataassim/obs/ANSA_SWE/write_ANSASWEsnow.F90 | 4 ++-- lis/dataassim/obs/ASCAT_TUW/ASCAT_TUWsm_Mod.F90 | 4 ++-- lis/dataassim/obs/ASCAT_TUW/read_ASCAT_TUWsm.F90 | 4 ++-- lis/dataassim/obs/ASCAT_TUW/write_ASCAT_TUWsmobs.F90 | 4 ++-- lis/dataassim/obs/ASO_SWE/ASO_SWE_Mod.F90 | 4 ++-- lis/dataassim/obs/ASO_SWE/read_ASO_SWE.F90 | 4 ++-- lis/dataassim/obs/ASO_SWE/write_ASO_SWEobs.F90 | 4 ++-- lis/dataassim/obs/CDFS_GVF/CDFSgvf_Mod.F90 | 2 +- lis/dataassim/obs/CDFS_GVF/read_CDFSgvf.F90 | 2 +- lis/dataassim/obs/CDFS_GVF/write_CDFSgvfobs.F90 | 2 +- .../cdfTransfer_NASASMAPsm_Mod.F90 | 4 ++-- .../read_cdfTransfer_NASASMAPsm.F90 | 4 ++-- .../write_cdfTransfer_NASASMAPsmobs.F90 | 4 ++-- lis/dataassim/obs/ESACCI_sm/ESACCI_sm_Mod.F90 | 4 ++-- lis/dataassim/obs/ESACCI_sm/read_ESACCIsm.F90 | 4 ++-- lis/dataassim/obs/ESACCI_sm/write_ESACCIsmobs.F90 | 4 ++-- .../obs/GCOMW_AMSR2L3SND/GCOMW_AMSR2L3SND_Mod.F90 | 4 ++-- .../obs/GCOMW_AMSR2L3SND/read_GCOMW_AMSR2L3SND.F90 | 4 ++-- .../obs/GCOMW_AMSR2L3SND/write_GCOMW_AMSR2L3SNDobs.F90 | 4 ++-- lis/dataassim/obs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_Mod.F90 | 4 ++-- .../obs/GCOMW_AMSR2L3sm/read_GCOMW_AMSR2L3sm.F90 | 4 ++-- .../obs/GCOMW_AMSR2L3sm/write_GCOMW_AMSR2L3smobs.F90 | 4 ++-- lis/dataassim/obs/GLASS_Albedo/GLASSalbedo_Mod.F90 | 4 ++-- lis/dataassim/obs/GLASS_Albedo/read_GLASSalbedo.F90 | 4 ++-- lis/dataassim/obs/GLASS_Albedo/write_GLASSalbedo.F90 | 4 ++-- lis/dataassim/obs/GLASS_LAI/GLASSlai_Mod.F90 | 4 ++-- lis/dataassim/obs/GLASS_LAI/read_GLASSlai.F90 | 4 ++-- lis/dataassim/obs/GLASS_LAI/write_GLASSlai.F90 | 4 ++-- lis/dataassim/obs/GRACE/GRACEobs_module.F90 | 4 ++-- lis/dataassim/obs/GRACE/read_GRACEobs.F90 | 4 ++-- lis/dataassim/obs/GRACE/write_GRACEobs.F90 | 4 ++-- lis/dataassim/obs/IMS_sca/IMSsca_mod.F90 | 4 ++-- lis/dataassim/obs/IMS_sca/read_IMSsca.F90 | 4 ++-- lis/dataassim/obs/IMS_sca/write_IMSscaobs.F90 | 4 ++-- lis/dataassim/obs/ISCCP_Tskin/ISCCP_Tskin_module.F90 | 4 ++-- lis/dataassim/obs/ISCCP_Tskin/read_ISCCP_Tskin.F90 | 4 ++-- lis/dataassim/obs/ISCCP_Tskin/write_ISCCP_Tskin.F90 | 4 ++-- lis/dataassim/obs/LPRM_AMSREsm/LPRM_AMSREsm_Mod.F90 | 4 ++-- lis/dataassim/obs/LPRM_AMSREsm/read_LPRM_AMSREsm.F90 | 4 ++-- lis/dataassim/obs/LPRM_AMSREsm/write_LPRM_AMSREsmobs.F90 | 4 ++-- lis/dataassim/obs/MCD15A2H_LAI/MCD15A2Hlai_Mod.F90 | 4 ++-- lis/dataassim/obs/MCD15A2H_LAI/read_MCD15A2Hlai.F90 | 4 ++-- lis/dataassim/obs/MCD15A2H_LAI/write_MCD15A2Hlai.F90 | 4 ++-- lis/dataassim/obs/MODIS_SPORT_LAI/MODISsportLAI_Mod.F90 | 4 ++-- lis/dataassim/obs/MODIS_SPORT_LAI/read_MODISsportLAI.F90 | 4 ++-- lis/dataassim/obs/MODIS_SPORT_LAI/write_MODISsportLAI.F90 | 4 ++-- lis/dataassim/obs/MODISsca/0Intro_modissca.txt | 4 ++-- lis/dataassim/obs/MODISsca/MODISscaobs_module.F90 | 4 ++-- lis/dataassim/obs/MODISsca/read_MODISscaobs.F90 | 4 ++-- lis/dataassim/obs/MODISsca/write_MODISsca.F90 | 4 ++-- lis/dataassim/obs/NASA_AMSREsm/0Intro_nasaamsre.txt | 4 ++-- lis/dataassim/obs/NASA_AMSREsm/NASA_AMSREsm_Mod.F90 | 4 ++-- lis/dataassim/obs/NASA_AMSREsm/read_NASA_AMSREsm.F90 | 4 ++-- lis/dataassim/obs/NASA_AMSREsm/write_NASA_AMSREsmobs.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPsm/NASASMAPsm_Mod.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPsm/read_NASASMAPsm.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPsm/write_NASASMAPsmobs.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPvod/NASASMAPvod_Mod.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPvod/read_NASASMAPvod.F90 | 4 ++-- lis/dataassim/obs/NASA_SMAPvod/write_NASASMAPvodobs.F90 | 4 ++-- lis/dataassim/obs/PMW_snow/0Intro_PMW_snow.txt | 4 ++-- lis/dataassim/obs/PMW_snow/PMW_snow_Mod.F90 | 4 ++-- lis/dataassim/obs/PMW_snow/read_PMW_snow.F90 | 4 ++-- lis/dataassim/obs/PMW_snow/write_PMW_snowobs.F90 | 4 ++-- lis/dataassim/obs/SMAP_E_OPLsm/SMAPEOPLsm_Mod.F90 | 2 +- lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 | 2 +- lis/dataassim/obs/SMAP_E_OPLsm/write_SMAPEOPLsmobs.F90 | 2 +- lis/dataassim/obs/SMAP_NRTsm/SMAPNRTsm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMAP_NRTsm/create_filelist.c | 4 ++-- lis/dataassim/obs/SMAP_NRTsm/read_SMAPNRTsm.F90 | 4 ++-- lis/dataassim/obs/SMAP_NRTsm/write_SMAPNRTsmobs.F90 | 4 ++-- lis/dataassim/obs/SMMR_SNWD/SMMRSNWDsnow_Mod.F90 | 4 ++-- lis/dataassim/obs/SMMR_SNWD/read_SMMRSNWDsnow.F90 | 4 ++-- lis/dataassim/obs/SMMR_SNWD/write_SMMRSNWDsnow.F90 | 4 ++-- lis/dataassim/obs/SMOPS_AMSR2sm/SMOPS_AMSR2sm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90 | 4 ++-- .../obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90.old | 4 ++-- .../obs/SMOPS_AMSR2sm/write_SMOPS_AMSR2smobs.F90 | 4 ++-- lis/dataassim/obs/SMOPS_ASCATsm/SMOPS_ASCATsm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOPS_ASCATsm/read_SMOPS_ASCATsm.F90 | 4 ++-- .../obs/SMOPS_ASCATsm/write_SMOPS_ASCATsmobs.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90.old | 4 ++-- lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90.old | 4 ++-- lis/dataassim/obs/SMOPS_SMAPsm/write_SMOPS_SMAPsmobs.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMOSsm/SMOPS_SMOSsm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90 | 4 ++-- lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90.old | 4 ++-- lis/dataassim/obs/SMOPS_SMOSsm/write_SMOPS_SMOSsmobs.F90 | 4 ++-- lis/dataassim/obs/SMOS_L2sm/SMOSL2sm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOS_L2sm/read_SMOSL2sm.F90 | 4 ++-- lis/dataassim/obs/SMOS_L2sm/write_SMOSL2smobs.F90 | 4 ++-- lis/dataassim/obs/SMOS_NESDIS/SMOSNESDISsm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOS_NESDIS/read_SMOSNESDISsm.F90 | 4 ++-- lis/dataassim/obs/SMOS_NESDIS/write_SMOSNESDISsmobs.F90 | 4 ++-- lis/dataassim/obs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_Mod.F90 | 4 ++-- lis/dataassim/obs/SMOS_NRTNN_L2sm/read_SMOSNRTNNL2sm.F90 | 4 ++-- .../obs/SMOS_NRTNN_L2sm/read_dgg_lookup_table.F90 | 4 ++-- .../obs/SMOS_NRTNN_L2sm/write_SMOSNRTNNL2smobs.F90 | 4 ++-- lis/dataassim/obs/SNODAS/SNODAS_Mod.F90 | 4 ++-- lis/dataassim/obs/SNODAS/read_SNODAS.F90 | 4 ++-- lis/dataassim/obs/SNODAS/write_SNODAS.F90 | 4 ++-- lis/dataassim/obs/SNODEP/SNODEPobs_Mod.F90 | 4 ++-- lis/dataassim/obs/SNODEP/read_SNODEPobs.F90 | 4 ++-- lis/dataassim/obs/SNODEP/write_SNODEPobs.F90 | 4 ++-- lis/dataassim/obs/SSMI_SNWD/SSMISNWDsnow_Mod.F90 | 4 ++-- lis/dataassim/obs/SSMI_SNWD/read_SSMISNWDsnow.F90 | 4 ++-- lis/dataassim/obs/SSMI_SNWD/write_SSMISNWDsnow.F90 | 4 ++-- lis/dataassim/obs/SYN_LBAND_TB/SYN_LBAND_TB_Mod.F90 | 4 ++-- lis/dataassim/obs/SYN_LBAND_TB/read_SYN_LBAND_TB.F90 | 4 ++-- lis/dataassim/obs/SYN_LBAND_TB/write_SYN_LBAND_TB.F90 | 4 ++-- lis/dataassim/obs/THySM/THySM_Mod.F90 | 4 ++-- lis/dataassim/obs/THySM/read_THySM.F90 | 4 ++-- lis/dataassim/obs/THySM/write_THySM.F90 | 4 ++-- lis/dataassim/obs/USAFSI/USAFSIobs_Mod.F90 | 4 ++-- lis/dataassim/obs/USAFSI/read_USAFSIobs.F90 | 4 ++-- lis/dataassim/obs/USAFSI/write_USAFSIobs.F90 | 4 ++-- lis/dataassim/obs/VIIRS_GVF/VIIRSgvf_Mod.F90 | 2 +- lis/dataassim/obs/VIIRS_GVF/read_VIIRSgvf.F90 | 2 +- lis/dataassim/obs/VIIRS_GVF/write_VIIRSgvfobs.F90 | 2 +- lis/dataassim/obs/WUS_UCLAsnow/WUS_UCLAsnowMod.F90 | 4 ++-- lis/dataassim/obs/WUS_UCLAsnow/read_WUS_UCLAsnow.F90 | 4 ++-- lis/dataassim/obs/WUS_UCLAsnow/write_WUS_UCLAsnow.F90 | 4 ++-- lis/dataassim/obs/WindSat_Cband_sm/WindSatCsm_Mod.F90 | 4 ++-- lis/dataassim/obs/WindSat_Cband_sm/read_WindSatCsm.F90 | 4 ++-- .../obs/WindSat_Cband_sm/write_WindSatCsmobs.F90 | 4 ++-- lis/dataassim/obs/WindSat_sm/0Intro_windsat.txt | 4 ++-- lis/dataassim/obs/WindSat_sm/WindSatsm_Mod.F90 | 4 ++-- lis/dataassim/obs/WindSat_sm/read_WindSatsm.F90 | 4 ++-- lis/dataassim/obs/WindSat_sm/write_WindSatsmobs.F90 | 4 ++-- lis/dataassim/obs/hydrowebWL/hydrowebWLobs_module.F90 | 4 ++-- lis/dataassim/obs/hydrowebWL/read_hydrowebWLobs.F90 | 4 ++-- lis/dataassim/obs/hydrowebWL/write_hydrowebWLobs.F90 | 4 ++-- lis/dataassim/obs/multisynsmobs/multisynsmobs_Mod.F90 | 4 ++-- lis/dataassim/obs/multisynsmobs/read_multisynsmobs.F90 | 4 ++-- lis/dataassim/obs/pildas/pildassmobs_module.F90 | 4 ++-- lis/dataassim/obs/pildas/read_pildassmobs.F90 | 4 ++-- lis/dataassim/obs/pildas/write_pildassmobs.F90 | 4 ++-- lis/dataassim/obs/simGRACE_JPL/read_simGRACEJPLobs.F90 | 4 ++-- lis/dataassim/obs/simGRACE_JPL/simGRACEJPLobs_module.F90 | 4 ++-- lis/dataassim/obs/simGRACE_JPL/write_simGRACEJPLobs.F90 | 4 ++-- .../obs/syntheticSnowTb/read_syntheticSnowTbObs.F90 | 4 ++-- .../obs/syntheticSnowTb/syntheticSnowTbObs_Mod.F90 | 4 ++-- .../obs/syntheticSnowTb/write_syntheticSnowTbObs.F90 | 4 ++-- lis/dataassim/obs/syntheticlst/read_syntheticlstobs.F90 | 4 ++-- lis/dataassim/obs/syntheticlst/syntheticlstobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticsf/read_syntheticsfobs.F90 | 4 ++-- lis/dataassim/obs/syntheticsf/syntheticsfobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticsf/write_syntheticsfobs.F90 | 4 ++-- lis/dataassim/obs/syntheticsm/read_syntheticsmobs.F90 | 4 ++-- lis/dataassim/obs/syntheticsm/syntheticsmobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticsm/write_syntheticsmobs.F90 | 4 ++-- lis/dataassim/obs/syntheticsnd/read_syntheticsndobs.F90 | 4 ++-- lis/dataassim/obs/syntheticsnd/syntheticsndobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticsnd/write_syntheticsndobs.F90 | 4 ++-- lis/dataassim/obs/syntheticswe/read_syntheticsweobs.F90 | 4 ++-- lis/dataassim/obs/syntheticswe/syntheticsweobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticswe/write_syntheticsweobs.F90 | 4 ++-- lis/dataassim/obs/syntheticwl/read_syntheticwlobs.F90 | 4 ++-- lis/dataassim/obs/syntheticwl/syntheticwlobs_module.F90 | 4 ++-- lis/dataassim/obs/syntheticwl/write_syntheticwlobs.F90 | 4 ++-- lis/dataassim/perturb/0Intro_algorithms.txt | 4 ++-- lis/dataassim/perturb/gmaopert/0Intro_gmao.txt | 4 ++-- lis/dataassim/perturb/gmaopert/gmaopert_Mod.F90 | 4 ++-- lis/dataassim/perturb/gmaopert/landpert_module.F90 | 4 ++-- lis/dataassim/perturb/gmaopert/landpert_routines.F90 | 4 ++-- lis/dataassim/perturb/gmaopert/nr_jacobi.F90 | 4 ++-- lis/dataassim/perturb/gmaopert/random_fields.F90 | 4 ++-- lis/dataassim/perturb/uniform/uniformPert_Mod.F90 | 4 ++-- lis/domains/0Intro_domains.txt | 4 ++-- lis/domains/UTM/0Intro_utm.txt | 4 ++-- lis/domains/UTM/readinput_UTM.F90 | 4 ++-- lis/domains/catchment/createtiles_catch.F90 | 4 ++-- lis/domains/catchment/qs.F90 | 4 ++-- lis/domains/catchment/readinput_catch.F90 | 4 ++-- lis/domains/catchment/tile_coord_routines.F90 | 4 ++-- lis/domains/catchment/tile_coord_types.F90 | 4 ++-- lis/domains/gaussian/readinput_gaussian.F90 | 4 ++-- lis/domains/hrap/readinput_hrap.F90 | 4 ++-- lis/domains/lambert/0Intro_lambert.txt | 4 ++-- lis/domains/lambert/readinput_lambert.F90 | 4 ++-- lis/domains/latlon/0Intro_latlon.txt | 4 ++-- lis/domains/latlon/readinput_latlon.F90 | 4 ++-- lis/domains/merc/0Intro_merc.txt | 4 ++-- lis/domains/merc/readinput_merc.F90 | 4 ++-- lis/domains/polar/0Intro_polar.txt | 4 ++-- lis/domains/polar/readinput_polar.F90 | 4 ++-- lis/forecast/algorithm/ESPboot/ESPboot_Mod.F90 | 4 ++-- lis/forecast/algorithm/ESPconv/ESPconv_Mod.F90 | 4 ++-- lis/interp/0Intro_interp.txt | 4 ++-- lis/interp/UTM_utils.F90 | 4 ++-- lis/interp/bilinear_interp.F90 | 4 ++-- lis/interp/bilinear_interp_input.F90 | 4 ++-- lis/interp/bilinear_interp_input_withgrid.F90 | 4 ++-- lis/interp/breakpt_module.F90 | 4 ++-- lis/interp/compute_earth_coord.F90 | 4 ++-- lis/interp/compute_earth_coord_UTM.F90 | 4 ++-- lis/interp/compute_earth_coord_ease.F90 | 4 ++-- lis/interp/compute_earth_coord_gauss.F90 | 4 ++-- lis/interp/compute_earth_coord_hrap.F90 | 4 ++-- lis/interp/compute_earth_coord_lambert.F90 | 4 ++-- lis/interp/compute_earth_coord_latlon.F90 | 4 ++-- lis/interp/compute_earth_coord_latlon_ll.F90 | 4 ++-- lis/interp/compute_earth_coord_ll.F90 | 4 ++-- lis/interp/compute_earth_coord_merc.F90 | 4 ++-- lis/interp/compute_earth_coord_polar.F90 | 4 ++-- lis/interp/compute_grid_coord.F90 | 4 ++-- lis/interp/compute_grid_coord_ease.F90 | 4 ++-- lis/interp/compute_grid_coord_gauss.F90 | 4 ++-- lis/interp/compute_grid_coord_hrap.F90 | 4 ++-- lis/interp/compute_grid_coord_lambert.F90 | 4 ++-- lis/interp/compute_grid_coord_latlon.F90 | 4 ++-- lis/interp/compute_grid_coord_merc.F90 | 4 ++-- lis/interp/compute_grid_coord_polar.F90 | 4 ++-- lis/interp/compute_stnwts.F90 | 4 ++-- lis/interp/compute_vinterp_weights.F90 | 4 ++-- lis/interp/conserv_interp.F90 | 4 ++-- lis/interp/conserv_interp_input.F90 | 4 ++-- lis/interp/conserv_interp_input_withgrid.F90 | 4 ++-- lis/interp/defineLocalDomain.F90 | 4 ++-- lis/interp/diff_lon.F90 | 4 ++-- lis/interp/easeV2_utils.F90 | 4 ++-- lis/interp/ezlh_convert.F90 | 4 ++-- lis/interp/ezlh_inverse.F90 | 4 ++-- lis/interp/gaussian_mod.F90.keep | 4 ++-- lis/interp/gaussian_quadrature.F90 | 4 ++-- lis/interp/gaussian_routines.F90 | 4 ++-- lis/interp/gausslat.F90 | 4 ++-- lis/interp/get_fieldpos.F90 | 4 ++-- lis/interp/hrapToLatLon.F90 | 4 ++-- lis/interp/idw_module.F90 | 4 ++-- lis/interp/interp_stndata.F90 | 4 ++-- lis/interp/latlonTohrap.F90 | 4 ++-- lis/interp/latlonTopolar.F90 | 4 ++-- lis/interp/lltops.F90 | 4 ++-- lis/interp/map_utils.F90 | 4 ++-- lis/interp/mqb_module.F90 | 4 ++-- lis/interp/neighbor_interp.F90 | 4 ++-- lis/interp/neighbor_interp_input.F90 | 4 ++-- lis/interp/neighbor_interp_input_withgrid.F90 | 4 ++-- lis/interp/normalize_stnwts.F90 | 4 ++-- lis/interp/polarToLatLon.F90 | 4 ++-- lis/interp/polfixs.F90 | 4 ++-- lis/interp/pstoll.F90 | 4 ++-- lis/interp/snsoidxyTolatlon.F90 | 4 ++-- lis/interp/stninterp_module.F90 | 4 ++-- lis/interp/upscaleByAveraging.F90 | 4 ++-- lis/interp/upscaleByAveraging_input.F90 | 4 ++-- lis/interp/upscaleByWeightedAveraging.F90 | 4 ++-- lis/interp/upscaleByWeightedAveraging_input.F90 | 4 ++-- lis/interp/zterp.F90 | 4 ++-- lis/irrigation/drip/drip_irrigationMod.F90 | 4 ++-- lis/irrigation/flood/flood_irrigationMod.F90 | 4 ++-- lis/irrigation/sprinkler/sprinkler_irrigationMod.F90 | 4 ++-- lis/lib/lis-cmem3/atm.F90.turnoff | 4 ++-- lis/lib/lis-cmem3/desert.F90 | 4 ++-- lis/lib/lis-cmem3/dieldesert_sub.F90 | 4 ++-- lis/lib/lis-cmem3/dielice_sub.F90 | 4 ++-- lis/lib/lis-cmem3/dielsoil_sub.F90 | 4 ++-- lis/lib/lis-cmem3/dielwat_sub.F90 | 4 ++-- lis/lib/lis-cmem3/fresnel_sub.F90 | 4 ++-- lis/lib/lis-cmem3/liebe89_sub.F90.turnoff | 4 ++-- lis/lib/lis-cmem3/lis_mem.F90 | 4 ++-- lis/lib/lis-cmem3/rghref_sub.F90 | 4 ++-- lis/lib/lis-cmem3/snow.F90 | 4 ++-- lis/lib/lis-cmem3/soil.F90 | 4 ++-- lis/lib/lis-cmem3/veg.F90 | 4 ++-- lis/lib/lis-cmem3/veg_sub.F90 | 4 ++-- lis/lib/lis-cmem3/water.F90 | 4 ++-- lis/lib/lis-crtm/CRTM_MW_Land_SfcOptics.f90 | 4 ++-- lis/lib/lis-crtm/CRTM_MW_Snow_SfcOptics.f90 | 4 ++-- lis/lib/lis-crtm/CRTM_Surface_Define.f90 | 4 ++-- lis/lib/lis-crtm/NESDIS_LandEM_Module.f90 | 4 ++-- lis/lib/lis-crtm/README | 4 ++-- lis/lib/lis-crtm/Set_CRTM_Environment.sh | 4 ++-- lis/make/build_version.sh | 4 ++-- lis/make/makedep.py | 4 ++-- lis/make/plugins.py | 4 ++-- lis/metforcing/3B42RT/0Intro_3B42RT.txt | 4 ++-- lis/metforcing/3B42RT/TRMM3B42RT_forcingMod.F90 | 4 ++-- lis/metforcing/3B42RT/finalize_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RT/get_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RT/interp_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RT/read_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RT/readcrd_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RT/timeinterp_TRMM3B42RT.F90 | 4 ++-- lis/metforcing/3B42RTV7/0Intro_3B42RTV7.txt | 4 ++-- lis/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 | 4 ++-- lis/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 | 4 ++-- lis/metforcing/3B42V6/0Intro_3B42V6.txt | 4 ++-- lis/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 | 4 ++-- lis/metforcing/3B42V6/finalize_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V6/get_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V6/interp_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V6/read_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 | 4 ++-- lis/metforcing/3B42V7/0Intro_3B42V7.txt | 4 ++-- lis/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 | 4 ++-- lis/metforcing/3B42V7/finalize_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/3B42V7/get_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/3B42V7/interp_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/3B42V7/read_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 | 4 ++-- lis/metforcing/AWAP/AWAP_forcingMod.F90 | 4 ++-- lis/metforcing/AWAP/AWAPfile.F90 | 4 ++-- lis/metforcing/AWAP/finalize_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/get_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/interp_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/read_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/readcrd_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/reset_AWAP.F90 | 4 ++-- lis/metforcing/AWAP/timeinterp_AWAP.F90 | 4 ++-- lis/metforcing/AWRAL/AWRAL_forcingMod.F90 | 4 ++-- lis/metforcing/AWRAL/finalize_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/get_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/interp_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/read_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/readcrd_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/reset_AWRAL.F90 | 4 ++-- lis/metforcing/AWRAL/timeinterp_AWRAL.F90 | 4 ++-- lis/metforcing/Bondville/0Intro_Bondville.txt | 4 ++-- lis/metforcing/Bondville/Bondville_forcingMod.F90 | 4 ++-- lis/metforcing/Bondville/finalize_Bondville.F90 | 4 ++-- lis/metforcing/Bondville/get_Bondville.F90 | 4 ++-- lis/metforcing/Bondville/read_Bondville.F90 | 4 ++-- lis/metforcing/Bondville/readcrd_Bondville.F90 | 4 ++-- lis/metforcing/Bondville/timeinterp_Bondville.F90 | 4 ++-- lis/metforcing/COAMPSout/COAMPSout_forcingMod.F90 | 4 ++-- lis/metforcing/COAMPSout/finalize_COAMPSout.F90 | 4 ++-- lis/metforcing/COAMPSout/get_COAMPSout.F90 | 4 ++-- lis/metforcing/COAMPSout/read_COAMPSout.F90 | 4 ++-- lis/metforcing/COAMPSout/readcrd_COAMPSout.F90 | 4 ++-- lis/metforcing/COAMPSout/reset_COAMPSout.F90 | 4 ++-- lis/metforcing/COAMPSout/timeinterp_COAMPSout.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/HiMATGMU_forcingMod.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/HiMATGMUfile.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/finalize_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/get_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/interp_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/read_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/readcrd_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/reset_HiMATGMU.F90 | 4 ++-- lis/metforcing/HiMAT_GMU/timeinterp_HiMATGMU.F90 | 4 ++-- lis/metforcing/Loobos/0Intro_Loobos.txt | 4 ++-- lis/metforcing/Loobos/Loobos_forcingMod.F90 | 4 ++-- lis/metforcing/Loobos/code/0Intro_Bondville.txt | 4 ++-- lis/metforcing/Loobos/code/Loobos_forcingMod.F90 | 4 ++-- lis/metforcing/Loobos/code/finalize_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/code/get_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/code/read_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/code/readcrd_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/code/timeinterp_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/finalize_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/get_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/read_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/readcrd_Loobos.F90 | 4 ++-- lis/metforcing/Loobos/timeinterp_Loobos.F90 | 4 ++-- lis/metforcing/PALSmetdata/PALSmetdata_forcingMod.F90 | 4 ++-- lis/metforcing/PALSmetdata/finalize_PALSmetdata.F90 | 4 ++-- lis/metforcing/PALSmetdata/get_PALSmetdata.F90 | 4 ++-- lis/metforcing/PALSmetdata/readcrd_PALSmetdata.F90 | 4 ++-- lis/metforcing/PALSmetdata/reset_PALSmetdata.F90 | 4 ++-- lis/metforcing/PALSmetdata/timeinterp_PALSmetdata.F90 | 4 ++-- lis/metforcing/RFE2Daily/0Intro_rfe2daily.txt | 4 ++-- lis/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 | 4 ++-- lis/metforcing/RFE2Daily/finalize_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2Daily/get_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2Daily/reproject_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 | 4 ++-- lis/metforcing/RFE2gdas/0Intro_rfe2gdas.txt | 4 ++-- lis/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 | 4 ++-- lis/metforcing/RFE2gdas/finalize_RFE2gdas.F90 | 4 ++-- lis/metforcing/RFE2gdas/get_RFE2gdas.F90 | 4 ++-- lis/metforcing/RFE2gdas/readRFE2gdascrd.F90 | 4 ++-- lis/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 | 4 ++-- lis/metforcing/RFE2gdas/reproject_RFE2gdas.F90 | 4 ++-- lis/metforcing/RFE2gdas/reset_RFE2gdas.F90 | 4 ++-- lis/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 | 4 ++-- lis/metforcing/WRFAKdom/0Intro_WRF_AKdomain.txt | 4 ++-- lis/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 | 4 ++-- lis/metforcing/WRFAKdom/finalize_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFAKdom/get_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFAKdom/read_WRFAK_elev.F90 | 4 ++-- lis/metforcing/WRFAKdom/read_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFAKdom/reset_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFAKdom/timeinterp_WRF_AKdom.F90 | 4 ++-- lis/metforcing/WRFout/0Intro_wrfout.txt | 4 ++-- lis/metforcing/WRFout/WRFout_forcingMod.F90 | 4 ++-- lis/metforcing/WRFout/finalize_WRFout.F90 | 4 ++-- lis/metforcing/WRFout/get_WRFout.F90 | 4 ++-- lis/metforcing/WRFout/read_WRFout.F90 | 4 ++-- lis/metforcing/WRFout/readcrd_WRFout.F90 | 4 ++-- lis/metforcing/WRFout/reset_WRFout.F90 | 4 ++-- lis/metforcing/WRFout/timeinterp_WRFout.F90 | 4 ++-- lis/metforcing/WRFoutv2/0Intro_WRFoutv2.txt | 4 ++-- lis/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 | 4 ++-- lis/metforcing/WRFoutv2/finalize_WRFoutv2.F90 | 4 ++-- lis/metforcing/WRFoutv2/get_WRFoutv2.F90 | 4 ++-- lis/metforcing/WRFoutv2/read_WRFoutv2.F90 | 4 ++-- lis/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 | 4 ++-- lis/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 | 4 ++-- lis/metforcing/WRFoutv2/reset_WRFoutv2.F90 | 4 ++-- lis/metforcing/WRFoutv2/timeinterp_WRFoutv2.F90 | 4 ++-- lis/metforcing/agrradps/0Intro_agrmetradps.txt | 4 ++-- lis/metforcing/agrradps/agrlwdn.F90 | 4 ++-- lis/metforcing/agrradps/agrradps_filenames.F90 | 4 ++-- lis/metforcing/agrradps/agrradps_forcingMod.F90 | 4 ++-- lis/metforcing/agrradps/finalize_agrradps.F90 | 4 ++-- lis/metforcing/agrradps/get_agrradps.F90 | 4 ++-- lis/metforcing/agrradps/interp_agrradpsvar.F90 | 4 ++-- lis/metforcing/agrradps/read_agrradps.F90 | 4 ++-- lis/metforcing/agrradps/readcrd_agrradps.F90 | 4 ++-- lis/metforcing/agrradps/timeinterp_agrradps.F90 | 4 ++-- lis/metforcing/chirps2/chirps2_forcingMod.F90 | 4 ++-- lis/metforcing/chirps2/finalize_chirps2.F90 | 4 ++-- lis/metforcing/chirps2/get_chirps2.F90 | 4 ++-- lis/metforcing/chirps2/read_chirps2.F90 | 4 ++-- lis/metforcing/chirps2/readconfig_chirps2.F90 | 4 ++-- lis/metforcing/chirps2/reset_chirps2.F90 | 4 ++-- lis/metforcing/chirps2/timeinterp_chirps2.F90 | 4 ++-- .../climatology/climatology_SpatialInterpMod.F90 | 4 ++-- lis/metforcing/climatology/climatology_VariablesMod.F90 | 4 ++-- lis/metforcing/climatology/climatology_forcingMod.F90 | 4 ++-- lis/metforcing/climatology/finalize_climatology.F90 | 4 ++-- lis/metforcing/climatology/get_climatology.F90 | 4 ++-- lis/metforcing/climatology/get_climatology_filename.F90 | 4 ++-- lis/metforcing/climatology/readcrd_climatology.F90 | 4 ++-- lis/metforcing/climatology/reset_climatology.F90 | 4 ++-- lis/metforcing/climatology/timeinterp_climatology.F90 | 4 ++-- lis/metforcing/cmap/0Intro_cmap.txt | 4 ++-- lis/metforcing/cmap/cmap_forcingMod.F90 | 4 ++-- lis/metforcing/cmap/cmap_reset_interp_input.F90 | 4 ++-- lis/metforcing/cmap/finalize_cmap.F90 | 4 ++-- lis/metforcing/cmap/get_cmap.F90 | 4 ++-- lis/metforcing/cmap/interp_cmap.F90 | 4 ++-- lis/metforcing/cmap/read_cmap.F90 | 4 ++-- lis/metforcing/cmap/readcrd_cmap.F90 | 4 ++-- lis/metforcing/cmap/timeinterp_cmap.F90 | 4 ++-- lis/metforcing/cmorph/0Intro_cmorph.txt | 4 ++-- lis/metforcing/cmorph/cm_readzipf.c | 4 ++-- lis/metforcing/cmorph/cmorph_forcingMod.F90 | 4 ++-- lis/metforcing/cmorph/finalize_cmorph.F90 | 4 ++-- lis/metforcing/cmorph/fmktime.c | 4 ++-- lis/metforcing/cmorph/get_cmorph.F90 | 4 ++-- lis/metforcing/cmorph/interp_cmorph.F90 | 4 ++-- lis/metforcing/cmorph/read_cmorph.F90 | 4 ++-- lis/metforcing/cmorph/readcrd_cmorph.F90 | 4 ++-- lis/metforcing/cmorph/timeinterp_cmorph.F90 | 4 ++-- lis/metforcing/ecmwf/0Intro_ecmwf.txt | 4 ++-- lis/metforcing/ecmwf/ecmwf_forcingMod.F90 | 4 ++-- lis/metforcing/ecmwf/finalize_ecmwf.F90 | 4 ++-- lis/metforcing/ecmwf/get_ecmwf.F90 | 4 ++-- lis/metforcing/ecmwf/read_ecmwf.F90 | 4 ++-- lis/metforcing/ecmwf/read_ecmwf_elev.F90 | 4 ++-- lis/metforcing/ecmwf/readcrd_ecmwf.F90 | 4 ++-- lis/metforcing/ecmwf/reset_ecmwf.F90 | 4 ++-- lis/metforcing/ecmwf/timeinterp_ecmwf.F90 | 4 ++-- lis/metforcing/era5/era5_forcingMod.F90 | 4 ++-- lis/metforcing/era5/finalize_era5.F90 | 4 ++-- lis/metforcing/era5/get_era5.F90 | 4 ++-- lis/metforcing/era5/read_era5.F90 | 4 ++-- lis/metforcing/era5/read_era5_elev.F90 | 4 ++-- lis/metforcing/era5/readcrd_era5.F90 | 4 ++-- lis/metforcing/era5/reset_era5.F90 | 4 ++-- lis/metforcing/era5/timeinterp_era5.F90 | 4 ++-- lis/metforcing/galwem/finalize_galwem.F90 | 4 ++-- lis/metforcing/galwem/galwem_forcingMod.F90 | 4 ++-- lis/metforcing/galwem/get_galwem.F90 | 4 ++-- lis/metforcing/galwem/read_galwem.F90 | 4 ++-- lis/metforcing/galwem/readcrd_galwem.F90 | 4 ++-- lis/metforcing/galwem/reset_galwem.F90 | 4 ++-- lis/metforcing/galwem/timeinterp_galwem.F90 | 4 ++-- lis/metforcing/galwem_ge/finalize_galwemge.F90 | 4 ++-- lis/metforcing/galwem_ge/galwemge_forcingMod.F90 | 4 ++-- lis/metforcing/galwem_ge/get_galwemge.F90 | 4 ++-- lis/metforcing/galwem_ge/read_galwemge.F90 | 4 ++-- lis/metforcing/galwem_ge/readcrd_galwemge.F90 | 4 ++-- lis/metforcing/galwem_ge/reset_galwemge.F90 | 4 ++-- lis/metforcing/galwem_ge/timeinterp_galwemge.F90 | 4 ++-- lis/metforcing/gdas/0Intro_gdas.txt | 4 ++-- lis/metforcing/gdas/create_gdasf9_filename.F90 | 4 ++-- lis/metforcing/gdas/create_gdasfilename.F90 | 4 ++-- lis/metforcing/gdas/finalize_gdas.F90 | 4 ++-- lis/metforcing/gdas/gdas_forcingMod.F90 | 4 ++-- lis/metforcing/gdas/gdas_reset_interp_input.F90 | 4 ++-- lis/metforcing/gdas/get_gdas.F90 | 4 ++-- lis/metforcing/gdas/read_gdas.F90 | 4 ++-- lis/metforcing/gdas/read_gdas_elev.F90 | 4 ++-- lis/metforcing/gdas/readcrd_gdas.F90 | 4 ++-- lis/metforcing/gdas/reset_gdas.F90 | 4 ++-- lis/metforcing/gdas/timeinterp_gdas.F90 | 4 ++-- lis/metforcing/gdasT1534/create_gdasT1534filename.F90 | 4 ++-- lis/metforcing/gdasT1534/finalize_gdasT1534.F90 | 4 ++-- lis/metforcing/gdasT1534/gdasT1534_forcingMod.F90 | 4 ++-- lis/metforcing/gdasT1534/get_gdasT1534.F90 | 4 ++-- lis/metforcing/gdasT1534/read_gdasT1534.F90 | 4 ++-- lis/metforcing/gdasT1534/readcrd_gdasT1534.F90 | 4 ++-- lis/metforcing/gdasT1534/reset_gdasT1534.F90 | 4 ++-- lis/metforcing/gdasT1534/timeinterp_gdasT1534.F90 | 4 ++-- lis/metforcing/gddp/finalize_gddp.F90 | 4 ++-- lis/metforcing/gddp/gddp_forcingMod.F90 | 4 ++-- lis/metforcing/gddp/get_gddp.F90 | 4 ++-- lis/metforcing/gddp/read_gddp.F90 | 4 ++-- lis/metforcing/gddp/readcrd_gddp.F90 | 4 ++-- lis/metforcing/gddp/reset_gddp.F90 | 4 ++-- lis/metforcing/gddp/timeinterp_gddp.F90 | 4 ++-- lis/metforcing/gefs/0Intro_gefs.txt | 4 ++-- lis/metforcing/gefs/finalize_gefs.F90 | 4 ++-- lis/metforcing/gefs/gefs_forcingMod.F90 | 4 ++-- lis/metforcing/gefs/get_gefs.F90 | 4 ++-- lis/metforcing/gefs/interp_gefs.F90 | 4 ++-- lis/metforcing/gefs/read_gefs_operational.F90 | 4 ++-- lis/metforcing/gefs/read_gefs_reforecast.F90 | 4 ++-- lis/metforcing/gefs/readcrd_gefs.F90 | 4 ++-- lis/metforcing/gefs/reset_gefs.F90 | 4 ++-- lis/metforcing/gefs/timeinterp_gefs.F90 | 4 ++-- lis/metforcing/genEnsFcst/0Intro_genEnsFcst.txt | 4 ++-- lis/metforcing/genEnsFcst/finalize_genEnsFcst.F90 | 4 ++-- lis/metforcing/genEnsFcst/genEnsFcst_SpatialInterpMod.F90 | 4 ++-- lis/metforcing/genEnsFcst/genEnsFcst_VariablesMod.F90 | 4 ++-- lis/metforcing/genEnsFcst/genEnsFcst_forcingMod.F90 | 4 ++-- lis/metforcing/genEnsFcst/get_genEnsFcst.F90 | 4 ++-- lis/metforcing/genEnsFcst/get_genEnsFcst_filename.F90 | 4 ++-- lis/metforcing/genEnsFcst/readcrd_genEnsFcst.F90 | 4 ++-- lis/metforcing/genEnsFcst/reset_genEnsFcst.F90 | 4 ++-- lis/metforcing/genEnsFcst/timeinterp_genEnsFcst.F90 | 4 ++-- lis/metforcing/genMetForc/0Intro_metForceGenerated.txt | 4 ++-- lis/metforcing/genMetForc/finalize_metForcGenerated.F90 | 4 ++-- lis/metforcing/genMetForc/get_metForcGen_filename.F90 | 4 ++-- lis/metforcing/genMetForc/get_metForcGenerated.F90 | 4 ++-- lis/metforcing/genMetForc/metForcGen_SpatialInterpMod.F90 | 4 ++-- lis/metforcing/genMetForc/metForcGen_VariablesMod.F90 | 4 ++-- lis/metforcing/genMetForc/metForcGenerated_forcingMod.F90 | 4 ++-- lis/metforcing/genMetForc/readcrd_metForcGenerated.F90 | 4 ++-- lis/metforcing/genMetForc/reset_metForcGenerated.F90 | 4 ++-- lis/metforcing/genMetForc/timeinterp_metForcGenerated.F90 | 4 ++-- lis/metforcing/geos5fcst/finalize_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/geos5fcst_forcingMod.F90 | 4 ++-- lis/metforcing/geos5fcst/get_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/interp_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/read_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/readcrd_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/reset_geos5fcst.F90 | 4 ++-- lis/metforcing/geos5fcst/timeinterp_geos5fcst.F90 | 4 ++-- lis/metforcing/geos_it/0Intro_geosit.txt | 4 ++-- lis/metforcing/geos_it/finalize_geosit.F90 | 4 ++-- lis/metforcing/geos_it/geosit_forcingMod.F90 | 4 ++-- lis/metforcing/geos_it/get_geosit.F90 | 4 ++-- lis/metforcing/geos_it/read_geosit.F90 | 4 ++-- lis/metforcing/geos_it/read_geosit_elev.F90 | 4 ++-- lis/metforcing/geos_it/readcrd_geosit.F90 | 4 ++-- lis/metforcing/geos_it/reset_geosit.F90 | 4 ++-- lis/metforcing/geos_it/timeinterp_geosit.F90 | 4 ++-- lis/metforcing/gfs/0Intro_gfs.txt | 4 ++-- lis/metforcing/gfs/create_gfs_f0backup_filename.F90 | 4 ++-- lis/metforcing/gfs/create_gfsfilename.F90 | 4 ++-- lis/metforcing/gfs/finalize_gfs.F90 | 4 ++-- lis/metforcing/gfs/get_gfs.F90 | 4 ++-- lis/metforcing/gfs/gfs_forcingMod.F90 | 4 ++-- lis/metforcing/gfs/read_gfs.F90 | 4 ++-- lis/metforcing/gfs/read_gfs_elev.F90 | 4 ++-- lis/metforcing/gfs/readcrd_gfs.F90 | 4 ++-- lis/metforcing/gfs/timeinterp_gfs.F90 | 4 ++-- lis/metforcing/gldas/0Intro_gldas.txt | 4 ++-- lis/metforcing/gldas/fillgaps_gldas.F90 | 4 ++-- lis/metforcing/gldas/finalize_gldas.F90 | 4 ++-- lis/metforcing/gldas/get_gldas.F90 | 4 ++-- lis/metforcing/gldas/gldas_forcingMod.F90 | 4 ++-- lis/metforcing/gldas/read_gldas.F90 | 4 ++-- lis/metforcing/gldas/readcrd_gldas.F90 | 4 ++-- lis/metforcing/gldas/timeinterp_gldas.F90 | 4 ++-- lis/metforcing/gswp1/0Intro_gswp1.txt | 4 ++-- lis/metforcing/gswp1/finalize_gswp1.F90 | 4 ++-- lis/metforcing/gswp1/get_gswp1.F90 | 4 ++-- lis/metforcing/gswp1/gswp1_forcingMod.F90 | 4 ++-- lis/metforcing/gswp1/read_gswp1.F90 | 4 ++-- lis/metforcing/gswp1/readcrd_gswp1.F90 | 4 ++-- lis/metforcing/gswp1/timeinterp_gswp1.F90 | 4 ++-- lis/metforcing/gswp2/0Intro_gswp.txt | 4 ++-- lis/metforcing/gswp2/fillgaps_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/finalize_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/finterp_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/get_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/gswp2_forcingMod.F90 | 4 ++-- lis/metforcing/gswp2/read_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/readcrd_gswp2.F90 | 4 ++-- lis/metforcing/gswp2/timeinterp_gswp2.F90 | 4 ++-- lis/metforcing/imerg/finalize_imerg.F90 | 4 ++-- lis/metforcing/imerg/get_imerg.F90 | 4 ++-- lis/metforcing/imerg/imerg_forcingMod.F90 | 4 ++-- lis/metforcing/imerg/interp_imerg.F90 | 4 ++-- lis/metforcing/imerg/read_imerg.F90 | 4 ++-- lis/metforcing/imerg/readcrd_imerg.F90 | 4 ++-- lis/metforcing/imerg/reset_imerg.F90 | 4 ++-- lis/metforcing/imerg/timeinterp_imerg.F90 | 4 ++-- lis/metforcing/merra2/0Intro_merra2.txt | 4 ++-- lis/metforcing/merra2/finalize_merra2.F90 | 4 ++-- lis/metforcing/merra2/get_merra2.F90 | 4 ++-- lis/metforcing/merra2/merra2_forcingMod.F90 | 4 ++-- lis/metforcing/merra2/read_merra2.F90 | 4 ++-- lis/metforcing/merra2/read_merra2_elev.F90 | 4 ++-- lis/metforcing/merra2/readcrd_merra2.F90 | 4 ++-- lis/metforcing/merra2/reset_merra2.F90 | 4 ++-- lis/metforcing/merra2/timeinterp_merra2.F90 | 4 ++-- lis/metforcing/mrms/finalize_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/get_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/interp_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/mrms_grib_forcingMod.F90 | 4 ++-- lis/metforcing/mrms/mrms_gribfile.F90 | 4 ++-- lis/metforcing/mrms/read_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/readcrd_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/reset_mrms_grib.F90 | 4 ++-- lis/metforcing/mrms/timeinterp_mrms_grib.F90 | 4 ++-- lis/metforcing/nam242/0Intro_nam242.txt | 4 ++-- lis/metforcing/nam242/create_nam242f9_filename.F90 | 4 ++-- lis/metforcing/nam242/create_nam242filename.F90 | 4 ++-- lis/metforcing/nam242/finalize_nam242.F90 | 4 ++-- lis/metforcing/nam242/get_nam242.F90 | 4 ++-- lis/metforcing/nam242/nam242_forcingMod.F90 | 4 ++-- lis/metforcing/nam242/read_nam242.F90 | 4 ++-- lis/metforcing/nam242/read_nam242_elev.F90 | 4 ++-- lis/metforcing/nam242/readcrd_nam242.F90 | 4 ++-- lis/metforcing/nam242/reset_nam242.F90 | 4 ++-- lis/metforcing/nam242/timeinterp_nam242.F90 | 4 ++-- lis/metforcing/narr/0Intro_narr.txt | 4 ++-- lis/metforcing/narr/finalize_narr.F90 | 4 ++-- lis/metforcing/narr/get_narr.F90 | 4 ++-- lis/metforcing/narr/interp_narrfield.F90 | 4 ++-- lis/metforcing/narr/narr_forcingMod.F90 | 4 ++-- lis/metforcing/narr/read_narr.F90 | 4 ++-- lis/metforcing/narr/readcrd_narr.F90 | 4 ++-- lis/metforcing/narr/timeinterp_narr.F90 | 4 ++-- lis/metforcing/nldas2/0Intro_nldas2.txt | 4 ++-- lis/metforcing/nldas2/finalize_nldas2.F90 | 4 ++-- lis/metforcing/nldas2/get_gesdisc_filenames.F90 | 4 ++-- lis/metforcing/nldas2/get_ncep_filenames.F90 | 4 ++-- lis/metforcing/nldas2/get_nldas2.F90 | 4 ++-- lis/metforcing/nldas2/nldas2_ec_removal.F90 | 4 ++-- lis/metforcing/nldas2/nldas2_forcingMod.F90 | 4 ++-- lis/metforcing/nldas2/read_nldas2_elev.F90 | 4 ++-- lis/metforcing/nldas2/read_nldas2a.F90 | 4 ++-- lis/metforcing/nldas2/read_nldas2b.F90 | 4 ++-- lis/metforcing/nldas2/read_orig_nldas2_elevdiff.F90 | 4 ++-- lis/metforcing/nldas2/readcrd_nldas2.F90 | 4 ++-- lis/metforcing/nldas2/reset_nldas2.F90 | 4 ++-- lis/metforcing/nldas2/timeinterp_nldas2.F90 | 4 ++-- lis/metforcing/pet_usgs/0Intro_petusgs.txt | 4 ++-- lis/metforcing/pet_usgs/finalize_petusgs.F90 | 4 ++-- lis/metforcing/pet_usgs/get_petusgs.F90 | 4 ++-- lis/metforcing/pet_usgs/interp_petusgs.F90 | 4 ++-- lis/metforcing/pet_usgs/petusgs_forcingMod.F90 | 4 ++-- lis/metforcing/pet_usgs/read_petusgs.F90 | 4 ++-- lis/metforcing/pet_usgs/readpetusgscrd.F90 | 4 ++-- lis/metforcing/pet_usgs/timeinterp_petusgs.F90 | 4 ++-- lis/metforcing/plumber2/finalize_plumber2.F90 | 4 ++-- lis/metforcing/plumber2/get_plumber2.F90 | 4 ++-- lis/metforcing/plumber2/plumber2_forcingMod.F90 | 4 ++-- lis/metforcing/plumber2/read_plumber2.F90 | 4 ++-- lis/metforcing/plumber2/readcrd_plumber2.F90 | 4 ++-- lis/metforcing/plumber2/reset_plumber2.F90 | 4 ++-- lis/metforcing/plumber2/timeinterp_plumber2.F90 | 4 ++-- lis/metforcing/pptEnsFcst/0Intro_genEnsFcst.txt | 4 ++-- lis/metforcing/pptEnsFcst/finalize_pptEnsFcst.F90 | 4 ++-- lis/metforcing/pptEnsFcst/get_pptEnsFcst.F90 | 4 ++-- lis/metforcing/pptEnsFcst/get_pptEnsFcst_filename.F90 | 4 ++-- lis/metforcing/pptEnsFcst/pptEnsFcst_SpatialInterpMod.F90 | 4 ++-- lis/metforcing/pptEnsFcst/pptEnsFcst_VariablesMod.F90 | 4 ++-- lis/metforcing/pptEnsFcst/pptEnsFcst_forcingMod.F90 | 4 ++-- lis/metforcing/pptEnsFcst/readcrd_pptEnsFcst.F90 | 4 ++-- lis/metforcing/pptEnsFcst/reset_pptEnsFcst.F90 | 4 ++-- lis/metforcing/pptEnsFcst/timeinterp_pptEnsFcst.F90 | 4 ++-- lis/metforcing/princeton/0Intro_princeton.txt | 4 ++-- lis/metforcing/princeton/finalize_princeton.F90 | 4 ++-- lis/metforcing/princeton/get_princeton.F90 | 4 ++-- lis/metforcing/princeton/princeton_forcingMod.F90 | 4 ++-- lis/metforcing/princeton/read_princeton.F90 | 4 ++-- lis/metforcing/princeton/read_princeton_elev.F90 | 4 ++-- lis/metforcing/princeton/readcrd_princeton.F90 | 4 ++-- lis/metforcing/princeton/reset_princeton.F90 | 4 ++-- lis/metforcing/princeton/timeinterp_princeton.F90 | 4 ++-- lis/metforcing/scan/0Intro_scan.txt | 4 ++-- lis/metforcing/scan/finalize_scan.F90 | 4 ++-- lis/metforcing/scan/get_scan.F90 | 4 ++-- lis/metforcing/scan/read_scan.F90 | 4 ++-- lis/metforcing/scan/readcrd_scan.F90 | 4 ++-- lis/metforcing/scan/scan_forcingMod.F90 | 4 ++-- lis/metforcing/scan/timeinterp_scan.F90 | 4 ++-- lis/metforcing/snotel/finalize_snotel.F90 | 4 ++-- lis/metforcing/snotel/get_snotel.F90 | 4 ++-- lis/metforcing/snotel/read_snotel.F90 | 4 ++-- lis/metforcing/snotel/readcrd_snotel.F90 | 4 ++-- lis/metforcing/snotel/snotel_forcingMod.F90 | 4 ++-- lis/metforcing/snotel/timeinterp_snotel.F90 | 4 ++-- lis/metforcing/stg2/0Intro_stage2.txt | 4 ++-- lis/metforcing/stg2/finalize_stg2.F90 | 4 ++-- lis/metforcing/stg2/get_stg2.F90 | 4 ++-- lis/metforcing/stg2/interp_stg2.F90 | 4 ++-- lis/metforcing/stg2/read_stg2.F90 | 4 ++-- lis/metforcing/stg2/readcrd_stg2.F90 | 4 ++-- lis/metforcing/stg2/stg2_forcingMod.F90 | 4 ++-- lis/metforcing/stg2/stg2file.F90 | 4 ++-- lis/metforcing/stg2/timeinterp_stg2.F90 | 4 ++-- lis/metforcing/stg4/0Intro_stage4.txt | 4 ++-- lis/metforcing/stg4/finalize_stg4.F90 | 4 ++-- lis/metforcing/stg4/get_stg4.F90 | 4 ++-- lis/metforcing/stg4/interp_stg4.F90 | 4 ++-- lis/metforcing/stg4/read_stg4.F90 | 4 ++-- lis/metforcing/stg4/readcrd_stg4.F90 | 4 ++-- lis/metforcing/stg4/reset_stg4.F90 | 4 ++-- lis/metforcing/stg4/stg4_forcingMod.F90 | 4 ++-- lis/metforcing/stg4/stg4file.F90 | 4 ++-- lis/metforcing/stg4/timeinterp_stg4.F90 | 4 ++-- lis/metforcing/templateMetForc/0Intro_template.txt | 4 ++-- .../templateMetForc/finalize_metForcTemplate.F90 | 4 ++-- lis/metforcing/templateMetForc/get_metForcTemplate.F90 | 4 ++-- .../templateMetForc/metForcTemplate_forcingMod.F90 | 4 ++-- lis/metforcing/templateMetForc/reset_metForcTemplate.F90 | 4 ++-- .../templateMetForc/timeinterp_metForctemplate.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_bakfac.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_bndslc.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_calc_albedo.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_calcrh.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_calcrh_dpt.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_calest.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_cdfs2_est.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_cliest.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_cmorph.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_coszen.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fgfill.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fillgaps.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fldbld.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_forcingMod.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_geoest.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_getcli.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_getcmorph.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_getpcpobs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_getpwe.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_getsfc.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_interp_cmorph.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_julhr_date10.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_loadcloud.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_longwv.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_make03.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_makest.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_makpwe.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_parse12.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_parse6.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_pcp_barnes.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_pcpobs_search.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_phsrel12.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_phsrel6.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_processobs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_read_pcpclimodata.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_readmask.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_readpcpcntm.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_readterrain.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_sfcalc.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_sfcalc_barnes.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_sfcval.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_smiest.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_solar.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_storeobs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_storeobs_offhour.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_svp.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_tr_coeffs.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_trcalc.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_trnref.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_trpoly.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_typcnv.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_valid.F90 | 4 ++-- lis/metforcing/usaf/AGRMET_w.F90 | 4 ++-- lis/metforcing/usaf/EMK_precipMod.F90.qc_attempt | 4 ++-- lis/metforcing/usaf/USAF_ImergHHMod.F90 | 4 ++-- lis/metforcing/usaf/USAF_OBAMod.F90 | 4 ++-- lis/metforcing/usaf/USAF_WWMCA_grib1Mod.F90 | 4 ++-- lis/metforcing/usaf/USAF_bratsethMod.F90 | 4 ++-- lis/metforcing/usaf/USAF_sfcval.F90 | 4 ++-- lis/metforcing/usaf/compute_cod_based_clouds.F90 | 4 ++-- lis/metforcing/usaf/compute_type_based_clouds.F90 | 4 ++-- lis/metforcing/usaf/finalize_agrmet.F90 | 4 ++-- lis/metforcing/usaf/get_agrmet.F90 | 4 ++-- lis/metforcing/usaf/interp_agrmetvar.F90 | 4 ++-- lis/metforcing/usaf/process_cloud_layers.F90 | 4 ++-- lis/metforcing/usaf/read_cod.F90 | 4 ++-- lis/metforcing/usaf/readagrmetforcing.F90 | 4 ++-- lis/metforcing/usaf/readagrmetforcinganalysis.F90 | 4 ++-- lis/metforcing/usaf/readagrmetpcpforcing.F90 | 4 ++-- lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 | 4 ++-- lis/metforcing/usaf/readcrd_agrmet.F90 | 4 ++-- lis/metforcing/usaf/reset_agrmet.F90 | 4 ++-- lis/metforcing/usaf/retrieve_agrmetvar.F90 | 4 ++-- lis/metforcing/usaf/timeinterp_agrmet.F90 | 4 ++-- lis/metforcing/vicforcing.4.1.2/0Intro_vicforcing.txt | 4 ++-- lis/metforcing/vicforcing.4.1.2/getvicforcing.F90 | 4 ++-- lis/metforcing/vicforcing.4.1.2/getvicforcing.F90.tinterp | 4 ++-- lis/metforcing/vicforcing.4.1.2/readviccrd.F90 | 4 ++-- .../vicforcing.4.1.2/time_interp_vicforcing.F90 | 4 ++-- .../vicforcing.4.1.2/time_interp_vicforcing.F90.tinterp | 4 ++-- .../vicforcing.4.1.2/vic412_read_gridded_forcing_data.F90 | 4 ++-- lis/metforcing/vicforcing.4.1.2/vic_forcingMod.F90 | 4 ++-- lis/metforcing/vicforcing.4.1.2/vicforcing_finalize.F90 | 4 ++-- lis/metforcing/vicforcing.4.1.2/vicforcing_reset.F90 | 4 ++-- lis/metforcing/vicforcing/0Intro_vicforcing.txt | 4 ++-- lis/metforcing/vicforcing/getvicforcing.F90 | 4 ++-- lis/metforcing/vicforcing/getvicforcing.F90.tinterp | 4 ++-- lis/metforcing/vicforcing/readviccrd.F90 | 4 ++-- lis/metforcing/vicforcing/time_interp_vicforcing.F90 | 4 ++-- .../vicforcing/time_interp_vicforcing.F90.tinterp | 4 ++-- .../vicforcing/vic411_read_gridded_forcing_data.F90 | 4 ++-- lis/metforcing/vicforcing/vic_forcingMod.F90 | 4 ++-- lis/metforcing/vicforcing/vicforcing_finalize.F90 | 4 ++-- lis/metforcing/vicforcing/vicforcing_reset.F90 | 4 ++-- lis/offline/lisdrv.F90 | 4 ++-- lis/optUE/0Intro_paramest.txt | 4 ++-- lis/optUE/algorithm/DEMC/DEMCAlgorithm.F90 | 4 ++-- lis/optUE/algorithm/DEMC/DEMC_varctl.F90 | 4 ++-- lis/optUE/algorithm/DEMCz/0Intro_demc.txt | 4 ++-- lis/optUE/algorithm/DEMCz/DEMCzAlgorithm.F90 | 4 ++-- lis/optUE/algorithm/DEMCz/DEMCz_varctl.F90 | 4 ++-- lis/optUE/algorithm/ES/ES_varctl.F90 | 4 ++-- lis/optUE/algorithm/ES/EnumeratedSearch.F90 | 4 ++-- lis/optUE/algorithm/GA/0Intro_ga.txt | 4 ++-- lis/optUE/algorithm/GA/GA_varctl.F90 | 4 ++-- lis/optUE/algorithm/GA/GeneticAlgorithm.F90 | 4 ++-- lis/optUE/algorithm/LM/LM_varctl.F90 | 4 ++-- lis/optUE/algorithm/LM/LevenbergMarquardt.F90 | 4 ++-- lis/optUE/algorithm/MCSIM/MCSIMAlgorithm.F90 | 4 ++-- lis/optUE/algorithm/MCSIM/MCSIM_varctl.F90 | 4 ++-- lis/optUE/algorithm/RWMCMC/RWMCMCAlgorithm.F90 | 4 ++-- lis/optUE/algorithm/RWMCMC/RWMCMC_varctl.F90 | 4 ++-- lis/optUE/algorithm/SCEUA/SCEUA_varctl.F90 | 4 ++-- lis/optUE/algorithm/SCEUA/ShuffledComplexEvolution.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LL/LLobjFunc_Mod.F90 | 4 ++-- .../type/paramestim/objfunc/LL/computeLLestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LL/resetLLestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LL/updateLLestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LM/LMobjFunc_Mod.F90 | 4 ++-- .../type/paramestim/objfunc/LM/computeLMestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LM/resetLMestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LM/updateLMestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LS/LSobjFunc_Mod.F90 | 4 ++-- .../type/paramestim/objfunc/LS/computeLSestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LS/resetLSestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/LS/updateLSestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/P/PobjFunc_Mod.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/P/computePestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/P/resetPestimate.F90 | 4 ++-- lis/optUE/type/paramestim/objfunc/P/updatePestimate.F90 | 4 ++-- .../type/paramestim/obs/AMSRE_SR/AMSRE_SR_em_obsMod.F90 | 4 ++-- .../type/paramestim/obs/AMSRE_SR/read_AMSRE_SRdata.F90 | 4 ++-- .../paramestim/obs/AMSRE_SR/reset_AMSRE_SRObsdata.F90 | 4 ++-- .../obs/AMSRE_SR/write_AMSRE_SR_em_obs_data.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARM/ARMdata_module.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARM/read_ARMdata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARM/reset_ARMdata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARM/write_ARMdata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARSsm/ARSsm_obsMod.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARSsm/read_ARSsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARSsm/reset_ARSsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ARSsm/write_ARSsmobs.F90 | 4 ++-- .../type/paramestim/obs/Ameriflux/AmerifluxobsMod.F90 | 4 ++-- .../type/paramestim/obs/Ameriflux/read_AmerifluxObs.F90 | 4 ++-- .../paramestim/obs/Ameriflux/read_ameriflux_station.F90 | 4 ++-- .../type/paramestim/obs/Ameriflux/write_AmerifluxObs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/CNRS/CNRS_em_obsMod.F90 | 4 ++-- lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata_MPDI.F90 | 4 ++-- .../type/paramestim/obs/CNRS/reset_CNRS_em_obs_data.F90 | 4 ++-- .../type/paramestim/obs/CNRS/write_CNRS_em_obs_data.F90 | 4 ++-- lis/optUE/type/paramestim/obs/EmptyObs/Empty_obsMod.F90 | 4 ++-- .../type/paramestim/obs/FLUXNET/FLUXNETdata_module.F90 | 4 ++-- .../type/paramestim/obs/FLUXNET/read_FLUXNETdata.F90 | 4 ++-- .../type/paramestim/obs/FLUXNET/reset_FLUXNETdata.F90 | 4 ++-- .../type/paramestim/obs/FLUXNET/write_FLUXNETdata.F90 | 4 ++-- .../paramestim/obs/Global_LS_data/GlobalLSDataMod.F90 | 4 ++-- .../obs/Global_LS_data/read_GlobalLSObsdata.F90 | 4 ++-- .../obs/Global_LS_data/reset_GlobalLSObsData.F90 | 4 ++-- .../obs/Global_LS_data/write_GlobalLSObsdata.F90 | 4 ++-- .../paramestim/obs/ISCCP_Tskin/ISCCP_Tskinobs_module.F90 | 4 ++-- .../paramestim/obs/ISCCP_Tskin/read_ISCCP_Tskindata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ISMNsm/ISMNsm_obsMod.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ISMNsm/read_ISMNsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ISMNsm/reset_ISMNsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/ISMNsm/write_ISMNsmobs.F90 | 4 ++-- .../paramestim/obs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 | 4 ++-- .../paramestim/obs/LPRM_AMSREsm/read_LPRM_AMSREsmdata.F90 | 4 ++-- .../obs/LPRM_AMSREsm/reset_LPRM_AMSREsmObsdata.F90 | 4 ++-- .../obs/LPRM_AMSREsm/write_LPRM_AMSREsm_obs_data.F90 | 4 ++-- .../type/paramestim/obs/Macon_LS_data/MaconLSDataMod.F90 | 4 ++-- .../paramestim/obs/Macon_LS_data/read_MaconLSObsdata.F90 | 4 ++-- .../paramestim/obs/Macon_LS_data/write_MaconLSObsdata.F90 | 4 ++-- lis/optUE/type/paramestim/obs/SMAPsm/SMAPsm_obsMod.F90 | 4 ++-- lis/optUE/type/paramestim/obs/SMAPsm/read_SMAPsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/SMAPsm/reset_SMAPsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/SMAPsm/write_SMAPsmobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/UAsnow/UAsnow_obsMod.F90 | 4 ++-- lis/optUE/type/paramestim/obs/UAsnow/read_UAsnowobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/UAsnow/reset_UAsnowobs.F90 | 4 ++-- lis/optUE/type/paramestim/obs/UAsnow/write_UAsnowobs.F90 | 4 ++-- .../type/paramestim/obs/USDA_ARSsm/USDA_ARSsm_obsMod.F90 | 4 ++-- .../paramestim/obs/USDA_ARSsm/read_USDA_ARSsmdata.F90 | 4 ++-- .../obs/USDA_ARSsm/reset_USDA_ARSsm_obs_data.F90 | 4 ++-- .../obs/USDA_ARSsm/write_USDA_ARSsm_obs_data.F90 | 4 ++-- .../type/paramestim/obs/pesynsm1/pesynsm1data_module.F90 | 4 ++-- .../type/paramestim/obs/pesynsm1/read_pesynsm1data.F90 | 4 ++-- .../type/paramestim/obs/template/read_templateObs.F90 | 4 ++-- .../type/paramestim/obs/template/reset_templateObs.F90 | 4 ++-- .../type/paramestim/obs/template/templateObs_module.F90 | 4 ++-- .../type/paramestim/obs/template/write_templateObs.F90 | 4 ++-- .../type/paramestim/obs/wgPBMRsm/read_wgPBMRsmdata.F90 | 4 ++-- .../type/paramestim/obs/wgPBMRsm/reset_wgPBMRsmdata.F90 | 4 ++-- .../type/paramestim/obs/wgPBMRsm/wgPBMRsmobs_module.F90 | 4 ++-- .../type/paramestim/obs/wgPBMRsm/write_wgPBMRsmdata.F90 | 4 ++-- lis/params/0Intro_params.txt | 4 ++-- lis/params/albedo/ALMIPII/read_ALMIPIIalbedo.F90 | 4 ++-- lis/params/albedo/ALMIPII/setup_ALMIPIIalbedo.F90 | 4 ++-- lis/params/emissivity/ALMIPII/read_ALMIPIIemiss.F90 | 4 ++-- lis/params/emissivity/ALMIPII/setup_ALMIPIIemiss.F90 | 4 ++-- lis/params/gfrac/0Intro_greenness.txt | 4 ++-- lis/params/gfrac/ALMIPII/read_ALMIPIIgfrac.F90 | 4 ++-- lis/params/gfrac/ALMIPII/setup_ALMIPIIgfrac.F90 | 4 ++-- lis/params/gfrac/NESDISWeekly/read_NESDISgfrac.F90 | 4 ++-- lis/params/gfrac/NESDISWeekly/setup_NESDISgfrac.F90 | 4 ++-- lis/params/gfrac/SPORTDaily/SPORTgfracMod.F90 | 4 ++-- lis/params/gfrac/SPORTDaily/cppfunmodis.h | 4 ++-- lis/params/gfrac/SPORTDaily/gvf_binary_reader_modis.h | 4 ++-- lis/params/gfrac/SPORTDaily/read_SPORTgfrac.F90 | 4 ++-- lis/params/gfrac/SPORTDaily/read_gvf_binary_modis.cc | 4 ++-- lis/params/gfrac/SPORTDaily/setup_SPORTgfrac.F90 | 4 ++-- lis/params/gfrac/VIIRSDaily/VIIRSgfracMod.F90 | 4 ++-- lis/params/gfrac/VIIRSDaily/cppfunviirs.h | 4 ++-- lis/params/gfrac/VIIRSDaily/gvf_binary_reader_viirs.h | 4 ++-- lis/params/gfrac/VIIRSDaily/read_VIIRSgfrac.F90 | 4 ++-- lis/params/gfrac/VIIRSDaily/read_gvf_binary_viirs.cc | 4 ++-- lis/params/gfrac/VIIRSDaily/setup_VIIRSgfrac.F90 | 4 ++-- lis/params/lai/0Intro_lai.txt | 4 ++-- lis/params/lai/ALMIPII/read_ALMIPIIlai.F90 | 4 ++-- lis/params/lai/ALMIPII/setup_ALMIPIIlai.F90 | 4 ++-- lis/params/lai/MODIS/read_MODISlai.F90 | 4 ++-- lis/params/lai/MODIS/read_MODISsai.F90 | 4 ++-- lis/params/lai/MODIS/setup_MODISlai.F90 | 4 ++-- lis/params/lai/MODIS_RT/read_MODIS_RT_lai.F90 | 4 ++-- lis/params/lai/MODIS_RT/read_MODIS_RT_sai.F90 | 4 ++-- lis/params/lai/MODIS_RT/setup_MODIS_RT_lai.F90 | 4 ++-- lis/params/roughness/ALMIPII/read_ALMIPIIroughness.F90 | 4 ++-- lis/params/roughness/ALMIPII/setup_ALMIPIIroughness.F90 | 4 ++-- lis/plugins/0Intro_plugins.txt | 4 ++-- lis/plugins/LIS_DAobs_pluginMod.F90 | 4 ++-- lis/plugins/LIS_ObjFunc_pluginMod.F90 | 4 ++-- lis/plugins/LIS_PEobs_pluginMod.F90 | 4 ++-- lis/plugins/LIS_RTM_pluginMod.F90 | 4 ++-- lis/plugins/LIS_RTMoptue_pluginMod.F90 | 4 ++-- lis/plugins/LIS_biasEstimation_pluginMod.F90 | 4 ++-- lis/plugins/LIS_dataassim_pluginMod.F90 | 4 ++-- lis/plugins/LIS_forecastAlg_pluginMod.F90 | 4 ++-- lis/plugins/LIS_glaciermodel_pluginMod.F90 | 4 ++-- lis/plugins/LIS_glacierrouting_pluginMod.F90 | 4 ++-- lis/plugins/LIS_irrigationmodel_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lakemodel_pluginMod.F90 | 4 ++-- lis/plugins/LIS_landslidemodel_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsm_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmcpl_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmda_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmirrigation_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmoptue_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmrouting_pluginMod.F90 | 4 ++-- lis/plugins/LIS_lsmrtm_pluginMod.F90 | 4 ++-- lis/plugins/LIS_metforcing_pluginMod.F90 | 4 ++-- lis/plugins/LIS_openwatermodel_pluginMod.F90 | 4 ++-- lis/plugins/LIS_optUEAlgorithm_pluginMod.F90 | 4 ++-- lis/plugins/LIS_param_pluginMod.F90 | 4 ++-- lis/plugins/LIS_perturb_pluginMod.F90 | 4 ++-- lis/plugins/LIS_pluginIndices.F90 | 4 ++-- lis/plugins/LIS_routing_pluginMod.F90 | 4 ++-- lis/plugins/LIS_routingda_pluginMod.F90 | 4 ++-- lis/plugins/LIS_runmode_pluginMod.F90 | 4 ++-- lis/plugins/LIS_runoffdata_pluginMod.F90 | 4 ++-- lis/plugins/LIS_sublsm_pluginMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_evapMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_initMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_model.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_modelMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_model_core.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_resopMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routingMod.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routing_output.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routing_readrst.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routing_reset.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_routing_writerst.F90 | 4 ++-- lis/routing/HYMAP2_router/HYMAP2_urbanMod.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_daWL_Mod.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_descale_WL.F90 | 4 ++-- .../HYMAP2_router/da_WL/HYMAP2_getStateSpaceSize.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_getWL.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_getWLpred.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_qcWL.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_qc_WLobs.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_scale_WL.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_setPertStates.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_setWL.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_updateWL.F90 | 4 ++-- lis/routing/HYMAP2_router/da_WL/HYMAP2_write_WL.F90 | 4 ++-- .../runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 | 4 ++-- .../runoffdata/ERAILanddata/readERAILandrunoffdata.F90 | 4 ++-- .../runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 | 4 ++-- .../runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 | 4 ++-- .../runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 | 4 ++-- .../runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 | 4 ++-- .../runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 | 4 ++-- .../runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 | 4 ++-- .../runoffdata/LISoutput/LISrunoffdataMod.F90 | 4 ++-- .../runoffdata/LISoutput/readLISrunoffdata.F90 | 4 ++-- .../runoffdata/MERRA2data/MERRA2runoffdataMod.F90 | 4 ++-- .../runoffdata/MERRA2data/readMERRA2runoffdata.F90 | 4 ++-- .../runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 | 4 ++-- .../runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_initMod.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_modelMod.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_routingMod.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_routing_output.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_routing_readrst.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_routing_run.F90 | 4 ++-- lis/routing/HYMAP_router/HYMAP_routing_writerst.F90 | 4 ++-- lis/routing/HYMAP_router/model.F90 | 4 ++-- .../runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 | 4 ++-- .../runoffdata/ERAILanddata/readERAILandrunoffdata.F90 | 4 ++-- .../runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 | 4 ++-- .../runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 | 4 ++-- .../runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 | 4 ++-- .../runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 | 4 ++-- .../runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 | 4 ++-- .../runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 | 4 ++-- .../runoffdata/LISoutput/LISrunoffdataMod.F90 | 4 ++-- .../runoffdata/LISoutput/readLISrunoffdata.F90 | 4 ++-- .../runoffdata/MERRA2data/MERRA2runoffdataMod.F90 | 4 ++-- .../runoffdata/MERRA2data/readMERRA2runoffdata.F90 | 4 ++-- .../runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 | 4 ++-- .../runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 | 4 ++-- lis/routing/NLDAS_router/NLDAS_routingMod.F90 | 4 ++-- lis/routing/NLDAS_router/NLDAS_routing_output.F90 | 4 ++-- lis/routing/NLDAS_router/NLDAS_routing_readrst.F90 | 4 ++-- lis/routing/NLDAS_router/NLDAS_routing_run.F90 | 4 ++-- lis/routing/NLDAS_router/NLDAS_routing_writerst.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_check_domain_size.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_model_main.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_routingMod.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_routing_output.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_routing_readrst.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_routing_run.F90 | 4 ++-- lis/routing/RAPID_router/RAPID_routing_writerst.F90 | 4 ++-- lis/rtms/CRTM/CRTM_handlerMod.F90 | 4 ++-- lis/rtms/CRTM/readCRTMcrd.F90 | 4 ++-- lis/rtms/CRTM2/CRTM2_handlerMod.F90 | 4 ++-- lis/rtms/CRTM2/readCRTM2crd.F90 | 4 ++-- lis/rtms/CRTM2EM/CRTM2_EMMod.F90 | 4 ++-- lis/rtms/CRTM2EM/pe/CRTM2EM_peMod.F90 | 4 ++-- lis/rtms/CRTM2EM/pe/CRTM2EM_set_pedecvars.F90 | 4 ++-- .../pe/obspred/AMSRE_SR/CRTM2EM_getpeobspred_AMSRE_SR.F90 | 4 ++-- .../pe/obspred/AMSRE_SR/CRTM2EM_setupobspred_AMSRE_SR.F90 | 4 ++-- .../CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS.F90 | 4 ++-- .../pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS_MPDI.F90 | 4 ++-- .../CRTM2EM/pe/obspred/CNRS/CRTM2EM_setupobspred_CNRS.F90 | 4 ++-- lis/rtms/CRTM2EM/readCRTM2EMcrd.F90 | 4 ++-- lis/rtms/LIS-CMEM3/CMEM3_Mod.F90 | 4 ++-- lis/rtms/LIS-CMEM3/pe/CMEM3_param_reset.F90 | 4 ++-- lis/rtms/LIS-CMEM3/pe/CMEM3_peMod.F90 | 4 ++-- lis/rtms/LIS-CMEM3/pe/CMEM3_set_pedecvars.F90 | 4 ++-- .../pe/obspred/AMSRE_SR/CMEM3_getpeobspred_AMSRE_SR.F90 | 4 ++-- .../pe/obspred/AMSRE_SR/CMEM3_setupobspred_AMSRE_SR.F90 | 4 ++-- lis/rtms/LIS-CMEM3/readCMEM3crd.F90 | 4 ++-- lis/rtms/TauOmegaRTM/TauOmegaRTM_Mod.F90 | 4 ++-- lis/runmodes/0Intro_runmodes.txt | 4 ++-- lis/runmodes/RTMforward/RTMforward_runMod.F90 | 4 ++-- lis/runmodes/agrmetmode/agrmet_runMod.F90 | 4 ++-- lis/runmodes/forecast/forecast_runMod.F90 | 4 ++-- lis/runmodes/gce_cpl_mode/lis_gce_init.F90 | 4 ++-- lis/runmodes/gce_cpl_mode/lis_gce_run.F90 | 4 ++-- lis/runmodes/gce_cpl_mode/lisgceGridCompMod.F90 | 4 ++-- lis/runmodes/gce_cpl_mode/lisgceexport_module.F90 | 4 ++-- lis/runmodes/gce_cpl_mode/lisgceimport_module.F90 | 4 ++-- lis/runmodes/landslide_optUE/landslideOptUE_runMod.F90 | 4 ++-- lis/runmodes/nuopc_cpl_mode/LIS_ESMF_Extensions.F90 | 4 ++-- lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Cap.F90 | 4 ++-- lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_DataCopy.F90 | 4 ++-- lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Gluecode.F90 | 4 ++-- lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Macros.h | 4 ++-- lis/runmodes/paramEstimation/0Intro_optUE.txt | 4 ++-- lis/runmodes/paramEstimation/paramEstim_runMod.F90 | 4 ++-- lis/runmodes/retrospective/0Intro_retrospective.txt | 4 ++-- lis/runmodes/retrospective/retrospective_runMod.F90 | 4 ++-- lis/runmodes/smootherDA/smootherDA_runMod.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/LISWRFGridCompMod.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/LISWRFexport_module.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/LISWRFimport_module.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/liswrffinalize_coupled.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/liswrfinit_coupled.F90 | 4 ++-- lis/runmodes/wrf_cpl_mode/liswrfrun_coupled.F90 | 4 ++-- .../noahmp.3.9.1.1/kwm_date_utilities_noahgl3911.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_Mod.F90 | 4 ++-- .../noahmp.3.9.1.1/noahmpglacier3911_coldstart.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_dynsetup.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_f2t.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_finalize.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_main.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_module.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_readcrd.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_readrst.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_setup.F90 | 4 ++-- .../glacier/noahmp.3.9.1.1/noahmpglacier3911_writerst.F90 | 4 ++-- .../routing/noahmpglacier3911_getrunoffs_hymap2.F90 | 4 ++-- .../routing/noahmpglacier3911_getrunoffs_mm.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_Mod.F90 | 4 ++-- .../glacier/template/templateGL_dynsetup.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_f2t.F90 | 4 ++-- .../glacier/template/templateGL_finalize.F90 | 4 ++-- .../glacier/template/templateGL_getrunoffs_mm.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_main.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_readcrd.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_readrst.F90 | 4 ++-- lis/surfacemodels/glacier/template/templateGL_setup.F90 | 4 ++-- .../glacier/template/templateGL_writerst.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_Mod.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_coldstart.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_dynsetup.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_f2t.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_finalize.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_main.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_module.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_readcrd.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_readrst.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_setup.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/FLake1_writerst.F90 | 4 ++-- lis/surfacemodels/lake/FLake.1.0/lis7_flake_2013.f90 | 4 ++-- lis/surfacemodels/land/0Intro_lsms.txt | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_coldstart.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_f2t.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_finalize.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_main.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_module.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_readcrd.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_readrst.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_setup.F90 | 4 ++-- lis/surfacemodels/land/awral.6.0.0/AWRAL600_writerst.F90 | 4 ++-- lis/surfacemodels/land/cable/0Intro_cable.txt | 4 ++-- lis/surfacemodels/land/cable/cable_coldstart.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_driver.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_f2t.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_finalize.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_listime.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_module.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_readcrd.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_readrst.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_setsoilparms.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_setup.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/cable/cable_writerst.F90 | 4 ++-- .../land/cable/cpl_wrf_noesmf/cable_setwrfexport.F90 | 4 ++-- .../land/cable/cpl_wrf_noesmf/cable_wrf_f2t.F90 | 4 ++-- lis/surfacemodels/land/clm2/0Intro_clm2.txt | 4 ++-- .../land/clm2/biogeochem/Biogeochemistry.F90 | 4 ++-- .../land/clm2/biogeochem/DustEmissionMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeochem/VOCEmission.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/BalanceCheck.F90 | 4 ++-- .../land/clm2/biogeophys/BareGroundFluxes.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Biogeophysics1.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Biogeophysics2.F90 | 4 ++-- .../land/clm2/biogeophys/Biogeophysics_Lake.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/CanopyFluxes.F90 | 4 ++-- .../land/clm2/biogeophys/CombineSnowLayers.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Combo.F90 | 4 ++-- .../land/clm2/biogeophys/DivideSnowLayers.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Drainage.F90 | 4 ++-- .../land/clm2/biogeophys/FrictionVelocity.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Hydrology1.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Hydrology2.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Hydrology_Lake.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Infiltration.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/LatentHCond.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/MoninObukIni.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/PhaseChange.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/QSatclm.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SensibleHCond.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SnowAge.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SnowAlbedo.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SnowCompaction.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SnowWater.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SoilAlbedo.F90 | 4 ++-- .../land/clm2/biogeophys/SoilTemperature.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SoilThermProp.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SoilWater.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/StabilityFunc.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Stomata.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SurfaceAlbedo.F90 | 4 ++-- .../land/clm2/biogeophys/SurfaceRadiation.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/SurfaceRunoff.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/Tridiagonal.F90 | 4 ++-- lis/surfacemodels/land/clm2/biogeophys/TwoStream.F90 | 4 ++-- .../land/clm2/biogeophys/WetIceHydrology.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/calendr.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/datetime.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/fileutils.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/gauaw_mod.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/ioFileMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/linebuf_stdout.c | 4 ++-- lis/surfacemodels/land/clm2/camclm_share/wrap_nf.F90 | 4 ++-- lis/surfacemodels/land/clm2/canhtset.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_finalize.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_lairead.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_main.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_readrestart.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_setup.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2_writerestart.F90 | 4 ++-- lis/surfacemodels/land/clm2/clm2type.F90 | 4 ++-- .../land/clm2/cpl_wrf_esmf/clm2_setwrfesmfexport.F90 | 4 ++-- .../land/clm2/cpl_wrf_esmf/clm2_wrf_esmff2t.F90 | 4 ++-- .../land/clm2/cpl_wrf_noesmf/clm2_setwrfexport.F90 | 4 ++-- .../land/clm2/cpl_wrf_noesmf/clm2_wrf_f2t.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_const_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_file_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_kind_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_msg_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_orb_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_sys_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_timer_mod.F90 | 4 ++-- .../land/clm2/csm_share/clm2_shr_vmath_fwrap.c | 4 ++-- .../land/clm2/csm_share/clm2_shr_vmath_mod.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_descale_lst.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_getlst.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_getsynlstpred.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_qclst.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_scale_lst.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_lst/clm2_setlst.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_descale_snow.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_getsnowvars.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_getsnwdpred.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_getswepred.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_map_sca.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_qc_snowobs.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_qcsnow.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_scale_snow.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_snow/clm2_setsnowvars.F90 | 4 ++-- .../land/clm2/da_snow/clm2_transform_obssca.F90 | 4 ++-- .../land/clm2/da_snow/clm2_updatesnowvars.F90 | 4 ++-- .../land/clm2/da_soilm/clm2_descale_soilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_getsoilm.F90 | 4 ++-- .../land/clm2/da_soilm/clm2_getsynsmpred.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_qcsoilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_scale_soilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_setsoilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_updatesoilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/da_soilm/clm2_write_soilm.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Allocation.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/EcosystemDyn.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Fire.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/FireSeason.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Kill.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/LitterSOM.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Mortality.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Phenology.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Reproduction.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/Turnover.F90 | 4 ++-- lis/surfacemodels/land/clm2/ecosysdyn/accumDGVM.F90 | 4 ++-- lis/surfacemodels/land/clm2/iniTimeConst.F90 | 4 ++-- lis/surfacemodels/land/clm2/iniTimeVar.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/atm_lndMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_accumulMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_areaMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_atmdrvMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_varcon.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_varpar.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/clm2_varsur.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/lnd_atmMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/pft_varcon.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/snowdp2lev.F90 | 4 ++-- lis/surfacemodels/land/clm2/main/surfFileMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkglacier.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkgridMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mklai.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mklanwat.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkmxovr.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkpft.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkrank.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mksoicol.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mksoitex.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mksrfdatMod.F90 | 4 ++-- lis/surfacemodels/land/clm2/mksrfdata/mkurban.F90 | 4 ++-- lis/surfacemodels/land/clm2/readclm2crd.F90 | 4 ++-- lis/surfacemodels/land/clm2/riverroute/RtmMod.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferpack2d.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferpack3d.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferpack4d.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferunpack2d.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferunpack3d.F90 | 4 ++-- .../land/clm2/utils/pilgrim/bufferunpack4d.F90 | 4 ++-- lis/surfacemodels/land/clm2/utils/pilgrim/debug.h | 4 ++-- .../land/clm2/utils/pilgrim/debugutilitiesmodule.F90 | 4 ++-- .../land/clm2/utils/pilgrim/decompmodule.F90 | 4 ++-- lis/surfacemodels/land/clm2/utils/pilgrim/ghostmodule.F90 | 4 ++-- .../land/clm2/utils/pilgrim/parutilitiesmodule.F90 | 4 ++-- lis/surfacemodels/land/clm2/utils/pilgrim/pilgrim.h | 4 ++-- .../land/clm2/utils/pilgrim/puminterfaces.F90 | 4 ++-- .../land/clm2/utils/pilgrim/redistributemodule.F90 | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/f_wrappers.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/get_cpustamp.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/get_thread_num.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/gpt.h | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_error.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_initialize.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_pclstr.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_pr.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_reset.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_setoption.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_stamp.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_start.c | 4 ++-- lis/surfacemodels/land/clm2/utils/timing/t_stop.c | 4 ++-- lis/surfacemodels/land/clsm.f2.5/0Intro_clsmf25.txt | 4 ++-- .../land/clsm.f2.5/clsmf25_DragCoefficientsMod.F90 | 4 ++-- .../land/clsm.f2.5/clsmf25_MAPL_constants.F90 | 4 ++-- .../land/clsm.f2.5/clsmf25_compute_land_parameters.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_constants.F90 | 4 ++-- .../land/clsm.f2.5/clsmf25_diagn_routines.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_drv_types.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_esat_qsat.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_f2t.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_finalize.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_main.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_model.F90 | 4 ++-- .../land/clsm.f2.5/clsmf25_modis_alb_types.F90 | 4 ++-- .../land/clsm.f2.5/clsmf25_pmonth_stage4.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_readcrd.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_readrst.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_relayer_snow.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_reset.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_setup.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_sibalb_coeff.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_surfacelayer.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_turb.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_types.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/clsmf25_writerst.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_dasnow_Mod.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_descale_snow.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_getsnowvars.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_getsnwdpred.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_qc_snowobs.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_qcsnow.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_scale_snow.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_setsnowvars.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_snow_DAlog.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_updatesnowvars.F90 | 4 ++-- .../land/clsm.f2.5/da_snow/clsmf25_wrtswe.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_dasoilm_Mod.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_descale_soilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_getsmpred.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_getsoilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_qc_soilmobs.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_qcsoilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_scale_soilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_setsoilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_soilm_DAlog.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_updatesoilm.F90 | 4 ++-- .../land/clsm.f2.5/da_soilm/clsmf25_write_soilm.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_datws_Mod.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_descale_tws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_gettws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_gettwspred.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_qc_twsobs.F90 | 4 ++-- lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qctws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_scale_tws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_settws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_tws_DAlogMod.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_update_tws.F90 | 4 ++-- .../land/clsm.f2.5/da_tws/clsmf25_write_tws.F90 | 4 ++-- .../clsm.f2.5/irrigation/clsmf25_getirrigationstates.F90 | 4 ++-- .../land/clsm.f2.5/routing/clsmf25_getrunoffs.F90 | 4 ++-- .../land/clsm.f2.5/routing/clsmf25_getrunoffs_hymap2.F90 | 4 ++-- .../land/clsm.f2.5/routing/clsmf25_getrunoffs_mm.F90 | 4 ++-- .../land/clsm.f2.5/routing/clsmf25_getsws_hymap2.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/0Intro_geowrsi2.txt | 4 ++-- .../land/geowrsi.2/geowrsi2_arraymgmt_module.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_f2t.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_finalize.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_main.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_module.F90 | 4 ++-- .../land/geowrsi.2/geowrsi2_physics_module.F90 | 4 ++-- .../land/geowrsi.2/geowrsi2_readInputSettings.F90 | 4 ++-- .../land/geowrsi.2/geowrsi2_readSOS_Bilfile.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_readcrd.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_readrst.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_set_gcoords.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_setup.F90 | 4 ++-- .../land/geowrsi.2/geowrsi2_writeSOS_Bilfile.F90 | 4 ++-- lis/surfacemodels/land/geowrsi.2/geowrsi2_writerst.F90 | 4 ++-- lis/surfacemodels/land/hyssib/0Intro_hyssib.txt | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_coldstart.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_f2t.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_finalize.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_gfrac.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_main.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_mapvegc.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_module.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_readcrd.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_readrst.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_settbot.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_settopostd.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_setup.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_totinit.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssib_writerst.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssibalb_module.F90 | 4 ++-- lis/surfacemodels/land/hyssib/hyssibveg_module.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/couple_jules_to_lis.sh | 4 ++-- .../land/jules.5.0/da_snodep/jules50_dasnodep_Mod.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_descale_snodep.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_getsnodeppred.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_getsnodepvars.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_map_snodep.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_qc_snodepobs.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_qcsnodep.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_scale_snodep.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_setsnodepvars.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_snodep_update.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_transform_snodep.F90 | 4 ++-- .../land/jules.5.0/da_snodep/jules50_updatesnodep.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_dasoilm_Mod.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_descale_soilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_getLbandTbPred.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_getsmpred.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_getsoilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_qc_soilmobs.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_qcsoilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_scale_soilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_setsoilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_updatesoilm.F90 | 4 ++-- .../land/jules.5.0/da_soilm/jules50_write_soilm.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_dausafsi_Mod.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_descale_usafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_getusafsipred.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_getusafsivars.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_map_usafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_qc_usafsiobs.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_qcusafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_scale_usafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_setusafsivars.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_transform_usafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_updateusafsi.F90 | 4 ++-- .../land/jules.5.0/da_usafsi/jules50_usafsi_update.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_main.F90 | 4 ++-- .../land/jules.5.0/jules50_main.F90.original | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_module.F90 | 4 ++-- .../land/jules.5.0/jules50_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules50_writerst.F90 | 4 ++-- .../land/jules.5.0/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/jules_lis_exchange.f90 | 4 ++-- lis/surfacemodels/land/jules.5.0/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/ps_to_tile.F90 | 4 ++-- .../land/jules.5.0/routing/jules50_getrunoffs_hymap2.F90 | 6 ++++-- .../land/jules.5.0/routing/jules50_getrunoffs_mm.F90 | 4 ++-- .../land/jules.5.0/routing/jules50_getrunoffs_rapid.F90 | 4 ++-- .../land/jules.5.0/routing/jules50_getsws_hymap2.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.0/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.0/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/couple_jules_to_lis.sh | 4 ++-- lis/surfacemodels/land/jules.5.1/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_main.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_module.F90 | 4 ++-- .../land/jules.5.1/jules51_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules51_writerst.F90 | 4 ++-- .../land/jules.5.1/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/jules_lis_exchange.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/ps_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.1/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.1/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/couple_jules_to_lis.sh | 4 ++-- .../land/jules.5.2/da_soilm/jules52_dasoilm_Mod.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_descale_soilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_getLbandTbPred.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_getsmpred.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_getsoilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_qc_soilmobs.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_qcsoilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_scale_soilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_setsoilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_updatesoilm.F90 | 4 ++-- .../land/jules.5.2/da_soilm/jules52_write_soilm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_main.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_module.F90 | 4 ++-- .../land/jules.5.2/jules52_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules52_writerst.F90 | 4 ++-- .../land/jules.5.2/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/jules_lis_exchange.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/ps_to_tile.F90 | 4 ++-- .../land/jules.5.2/routing/jules52_getrunoffs_mm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.2/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.2/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/couple_jules_to_lis.sh | 4 ++-- .../land/jules.5.3/da_soilm/jules53_dasoilm_Mod.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_descale_soilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_getLbandTbPred.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_getsmpred.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_getsoilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_qc_soilmobs.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_qcsoilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_scale_soilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_setsoilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_updatesoilm.F90 | 4 ++-- .../land/jules.5.3/da_soilm/jules53_write_soilm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_main.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_module.F90 | 4 ++-- .../land/jules.5.3/jules53_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules53_writerst.F90 | 4 ++-- .../land/jules.5.3/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/jules_lis_exchange.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/ps_to_tile.F90 | 4 ++-- .../land/jules.5.3/routing/jules53_getrunoffs_mm.F90 | 4 ++-- .../land/jules.5.3/routing/jules53_getrunoffs_mm.F90.0 | 4 ++-- lis/surfacemodels/land/jules.5.3/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.3/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.3/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/couple_jules_to_lis.sh | 4 ++-- lis/surfacemodels/land/jules.5.4/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_main.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_module.F90 | 4 ++-- .../land/jules.5.4/jules54_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules54_writerst.F90 | 4 ++-- .../land/jules.5.4/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/jules_lis_exchange.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/ps_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.4/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.4/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/ancil_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/bvoc_vars_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/couple_jules_to_lis.sh | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_dasnodep_Mod.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_descale_snodep.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_getsnodeppred.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_getsnodepvars.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_map_snodep.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_qc_snodepobs.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_qcsnodep.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_scale_snodep.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_setsnodepvars.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_snodep_update.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_transform_snodep.F90 | 4 ++-- .../land/jules.5.x/da_snodep/jules5x_updatesnodep.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_dasoilm_Mod.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_descale_soilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_getLbandTbPred.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_getsmpred.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_getsoilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_qc_soilmobs.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_qcsoilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_scale_soilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_setsoilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_updatesoilm.F90 | 4 ++-- .../land/jules.5.x/da_soilm/jules5x_write_soilm.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_dausafsi_Mod.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_descale_usafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_getusafsipred.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_getusafsivars.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_map_usafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_qc_usafsiobs.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_qcusafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_scale_usafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_setusafsivars.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_transform_usafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_updateusafsi.F90 | 4 ++-- .../land/jules.5.x/da_usafsi/jules5x_usafsi_update.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/debug_latlon.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/fluxes_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_coldstart.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_f2t.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_finalize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_initialize.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_main.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_module.F90 | 4 ++-- .../land/jules.5.x/jules5x_read_multilevel_param.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_readcrd.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_readrst.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_setup.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules5x_writerst.F90 | 4 ++-- .../land/jules.5.x/jules_internal_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/jules_lis_exchange.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/l_to_rc.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/lis_control.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/prog_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/ps_to_tile.F90 | 4 ++-- .../land/jules.5.x/routing/jules5x_getrunoffs_mm.F90 | 4 ++-- .../land/jules.5.x/routing/jules5x_getrunoffs_mm.F90.0 | 4 ++-- .../land/jules.5.x/routing/jules5x_getrunoffs_rapid.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/sf_diag_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_ancil.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_bvoc_vars.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_fluxes.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_forcing.F90 | 4 ++-- .../land/jules.5.x/tile_to_jules_internal.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_prog.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_ps.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_sf_diag.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_top_pdm.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/tile_to_trifctl.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/top_pdm_to_tile.F90 | 4 ++-- lis/surfacemodels/land/jules.5.x/trifctl_to_tile.F90 | 4 ++-- lis/surfacemodels/land/mosaic/0Intro_mosaic.txt | 4 ++-- .../land/mosaic/da_soilm/mos_descale_soilm.F90 | 4 ++-- lis/surfacemodels/land/mosaic/da_soilm/mos_getsoilm.F90 | 4 ++-- .../land/mosaic/da_soilm/mos_getsynsmpred.F90 | 4 ++-- lis/surfacemodels/land/mosaic/da_soilm/mos_qcsoilm.F90 | 4 ++-- .../land/mosaic/da_soilm/mos_scale_soilm.F90 | 4 ++-- lis/surfacemodels/land/mosaic/da_soilm/mos_setsoilm.F90 | 4 ++-- .../land/mosaic/da_soilm/mos_updatesoilm.F90 | 4 ++-- .../land/mosaic/da_soilm/mos_write_soilm.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mapsib2umd.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_coldstart.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_f2t.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_finalize.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_main.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_module.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_readrestart.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_setup.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_tile.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mos_writerst.F90 | 4 ++-- lis/surfacemodels/land/mosaic/mosdynp.F90 | 4 ++-- lis/surfacemodels/land/mosaic/moslairead.F90.notemp | 4 ++-- lis/surfacemodels/land/mosaic/paramb.F90 | 4 ++-- lis/surfacemodels/land/mosaic/readmoscrd.F90 | 4 ++-- lis/surfacemodels/land/mosaic/setmosp.F90 | 4 ++-- lis/surfacemodels/land/mosaic/sfc_cmem3/mos_sfc2cmem3.F90 | 4 ++-- lis/surfacemodels/land/mosaic/sibalb_module.F90 | 4 ++-- lis/surfacemodels/land/mosaic/texture.F90 | 4 ++-- lis/surfacemodels/land/mosaic/umd_sibalb.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/0Intro_noah271.txt | 4 ++-- .../land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.old | 4 ++-- .../land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.wrf | 4 ++-- .../land/noah.2.7.1/cpl_gce/noah271_gce_f2t.F90 | 4 ++-- .../land/noah.2.7.1/cpl_gce/noah271_setgceexport.F90 | 4 ++-- .../noah.2.7.1/cpl_wrf_esmf/noah271_setwrfesmfexport.F90 | 4 ++-- .../land/noah.2.7.1/cpl_wrf_esmf/noah271_wrf_esmff2t.F90 | 4 ++-- .../noah.2.7.1/cpl_wrf_noesmf/noah271_setwrfexport.F90 | 4 ++-- .../land/noah.2.7.1/cpl_wrf_noesmf/noah271_wrf_f2t.F90 | 4 ++-- .../noah.2.7.1/da_multism/noah271_descale_multism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_getmultism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_getmultismpred.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_qcmultism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_scale_multism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_setmultism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_updatemultism.F90 | 4 ++-- .../land/noah.2.7.1/da_multism/noah271_write_multism.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_descale_scf.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_getscfpred.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_getscfvars.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_map_scf.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_qc_scf.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_scale_scf.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_setscfvars.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_transform_scf.F90 | 4 ++-- .../land/noah.2.7.1/da_scf/noah271_updatescfvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_dasnow_Mod.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_getsnodepvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_map_snodep.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_qcsnodep.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_setsnodepvars.F90 | 4 ++-- .../noah.2.7.1/da_snodep/noah271_transform_snodep.F90 | 4 ++-- .../land/noah.2.7.1/da_snodep/noah271_updatesnodep.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_descale_snow.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_getscapred.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_getsnowvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_getsynswepred.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_map_snow.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_map_swe.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_qc_snowobs.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_qcsnow.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_scale_snow.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_setsnowvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_transform_snow.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_updatesnowvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snow/noah271_wrtswe.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_descale_snwd.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_getsnwdpred.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_getsnwdvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_qcsnwd.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_scale_snwd.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_setsnwdvars.F90 | 4 ++-- .../land/noah.2.7.1/da_snwd/noah271_updatesnwdvars.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_descale_soilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_getsoilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_getsynsmpred.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_map_sm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_qc_soilmobs.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_qcsoilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_scale_soilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_setsoilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_transform_synsm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_updatesoilm.F90 | 4 ++-- .../land/noah.2.7.1/da_soilm/noah271_write_soilm.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_descale_swe.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_getswepred.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_getswevars.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_qcswe.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_scale_swe.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_setswevars.F90 | 4 ++-- .../land/noah.2.7.1/da_swe/noah271_updateswevars.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_descale_tskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_getTskinPred.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_gettskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_qc_tskinobs.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_qctskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_scale_tskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_settskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_update_tskin.F90 | 4 ++-- .../land/noah.2.7.1/da_tskin/noah271_wrttskin.F90 | 4 ++-- .../land/noah.2.7.1/module_sf_noah271lsm.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_calc_tskin.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_f2t.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_finalize.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_main.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_module.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_readrst.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_setsoils.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_settbot.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_setup.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/noah271_writerst.F90 | 4 ++-- .../land/noah.2.7.1/pe/noah271_getpeobspred_wgPBMRsm.F90 | 4 ++-- lis/surfacemodels/land/noah.2.7.1/pe/noah271_peMod.F90 | 4 ++-- .../land/noah.2.7.1/pe/noah271_set_pedecvars.F90 | 4 ++-- .../land/noah.2.7.1/pe/noah271_setupobspred_wgPBMRsm.F90 | 4 ++-- .../land/noah.2.7.1/routing/noah271_getrunoffs.F90 | 4 ++-- .../land/noah.2.7.1/routing/noah271_getrunoffs_mm.F90 | 4 ++-- .../land/noah.2.7.1/sfc_cmem3/noah271_sfc2cmem3.F90 | 4 ++-- .../land/noah.2.7.1/sfc_crtm/noah271_sfc2crtm.F90 | 4 ++-- .../land/noah.3.2/cpl_wrf_noesmf/noah32_setwrfexport.F90 | 4 ++-- .../land/noah.3.2/cpl_wrf_noesmf/noah32_wrf_f2t.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_getsnodepvars.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_map_snodep.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_qcsnodep.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_setsnodepvars.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_transform_snodep.F90 | 4 ++-- .../land/noah.3.2/da_snodep/noah32_updatesnodep.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_dascf_Mod.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_descale_snow.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_getsnowvars.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_getsnwdpred.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_getswepred.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_map_snow.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_map_swe.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_qc_snowobs.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/da_snow/noah32_qcsnow.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_scale_snow.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_setsnowvars.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_transform_snow.F90 | 4 ++-- .../land/noah.3.2/da_snow/noah32_updatesnowvars.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/da_snow/noah32_wrtswe.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_descale_soilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_getsmpred.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_getsoilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_qc_soilmobs.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_qcsoilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_scale_soilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_setsoilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_updatesoilm.F90 | 4 ++-- .../land/noah.3.2/da_soilm/noah32_write_soilm.F90 | 4 ++-- .../land/noah.3.2/module_model_constants_32.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/module_sf_noah32lsm.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/module_sfcdif_wrf_32.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_f2t.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_finalize.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_main.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_module.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_readrst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_setsoils.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_settbot.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_setup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/noah32_writerst.F90 | 4 ++-- .../land/noah.3.2/pe/noah32_getpeobspred_ARMobs.F90 | 4 ++-- .../land/noah.3.2/pe/noah32_getpeobspred_template.F90 | 4 ++-- lis/surfacemodels/land/noah.3.2/pe/noah32_peMod.F90 | 4 ++-- .../land/noah.3.2/pe/noah32_set_pedecvars.F90 | 4 ++-- .../land/noah.3.2/pe/noah32_setupobspred_ARMobs.F90 | 4 ++-- .../land/noah.3.2/pe/noah32_setupobspred_template.F90 | 4 ++-- .../land/noah.3.2/routing/noah32_getrunoffs.F90 | 4 ++-- .../land/noah.3.2/routing/noah32_getrunoffs_mm.F90 | 4 ++-- .../land/noah.3.2/sfc_cmem3/noah32_sfc2cmem3.F90 | 4 ++-- .../land/noah.3.2/sfc_crtm/noah32_sfc2crtm.F90 | 4 ++-- .../land/noah.3.3/cpl_wrf_noesmf/noah33_setwrfexport.F90 | 4 ++-- .../land/noah.3.3/cpl_wrf_noesmf/noah33_wrf_f2t.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_descale_snodep.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_getsnodeppred.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_getsnodepvars.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_map_snodep.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_qc_snodepobs.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_qcsnodep.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_scale_snodep.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_setsnodepvars.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_transform_snodep.F90 | 4 ++-- .../land/noah.3.3/da_snodep/noah33_updatesnodep.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_dasnow_Mod.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_descale_snow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_getscfpred.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_getsnowpred_PMWsnow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_getsnowvars.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_getsnwdpred.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_getswepred.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_map_snow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_map_snow_DI.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_map_swe.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_qc_PMWsnowobs.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_qc_scfobs.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_qc_snowobs.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/da_snow/noah33_qcsnow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_scale_snow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_setsnowvars.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_transform_snow.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_updatesnowvars.F90 | 4 ++-- .../land/noah.3.3/da_snow/noah33_updatesnowvars_scfda.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_dasoilm_Mod.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_descale_soilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_getLbandTbPred.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_getsmpred.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_getsoilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_qc_soilmobs.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_qcsoilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_scale_soilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_setsoilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_updatesoilm.F90 | 4 ++-- .../land/noah.3.3/da_soilm/noah33_write_soilm.F90 | 4 ++-- .../noah.3.3/irrigation/noah33_getirrigationstates.F90 | 4 ++-- .../land/noah.3.3/module_model_constants_33.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm.F90 | 4 ++-- .../land/noah.3.3/module_sf_noah33lsm_glacial.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/module_sfcdif_wrf_33.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_f2t.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_finalize.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_main.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_module.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_readrst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_reset.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_setsoils.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_settbot.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_setup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/noah33_writerst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.3/pe/noah33_peMod.F90 | 4 ++-- .../land/noah.3.3/pe/noah33_set_pedecvars.F90 | 4 ++-- .../pe/obspred/ARM/noah33_getpeobspred_ARMobs.F90 | 4 ++-- .../pe/obspred/ARM/noah33_setupobspred_ARMobs.F90 | 4 ++-- .../pe/obspred/FLUXNET/noah33_getpeobspred_FLUXNETobs.F90 | 4 ++-- .../pe/obspred/FLUXNET/noah33_setupobspred_FLUXNETobs.F90 | 4 ++-- .../LPRM_AMSREsm/noah33_getpeobspred_LPRMsmobs.F90 | 4 ++-- .../LPRM_AMSREsm/noah33_setupobspred_LPRMsmobs.F90 | 4 ++-- .../USDA_ARSsm/noah33_getpeobspred_USDA_ARSsmobs.F90 | 4 ++-- .../USDA_ARSsm/noah33_setupobspred_USDA_ARSsmobs.F90 | 4 ++-- .../pe/obspred/template/noah33_getpeobspred_template.F90 | 4 ++-- .../pe/obspred/template/noah33_setupobspred_template.F90 | 4 ++-- .../land/noah.3.3/routing/noah33_getrunoffs.F90 | 4 ++-- .../land/noah.3.3/routing/noah33_getrunoffs_et.F90 | 4 ++-- .../land/noah.3.3/routing/noah33_getrunoffs_mm.F90 | 4 ++-- .../land/noah.3.3/sfc_cmem3/noah33_sfc2cmem3.F90 | 4 ++-- .../land/noah.3.3/sfc_crtm/noah33_sfc2crtm.F90 | 4 ++-- .../land/noah.3.3/sfc_tauomega/noah33_sfc2tauomega.F90 | 4 ++-- .../land/noah.3.6/cpl_wrf_noesmf/noah36_setwrfexport.F90 | 4 ++-- .../land/noah.3.6/cpl_wrf_noesmf/noah36_wrf_f2t.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_descale_snodep.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_getsnodeppred.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_getsnodepvars.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_map_snodep.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_qc_snodepobs.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_qcsnodep.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_scale_snodep.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_setsnodepvars.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_transform_snodep.F90 | 4 ++-- .../land/noah.3.6/da_snodep/noah36_updatesnodep.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_dasnow_Mod.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_descale_snow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_getscfpred.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_getsnowpred_PMWsnow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_getsnowvars.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_getsnwdpred.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_getswepred.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_map_snow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_map_snow_DI.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_map_swe.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_qc_PMWsnowobs.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_qc_scfobs.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_qc_snowobs.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/da_snow/noah36_qcsnow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_scale_snow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_setsnowvars.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_transform_snow.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_updatesnowvars.F90 | 4 ++-- .../land/noah.3.6/da_snow/noah36_updatesnowvars_scfda.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_dasoilm_Mod.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_descale_soilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_getLbandTbPred.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_getsmpred.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_getsoilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_qc_soilmobs.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_qcsoilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_scale_soilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_setsoilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_updatesoilm.F90 | 4 ++-- .../land/noah.3.6/da_soilm/noah36_write_soilm.F90 | 4 ++-- .../land/noah.3.6/module_model_constants_36.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm.F90 | 4 ++-- .../land/noah.3.6/module_sf_noah36lsm_glacial.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/module_sfcdif_wrf_36.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_f2t.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_finalize.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_main.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_module.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_readrst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_reset.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_setsoils.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_settbot.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_setup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/noah36_writerst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.6/pe/noah36_peMod.F90 | 4 ++-- .../land/noah.3.6/pe/noah36_set_pedecvars.F90 | 4 ++-- .../land/noah.3.6/routing/noah36_getrunoffs.F90 | 4 ++-- .../land/noah.3.6/routing/noah36_getrunoffs_hymap2.F90 | 4 ++-- .../land/noah.3.6/routing/noah36_getrunoffs_mm.F90 | 4 ++-- .../land/noah.3.6/routing/noah36_getsws_hymap2.F90 | 4 ++-- .../land/noah.3.6/sfc_cmem3/noah36_sfc2cmem3.F90 | 4 ++-- .../land/noah.3.9/cplsubLSM/noah39_getCROCUSexport.F90 | 2 +- .../land/noah.3.9/cplsubLSM/noah39_setCROCUSimport.F90 | 4 ++-- .../land/noah.3.9/cplsubLSM/noah39_snow_update.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_descale_snodep.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_getsnodeppred.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_getsnodepvars.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_map_snodep.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_qc_snodepobs.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_qcsnodep.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_scale_snodep.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_setsnodepvars.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_transform_snodep.F90 | 4 ++-- .../land/noah.3.9/da_snodep/noah39_updatesnodep.F90 | 4 ++-- .../land/noah.3.9/da_snow/noah39_dasnow_Mod.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_dasoilm_Mod.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_descale_soilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_getLbandTbPred.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_getsmpred.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_getsoilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_qc_soilmobs.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_qcsoilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_scale_soilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_setsoilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_updatesoilm.F90 | 4 ++-- .../land/noah.3.9/da_soilm/noah39_write_soilm.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_descale_usafsi.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_getusafsipred.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_getusafsivars.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_map_usafsi.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_qc_usafsiobs.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_qcusafsi.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_scale_usafsi.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_setusafsivars.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_transform_usafsi.F90 | 4 ++-- .../land/noah.3.9/da_usafsi/noah39_updateusafsi.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/module_sfcdif_wrf_39.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_f2t.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_finalize.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_main.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_module.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_reset.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_setsoils.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_settbot.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_setup.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_setvegparms.F90 | 4 ++-- lis/surfacemodels/land/noah.3.9/noah39_writerst.F90 | 4 ++-- .../land/noah.3.9/phys/module_sf_noah39lsm.F90 | 4 ++-- .../land/noah.3.9/routing/noah39_getrunoffs.F90 | 4 ++-- .../land/noah.3.9/routing/noah39_getrunoffs_hymap2.F90 | 4 ++-- .../land/noah.3.9/routing/noah39_getrunoffs_mm.F90 | 4 ++-- .../land/noah.3.9/routing/noah39_getrunoffs_rapid.F90 | 4 ++-- .../land/noah.3.9/routing/noah39_getsws_hymap2.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_coldstart.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_f2t.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_finalize.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_main.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_module.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_readrst.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_reset.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_setup.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/NoahMP36_writerst.F90 | 4 ++-- .../land/noahmp.3.6/SOIL_VEG_GEN_PARM_36.F90 | 4 ++-- .../noahmp.3.6/cpl_wrf_noesmf/noahMP36_setwrfexport.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_daveg_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_descale_veg.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_getLAIpred.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_getvegvars.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_map_veg.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_qc_LAIobs.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_qcveg.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_scale_veg.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_setvegvars.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_transform_veg.F90 | 4 ++-- .../land/noahmp.3.6/da_LAI/noahmp36_updatevegvars.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_daalbedo_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_descale_albedo.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_getalbedopred.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_getalbedovars.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_map_albedo.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_qc_albedoobs.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_qcalbedo.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_scale_albedo.F90 | 4 ++-- .../land/noahmp.3.6/da_albedo/noahmp36_setalbedovars.F90 | 4 ++-- .../noahmp.3.6/da_albedo/noahmp36_transform_albedo.F90 | 4 ++-- .../noahmp.3.6/da_albedo/noahmp36_updatealbedovars.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_dasnodep_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_descale_snodep.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_getsnodeppred.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_getsnodepvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_map_snodep.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_qc_snodepobs.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_qcsnodep.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_scale_snodep.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_setsnodepvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snodep/noahmp36_snodep_update.F90 | 4 ++-- .../noahmp.3.6/da_snodep/noahmp36_transform_snodep.F90 | 4 ++-- .../noahmp.3.6/da_snodep/noahmp36_updatesnodepvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_dasnow_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_descale_snow.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_getsnowvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_getsnwdpred.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_getswepred.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_qc_snowobs.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_qcsnow.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_scale_snow.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_setsnowvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_snow_update.F90 | 4 ++-- .../land/noahmp.3.6/da_snow/noahmp36_updatesnowvars.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/mwSVM_routines.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/noahmp36_LIS_SVM.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/noahmp36_dasnowSVM_Mod.F90 | 4 ++-- .../noahmp.3.6/da_snowSVM/noahmp36_descale_snowSVM.F90 | 4 ++-- .../noahmp.3.6/da_snowSVM/noahmp36_getsnowvarsSVM.F90 | 4 ++-- .../noahmp.3.6/da_snowSVM/noahmp36_getsnwdpred_TB.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/noahmp36_qc_snowobsSVM.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/noahmp36_qcsnowSVM.F90 | 4 ++-- .../land/noahmp.3.6/da_snowSVM/noahmp36_scale_snowSVM.F90 | 4 ++-- .../noahmp.3.6/da_snowSVM/noahmp36_setsnowvarsSVM.F90 | 4 ++-- .../noahmp.3.6/da_snowSVM/noahmp36_updatesnowvarsSVM.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_dasoilm_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_descale_soilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_getsmpred.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_getsoilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_qc_soilmobs.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_qcsoilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_scale_soilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_setsoilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_updatesoilm.F90 | 4 ++-- .../land/noahmp.3.6/da_soilm/noahmp36_write_soilm.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_datws_Mod.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_descale_tws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_gettws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_gettwspred.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_qc_twsobs.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_qctws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_scale_tws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_settws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_tws_DAlogMod.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_updatetws.F90 | 4 ++-- .../land/noahmp.3.6/da_tws/noahmp36_write_tws.F90 | 4 ++-- .../irrigation/noahmp36_getirrigationstates.F90 | 4 ++-- .../land/noahmp.3.6/kwm_date_utilities_36.F90 | 4 ++-- .../land/noahmp.3.6/module_model_constants_36.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/module_sf_myjsfc_36.F90 | 4 ++-- .../land/noahmp.3.6/module_sf_noahlsm_36.F90 | 4 ++-- .../land/noahmp.3.6/module_sf_noahmplsm_36.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/module_sf_sfclay_36.F90 | 4 ++-- .../land/noahmp.3.6/noahmp36_wrf_routines.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/noahmp_driver_36.F90 | 4 ++-- lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_peMod.F90 | 4 ++-- .../land/noahmp.3.6/pe/NoahMP36_set_pedecvars.F90 | 4 ++-- .../pe/obspred/ARSsm/NoahMP36_getpeobspred_ARSsmobs.F90 | 4 ++-- .../pe/obspred/ARSsm/NoahMP36_setupobspred_ARSsmobs.F90 | 4 ++-- .../pe/obspred/ISMNsm/NoahMP36_getpeobspred_ISMNsmobs.F90 | 4 ++-- .../pe/obspred/ISMNsm/NoahMP36_setupobspred_ISMNsmobs.F90 | 4 ++-- .../pe/obspred/SMAPsm/NoahMP36_getpeobspred_SMAPsmobs.F90 | 4 ++-- .../pe/obspred/SMAPsm/NoahMP36_setupobspred_SMAPsmobs.F90 | 4 ++-- .../land/noahmp.3.6/routing/noahmp36_getrunoffs.F90 | 4 ++-- .../noahmp.3.6/routing/noahmp36_getrunoffs_hymap2.F90 | 4 ++-- .../land/noahmp.3.6/routing/noahmp36_getrunoffs_mm.F90 | 4 ++-- .../land/noahmp.3.6/routing/noahmp36_getrunoffs_rapid.F90 | 4 ++-- .../land/noahmp.3.6/routing/noahmp36_getsws_hymap2.F90 | 4 ++-- .../land/noahmp.3.6/sfc_cmem3/noahmp36_sfc2cmem3.F90 | 4 ++-- .../land/noahmp.4.0.1/NoahMP401_coldstart.F90 | 4 ++-- .../land/noahmp.4.0.1/NoahMP401_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_f2t.F90 | 4 ++-- .../land/noahmp.4.0.1/NoahMP401_finalize.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_module.F90 | 4 ++-- .../land/noahmp.4.0.1/NoahMP401_read_OPT_parameters.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readrst.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_reset.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_setup.F90 | 4 ++-- .../land/noahmp.4.0.1/NoahMP401_writerst.F90 | 4 ++-- .../cpl_wrf_noesmf/noahMP401_setwrfexport.F90 | 4 ++-- .../noahmp.4.0.1/cplsubLSM/noahmp401_getCROCUSexport.F90 | 4 ++-- .../cplsubLSM/noahmp401_getSnowModelexport.F90 | 4 ++-- .../noahmp.4.0.1/cplsubLSM/noahmp401_setCROCUSimport.F90 | 4 ++-- .../cplsubLSM/noahmp401_setSnowModelimport.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_daveg_Mod.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_descale_veg.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_getLAIpred.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_getvegvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_qc_LAIobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_qcveg.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_scale_veg.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_setvegvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_updatevegvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_veg_DAlog.F90 | 4 ++-- .../land/noahmp.4.0.1/da_LAI/noahmp401_write_veg.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_dasnodep_Mod.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_descale_snodep.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_getsnodeppred.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_getsnodepvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snodep/noahmp401_map_snodep.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_qc_snodepobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snodep/noahmp401_qcsnodep.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_scale_snodep.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_setsnodepvars.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_snodep_update.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_transform_snodep.F90 | 4 ++-- .../noahmp.4.0.1/da_snodep/noahmp401_updatesnodepvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_dasnow_Mod.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_descale_snow.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_getsnowpred.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_getsnowvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_getswepred.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_qc_snowobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_qcsnow.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_scale_snow.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_setsnowvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 | 4 ++-- .../noahmp.4.0.1/da_snow/noahmp401_updatesnowvars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_dasoilm_Mod.F90 | 4 ++-- .../noahmp.4.0.1/da_soilm/noahmp401_descale_soilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_getsmpred.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_getsoilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_qc_soilmobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_qcsoilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_scale_soilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_setsoilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_updatesoilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_soilm/noahmp401_write_soilm.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_gettwspred.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_qc_twsobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_tws_DAlogMod.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 | 4 ++-- .../land/noahmp.4.0.1/da_tws/noahmp401_write_tws.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_dausafsi_Mod.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_descale_usafsi.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_getusafsipred.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_getusafsivars.F90 | 4 ++-- .../land/noahmp.4.0.1/da_usafsi/noahmp401_map_usafsi.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_qc_usafsiobs.F90 | 4 ++-- .../land/noahmp.4.0.1/da_usafsi/noahmp401_qcusafsi.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_scale_usafsi.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_setusafsivars.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_transform_usafsi.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_updateusafsivars.F90 | 4 ++-- .../noahmp.4.0.1/da_usafsi/noahmp401_usafsi_update.F90 | 4 ++-- .../irrigation/noahmp401_getirrigationstates.F90 | 4 ++-- .../land/noahmp.4.0.1/kwm_date_utilities_401.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/noahmp_driver_401.F90 | 4 ++-- .../land/noahmp.4.0.1/pe/NoahMP401_peMod.F90 | 4 ++-- .../land/noahmp.4.0.1/pe/NoahMP401_set_pedecvars.F90 | 4 ++-- .../obspred/UAsnow/NoahMP401_getpeobspred_UAsnowobs.F90 | 4 ++-- .../obspred/UAsnow/NoahMP401_setupobspred_UAsnowobs.F90 | 4 ++-- .../land/noahmp.4.0.1/routing/noahmp401_getrunoffs.F90 | 4 ++-- .../noahmp.4.0.1/routing/noahmp401_getrunoffs_hymap2.F90 | 4 ++-- .../land/noahmp.4.0.1/routing/noahmp401_getrunoffs_mm.F90 | 4 ++-- .../noahmp.4.0.1/routing/noahmp401_getrunoffs_rapid.F90 | 4 ++-- .../land/noahmp.4.0.1/routing/noahmp401_getsws_hymap2.F90 | 4 ++-- lis/surfacemodels/land/noahmp.4.0.1/wrf_debug.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356.lis.config | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_coldstart.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_f2t.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_finalize.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90.old | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_module.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readcrd.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readrst.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_setup.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM356_writerst.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/RDHM_356.F90 | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/SOILPAR2.F | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/com_header.h | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/init_soil_moisture.f | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/linux.h | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/logfromfortran.c | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/models.h | 4 ++-- lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_coldstart.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_f2t.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_finalize.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_main.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_module.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_readcrd.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_readrst.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_setup.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/RUC37_writerst.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_dasnow_Mod.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_descale_snow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_getscfpred.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_getsnowpred_PMWsnow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_getsnowvars.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_getsnwdpred.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_getswepred.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_map_snow_DI.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_swe.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_qc_PMWsnowobs.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_qc_scfobs.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_qc_snowobs.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qcsnow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_scale_snow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_setsnowvars.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_transform_snow.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_updatesnowvars.F90 | 4 ++-- .../land/ruc.3.7/da_snow/ruc37_updatesnowvars_scfda.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_dasoilm_Mod.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_descale_soilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_getLbandTbPred.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_getsmpred.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_getsoilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_getsynsmpred.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_qc_soilmobs.F90 | 4 ++-- lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qcsoilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_scale_soilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_setsoilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_updatesoilm.F90 | 4 ++-- .../land/ruc.3.7/da_soilm/ruc37_write_soilm.F90 | 4 ++-- .../land/ruc.3.7/irrigation/ruc37_getirrigationstates.F90 | 4 ++-- .../land/ruc.3.7/routing/ruc37_getrunoffs.F90 | 4 ++-- .../land/ruc.3.7/routing/ruc37_getrunoffs_mm.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_coldstart.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_f2t.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_finalize.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_lsmMod.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_main.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_module.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_readcrd.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_readrst.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_setup.F90 | 4 ++-- .../land/subLSM/crocus.8.1/Crocus81_writerst.F90 | 4 ++-- .../subLSM/crocus.8.1/cplLSM/Crocus81_getLSMexport.F90 | 4 ++-- .../subLSM/crocus.8.1/cplLSM/Crocus81_setLSMimport.F90 | 4 ++-- .../land/subLSM/crocus.8.1/crocus_driver.F90 | 4 ++-- .../subLSM/crocus.8.1/kwm_date_utilities_crocus81.F90 | 4 ++-- .../subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 | 4 ++-- .../subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 | 4 ++-- .../land/subLSM/snowmodel/micromet_module.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_coldstart.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_finalize.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_lsmMod.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_main.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_module.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_readconfig.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_readrst.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_reset.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_setup.F90 | 4 ++-- .../land/subLSM/snowmodel/snowmodel_writerst.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_f2t.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_finalize.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_main.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_module.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_readcrd.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_readrst.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_setup.F90 | 4 ++-- lis/surfacemodels/land/summa.1.0/summa1_writerst.F90 | 4 ++-- lis/surfacemodels/land/template/0Intro_template.txt | 4 ++-- lis/surfacemodels/land/template/template_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/template/template_f2t.F90 | 4 ++-- lis/surfacemodels/land/template/template_finalize.F90 | 4 ++-- lis/surfacemodels/land/template/template_getrunoffs.F90 | 4 ++-- lis/surfacemodels/land/template/template_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/template/template_main.F90 | 4 ++-- lis/surfacemodels/land/template/template_module.F90 | 4 ++-- lis/surfacemodels/land/template/template_readcrd.F90 | 4 ++-- lis/surfacemodels/land/template/template_readrst.F90 | 4 ++-- lis/surfacemodels/land/template/template_reset.F90 | 4 ++-- lis/surfacemodels/land/template/template_setup.F90 | 4 ++-- lis/surfacemodels/land/template/template_writerst.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/0Intro_vic411.txt | 4 ++-- lis/surfacemodels/land/vic.4.1.1/finalize_vic411.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/setup_vic411.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_add_atmosdata.c | 4 ++-- .../land/vic.4.1.1/vic411_compute_treeline_lis.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_diag.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_f2t.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_finalize.F90 | 4 ++-- .../land/vic.4.1.1/vic411_find_min_tfactor.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_fsvp.c | 4 ++-- .../land/vic.4.1.1/vic411_get_max_snow_temp.c | 4 ++-- .../land/vic.4.1.1/vic411_lis_read_soilparam_arc.c | 4 ++-- .../land/vic.4.1.1/vic411_lis_scan_soilparam_flat_ascii.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_main.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_module.F90 | 4 ++-- .../land/vic.4.1.1/vic411_read_vegparam_lis.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_readcard.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_readrst.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_run.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_setup.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_write_atmos.c | 4 ++-- .../land/vic.4.1.1/vic411_write_bin_atmosdata.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_write_lakecon.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_write_prcp.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_write_state.c | 4 ++-- lis/surfacemodels/land/vic.4.1.1/vic411_writerst.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/0Intro_vic412.txt | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/finalize_vic412.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/find_min_tfactor.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/fsvp.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/get_max_snow_temp.c | 4 ++-- .../land/vic.4.1.2.l/lis_read_soilparam_arc.c.original | 4 ++-- .../land/vic.4.1.2.l/lis_scan_soilparam_flat_ascii.c | 4 ++-- .../land/vic.4.1.2.l/routing/vic412_getrunoff.c | 4 ++-- .../land/vic.4.1.2.l/routing/vic412_getrunoffs.F90 | 4 ++-- .../land/vic.4.1.2.l/routing/vic412_getrunoffs_mm.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c.origin | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_add_atmosdata.c | 4 ++-- .../land/vic.4.1.2.l/vic412_compute_treeline.c | 4 ++-- .../land/vic.4.1.2.l/vic412_count_model_state.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_diag.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_dynsetup.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_f2t.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_finalize.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_intialize.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_lsmMod.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_main.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_module.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_read_vegparam.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_readcard.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_readrst.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_setup.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/vic412_writerst.F90 | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/write_atmosdata.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/write_bin_atmosdata.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/write_lakecon.c | 4 ++-- lis/surfacemodels/land/vic.4.1.2.l/write_prcp.c | 4 ++-- .../openwater/template/readtemplateOpenWatercrd.F90 | 4 ++-- .../openwater/template/templateOpenWaterMod.F90 | 4 ++-- .../openwater/template/templateOpenWater_dynsetup.F90 | 4 ++-- .../openwater/template/templateOpenWater_f2t.F90 | 4 ++-- .../openwater/template/templateOpenWater_finalize.F90 | 4 ++-- .../openwater/template/templateOpenWater_main.F90 | 4 ++-- .../openwater/template/templateOpenWater_module.F90 | 4 ++-- .../openwater/template/templateOpenWater_readrst.F90 | 4 ++-- .../openwater/template/templateOpenWater_setup.F90 | 4 ++-- .../openwater/template/templateOpenWater_writerst.F90 | 4 ++-- .../metforcing/afwa-cod/compute_cod_based_clouds.F90 | 4 ++-- .../metforcing/afwa-cod/compute_type_based_clouds.F90 | 4 ++-- lis/testcases/metforcing/afwa-cod/readagrmetforcing.F90 | 4 ++-- .../metforcing/afwa-galwem/AGRMET_fldbld_galwem.F90 | 4 ++-- .../afwa-galwem/AGRMET_fldbld_precip_galwem.F90 | 4 ++-- lis/testcases/metforcing/merra2/read_CONSTANT_lc.F90 | 4 ++-- lis/testcases/metforcing/merra2/read_merra2.F90.dbg | 4 ++-- lis/testcases/misc/history/template_main.F90 | 4 ++-- .../land/geowrsi.2/wget_testcasefiles_portal.sh | 4 ++-- lis/utils/eis_visualization_portal/eis-fire/index.html | 4 ++-- .../eis-freshwater/data/MissRiverBasin0.js | 4 ++-- .../eis-freshwater/data/columbia_basin_0.js | 4 ++-- .../eis-freshwater/data/dams_columbia_all_3.js | 4 ++-- .../eis-freshwater/data/downstream_reach_4.js | 4 ++-- .../eis-freshwater/data/reservoir_only_6.js | 4 ++-- .../eis-freshwater/data/reservoir_upstream_7.js | 4 ++-- .../eis-freshwater/data/reservoir_upstream_dnstream_8.js | 4 ++-- .../eis-freshwater/data/reservoirs_2.js | 4 ++-- .../eis-freshwater/data/rivers_1.js | 4 ++-- .../eis-freshwater/data/rivers_mrb_0.js | 4 ++-- .../eis-freshwater/data/upstream_reach_5.js | 4 ++-- .../eis_visualization_portal/eis-freshwater/explorer.html | 4 ++-- .../eis_visualization_portal/eis-freshwater/index.html | 4 ++-- .../eis_visualization_portal/eis-freshwater/storymap.html | 4 ++-- .../eis-freshwater/timeseries_altimeter.html | 4 ++-- .../eis-freshwater/timeseries_streamflow.html | 4 ++-- .../eis_visualization_portal/eis-sealevel/index.html | 4 ++-- .../eis_visualization_portal/eis-sealevel/storymap.html | 4 ++-- .../eis_visualization_portal/eis-toplanding/about.html | 4 ++-- .../eis_visualization_portal/eis-toplanding/css/about.css | 4 ++-- .../eis-toplanding/css/agency.css | 4 ++-- .../eis-toplanding/css/agency.min.css | 4 ++-- .../eis_visualization_portal/eis-toplanding/css/style.css | 4 ++-- .../eis-toplanding/css/styles.css | 4 ++-- .../eis_visualization_portal/eis-toplanding/index.html | 4 ++-- .../eis_visualization_portal/eis-toplanding/js/agency.js | 4 ++-- .../eis-toplanding/js/agency.min.js | 4 ++-- .../eis-toplanding/js/contact_me.js | 4 ++-- .../eis-toplanding/scss/agency.scss | 4 ++-- .../eis-toplanding/scss/base/_mixins.scss | 4 ++-- .../eis-toplanding/scss/base/_page.scss | 4 ++-- .../eis-toplanding/scss/base/_variables.scss | 4 ++-- .../eis-toplanding/scss/components/_buttons.scss | 4 ++-- .../eis-toplanding/scss/components/_navbar.scss | 4 ++-- .../eis-toplanding/scss/layout/_contact.scss | 4 ++-- .../eis-toplanding/scss/layout/_footer.scss | 4 ++-- .../eis-toplanding/scss/layout/_masthead.scss | 4 ++-- .../eis-toplanding/scss/layout/_portfolio.scss | 4 ++-- .../eis-toplanding/scss/layout/_services.scss | 4 ++-- .../eis-toplanding/scss/layout/_team.scss | 4 ++-- .../eis-toplanding/scss/layout/_timeline.scss | 4 ++-- lis/utils/ensemble_downscale/restartFromEnsemble.F90 | 4 ++-- lis/utils/ensemble_upscale/restartForEnsemble.F90 | 4 ++-- lis/utils/grads/generateGrADsControlFile.F90 | 4 ++-- lis/utils/refman_scripts/doc.sh | 4 ++-- lis/utils/restartConverter/bilinear_interp.F90 | 4 ++-- lis/utils/restartConverter/bilinear_interp_input.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_ease.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_gauss.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_hrap.F90 | 4 ++-- .../restartConverter/compute_earth_coord_lambert.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_latlon.F90 | 4 ++-- .../restartConverter/compute_earth_coord_latlon_ll.F90 | 4 ++-- .../restartConverter/compute_earth_coord_latlon_ur.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_ll.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_merc.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_polar.F90 | 4 ++-- lis/utils/restartConverter/compute_earth_coord_ur.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_ease.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_gauss.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_hrap.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_lambert.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_latlon.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_merc.F90 | 4 ++-- lis/utils/restartConverter/compute_grid_coord_polar.F90 | 4 ++-- lis/utils/restartConverter/ezlh_convert.F90 | 4 ++-- lis/utils/restartConverter/ezlh_inverse.F90 | 4 ++-- lis/utils/restartConverter/gaussian_mod.F90 | 4 ++-- lis/utils/restartConverter/gausslat.F90 | 4 ++-- lis/utils/restartConverter/get_fieldpos.F90 | 4 ++-- lis/utils/restartConverter/latlonTohrap.F90 | 4 ++-- lis/utils/restartConverter/latlonTopolar.F90 | 4 ++-- lis/utils/restartConverter/map_utils.F90 | 4 ++-- lis/utils/restartConverter/neighbor_interp.F90 | 4 ++-- lis/utils/restartConverter/neighbor_interp_input.F90 | 4 ++-- lis/utils/restartConverter/polfixs.F90 | 4 ++-- lis/utils/restartConverter/restartConverter.F90 | 4 ++-- lis/utils/restartConverter/restartConverter.F90.afwa | 4 ++-- lis/utils/restartConverter/restartConverter.F90.orig | 4 ++-- lis/utils/restartGenAFWA/bilinear_interp.F90 | 4 ++-- lis/utils/restartGenAFWA/bilinear_interp_input.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord_gauss.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord_lambert.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord_latlon.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord_merc.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_earth_coord_polar.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord_gauss.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord_lambert.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord_latlon.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord_merc.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_grid_coord_polar.F90 | 4 ++-- lis/utils/restartGenAFWA/compute_stnwts.F90 | 4 ++-- lis/utils/restartGenAFWA/conserv_interp.F90 | 4 ++-- lis/utils/restartGenAFWA/conserv_interp_input.F90 | 4 ++-- lis/utils/restartGenAFWA/createLISrestart.F90 | 4 ++-- lis/utils/restartGenAFWA/gausslat.F90 | 4 ++-- lis/utils/restartGenAFWA/get_fieldpos.F90 | 4 ++-- lis/utils/restartGenAFWA/interp_stndata.F90 | 4 ++-- lis/utils/restartGenAFWA/latlonTopolar.F90 | 4 ++-- lis/utils/restartGenAFWA/lltops.F90 | 4 ++-- lis/utils/restartGenAFWA/map_utils.F90 | 4 ++-- lis/utils/restartGenAFWA/neighbor_interp.F90 | 4 ++-- lis/utils/restartGenAFWA/neighbor_interp_input.F90 | 4 ++-- lis/utils/restartGenAFWA/normalize_stnwts.F90 | 4 ++-- lis/utils/restartGenAFWA/polarToLatLon.F90 | 4 ++-- lis/utils/restartGenAFWA/polfixs.F90 | 4 ++-- lis/utils/restartGenAFWA/pstoll.F90 | 4 ++-- lis/utils/ueinit_generator/generateUEinitFile.F90 | 4 ++-- lis/utils/usaf/dump2lis_nsmax1.py | 4 ++-- lis/utils/usaf/dump2lis_nsmax3.py | 4 ++-- lis/utils/usaf/retune_bratseth/scripts/autotune.py | 4 ++-- .../usaf/retune_bratseth/scripts/create_blacklist.py | 4 ++-- .../usaf/retune_bratseth/scripts/customize_lis_config.py | 4 ++-- .../usaf/retune_bratseth/scripts/customize_procoba_nwp.py | 4 ++-- .../usaf/retune_bratseth/scripts/customize_procoba_sat.py | 4 ++-- .../usaf/retune_bratseth/scripts/fit_semivariogram.py | 4 ++-- .../usaf/retune_bratseth/scripts/plot_semivariogram.py | 4 ++-- .../usaf/retune_bratseth/scripts/rescale_sat_sigma2.py | 4 ++-- lis/utils/usaf/retune_bratseth/scripts/semivar.py | 4 ++-- lis/utils/usaf/retune_bratseth/src/USAF_GridHashMod.F90 | 4 ++-- lis/utils/usaf/retune_bratseth/src/USAF_ReportsMod.F90 | 4 ++-- lis/utils/usaf/retune_bratseth/src/USAF_StationsMod.F90 | 4 ++-- lis/utils/usaf/retune_bratseth/src/USAF_sharedMod.F90 | 4 ++-- .../usaf/retune_bratseth/src/future/USAF_StnOBDictMod.F90 | 4 ++-- .../usaf/retune_bratseth/src/future/USAF_readFilesMod.F90 | 4 ++-- lis/utils/usaf/retune_bratseth/src/procOBA_NWP.F90 | 4 ++-- lis/utils/usaf/retune_bratseth/src/procOBA_Sat.F90 | 4 ++-- lis/utils/usaf/rose2lis.py | 4 ++-- .../usaf/s2s/global_usaf_forc/customize_lis_config.py | 4 ++-- lis/utils/usaf/s2s/global_usaf_forc/store_lis_output.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/check_cfsv2_bcsd.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/check_disaggr_bcsd.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/check_nmme_bcsd.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/check_nmme_ncep.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/nctool.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/s2s_api.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh | 8 ++++---- lis/utils/usaf/s2s/s2s_app/s2s_run.sh | 8 ++++---- lis/utils/usaf/s2s/s2s_app/verify_tiff.py | 4 ++-- lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh | 8 ++++---- .../s2s_modules/bcsd_fcst/bcsd_library/bcsd_function.py | 4 ++-- .../bcsd_library/convert_forecast_data_to_netcdf.py | 4 ++-- .../s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_f.py | 4 ++-- .../s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py | 4 ++-- .../bcsd_fcst/bcsd_library/process_forecast_data.py | 4 ++-- .../bcsd_fcst/check_preprocess_forecast_files.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_01.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_03.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_04.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_05.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_06.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_07.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_08.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_09.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_10.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_11.py | 4 ++-- .../usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_12.py | 4 ++-- .../ldt_ics/generate_ldtconfig_files_ensrst_nrt.py | 4 ++-- .../s2s_modules/lis_darun/generate_lisda_config_nrt.py | 4 ++-- .../lis_fcst/generate_lis_config_scriptfiles_fcst.py | 4 ++-- .../usaf/s2s/s2s_modules/s2smetric/convert_s2s_anom_cf.py | 4 ++-- .../s2smetric/make_s2s_median_metric_geotiff.py | 4 ++-- .../usaf/s2s/s2s_modules/s2smetric/merge_s2s_anom_cf.py | 4 ++-- .../usaf/s2s/s2s_modules/s2splots/plot_anom_verify.py | 4 ++-- lis/utils/usaf/s2s/s2s_modules/s2splots/plot_hybas.py | 4 ++-- lis/utils/usaf/s2s/s2s_modules/s2splots/plot_mena.py | 4 ++-- .../usaf/s2s/s2s_modules/s2splots/plot_s2smetrics.py | 4 ++-- .../usaf/s2s/s2s_modules/s2splots/plot_streamflow_anom.py | 4 ++-- lis/utils/usaf/s2s/s2s_modules/s2splots/plot_utils.py | 4 ++-- .../usaf/s2s/s2s_modules/s2spost/daily_s2spost_nc.py | 4 ++-- .../usaf/s2s/s2s_modules/s2spost/monthly_s2spost_nc.py | 4 ++-- .../usaf/s2s/s2s_modules/s2spost/run_s2spost_1month.py | 4 ++-- .../usaf/s2s/s2s_modules/s2spost/run_s2spost_9months.py | 4 ++-- lis/utils/usaf/s2s/s2s_modules/shared/utils.py | 4 ++-- lis/utils/usaf/surf2lisnc_3_17km_4pt.py | 4 ++-- 2911 files changed, 5820 insertions(+), 5818 deletions(-) diff --git a/lis/apps/landslide/GLS/GLSMod.F90 b/lis/apps/landslide/GLS/GLSMod.F90 index 099e2e133..18c63c260 100644 --- a/lis/apps/landslide/GLS/GLSMod.F90 +++ b/lis/apps/landslide/GLS/GLSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/GLS/pe_raint/GLS_getpeobspred_raint.F90 b/lis/apps/landslide/GLS/pe_raint/GLS_getpeobspred_raint.F90 index 2380470c8..3aa13d579 100644 --- a/lis/apps/landslide/GLS/pe_raint/GLS_getpeobspred_raint.F90 +++ b/lis/apps/landslide/GLS/pe_raint/GLS_getpeobspred_raint.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/GLS/pe_raint/GLS_param_reset.F90 b/lis/apps/landslide/GLS/pe_raint/GLS_param_reset.F90 index 5d8a79a21..872ce647d 100644 --- a/lis/apps/landslide/GLS/pe_raint/GLS_param_reset.F90 +++ b/lis/apps/landslide/GLS/pe_raint/GLS_param_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/GLS/pe_raint/GLS_qcdec_raint.F90 b/lis/apps/landslide/GLS/pe_raint/GLS_qcdec_raint.F90 index e0053319b..808ebf759 100644 --- a/lis/apps/landslide/GLS/pe_raint/GLS_qcdec_raint.F90 +++ b/lis/apps/landslide/GLS/pe_raint/GLS_qcdec_raint.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/GLS/pe_raint/GLS_setdec_raint.F90 b/lis/apps/landslide/GLS/pe_raint/GLS_setdec_raint.F90 index de55c8064..00f49fb6a 100644 --- a/lis/apps/landslide/GLS/pe_raint/GLS_setdec_raint.F90 +++ b/lis/apps/landslide/GLS/pe_raint/GLS_setdec_raint.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/GLS/pe_raint/GLS_setupobspred_raint.F90 b/lis/apps/landslide/GLS/pe_raint/GLS_setupobspred_raint.F90 index bdded64cd..daabc14ff 100644 --- a/lis/apps/landslide/GLS/pe_raint/GLS_setupobspred_raint.F90 +++ b/lis/apps/landslide/GLS/pe_raint/GLS_setupobspred_raint.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/TRIGRS/TRIGRSMod.F90 b/lis/apps/landslide/TRIGRS/TRIGRSMod.F90 index c8cfe8ba7..f2b45fe98 100644 --- a/lis/apps/landslide/TRIGRS/TRIGRSMod.F90 +++ b/lis/apps/landslide/TRIGRS/TRIGRSMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/TRIGRS/grids.F90 b/lis/apps/landslide/TRIGRS/grids.F90 index 5ceba8c74..c5af9dd69 100755 --- a/lis/apps/landslide/TRIGRS/grids.F90 +++ b/lis/apps/landslide/TRIGRS/grids.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/TRIGRS/input_file_defs.F90 b/lis/apps/landslide/TRIGRS/input_file_defs.F90 index 64f0537cc..e0f56d231 100755 --- a/lis/apps/landslide/TRIGRS/input_file_defs.F90 +++ b/lis/apps/landslide/TRIGRS/input_file_defs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/TRIGRS/input_vars.F90 b/lis/apps/landslide/TRIGRS/input_vars.F90 index e824acf6f..72303cdcc 100644 --- a/lis/apps/landslide/TRIGRS/input_vars.F90 +++ b/lis/apps/landslide/TRIGRS/input_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/apps/landslide/TRIGRS/model_vars.F90 b/lis/apps/landslide/TRIGRS/model_vars.F90 index b9cadde9b..3431d2f3d 100755 --- a/lis/apps/landslide/TRIGRS/model_vars.F90 +++ b/lis/apps/landslide/TRIGRS/model_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/arch/Config.pl b/lis/arch/Config.pl index b4bed04b1..9f8f72b9c 100755 --- a/lis/arch/Config.pl +++ b/lis/arch/Config.pl @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/compile b/lis/compile index 0d429d2e9..21b6df505 100755 --- a/lis/compile +++ b/lis/compile @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/configs/557WW-7.3-FOC/JULES/single_snow_layer/gen_time.py b/lis/configs/557WW-7.3-FOC/JULES/single_snow_layer/gen_time.py index 859bcf0d3..538048d7d 100755 --- a/lis/configs/557WW-7.3-FOC/JULES/single_snow_layer/gen_time.py +++ b/lis/configs/557WW-7.3-FOC/JULES/single_snow_layer/gen_time.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/configs/557WW-7.4-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py b/lis/configs/557WW-7.4-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py index 859bcf0d3..538048d7d 100755 --- a/lis/configs/557WW-7.4-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py +++ b/lis/configs/557WW-7.4-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/configs/557WW-7.5-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py b/lis/configs/557WW-7.5-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py index 859bcf0d3..538048d7d 100755 --- a/lis/configs/557WW-7.5-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py +++ b/lis/configs/557WW-7.5-FOC/NRT_GLOBAL/JULES/single_snow_layer/gen_time.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/configs/557WW-7.5-FOC/NRT_STREAMFLOW/JULES/single_snow_layer/gen_time.py b/lis/configs/557WW-7.5-FOC/NRT_STREAMFLOW/JULES/single_snow_layer/gen_time.py index 859bcf0d3..538048d7d 100755 --- a/lis/configs/557WW-7.5-FOC/NRT_STREAMFLOW/JULES/single_snow_layer/gen_time.py +++ b/lis/configs/557WW-7.5-FOC/NRT_STREAMFLOW/JULES/single_snow_layer/gen_time.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/configure b/lis/configure index 9afecd763..42dca1626 100755 --- a/lis/configure +++ b/lis/configure @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/0Intro_core.txt b/lis/core/0Intro_core.txt index 9c673cf5f..f330bd8c8 100644 --- a/lis/core/0Intro_core.txt +++ b/lis/core/0Intro_core.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/FTable.c b/lis/core/FTable.c index 32c1e02d5..016fbc30a 100644 --- a/lis/core/FTable.c +++ b/lis/core/FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/FTable.h b/lis/core/FTable.h index acdd97c69..82ef91480 100644 --- a/lis/core/FTable.h +++ b/lis/core/FTable.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_DAobservationsMod.F90 b/lis/core/LIS_DAobservationsMod.F90 index 49b61cde5..0b14ac791 100644 --- a/lis/core/LIS_DAobservationsMod.F90 +++ b/lis/core/LIS_DAobservationsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_FORC_AttributesMod.F90 b/lis/core/LIS_FORC_AttributesMod.F90 index 8650cbded..d4d595af8 100644 --- a/lis/core/LIS_FORC_AttributesMod.F90 +++ b/lis/core/LIS_FORC_AttributesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_LMLCMod.F90 b/lis/core/LIS_LMLCMod.F90 index fd8b1724f..cc7aa1999 100644 --- a/lis/core/LIS_LMLCMod.F90 +++ b/lis/core/LIS_LMLCMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_PE_HandlerMod.F90 b/lis/core/LIS_PE_HandlerMod.F90 index e9892f88b..bcc83346f 100644 --- a/lis/core/LIS_PE_HandlerMod.F90 +++ b/lis/core/LIS_PE_HandlerMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_PRIV_gridMod.F90 b/lis/core/LIS_PRIV_gridMod.F90 index a15e00c91..94e1faf41 100644 --- a/lis/core/LIS_PRIV_gridMod.F90 +++ b/lis/core/LIS_PRIV_gridMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_PRIV_rcMod.F90 b/lis/core/LIS_PRIV_rcMod.F90 index 1a9db6d07..6a69fe61f 100644 --- a/lis/core/LIS_PRIV_rcMod.F90 +++ b/lis/core/LIS_PRIV_rcMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_PRIV_tileMod.F90 b/lis/core/LIS_PRIV_tileMod.F90 index 2b6f8fd0d..17cb309b2 100644 --- a/lis/core/LIS_PRIV_tileMod.F90 +++ b/lis/core/LIS_PRIV_tileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_RTMMod.F90 b/lis/core/LIS_RTMMod.F90 index fa9dc23fd..aed335a96 100644 --- a/lis/core/LIS_RTMMod.F90 +++ b/lis/core/LIS_RTMMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_RTM_FTable.c b/lis/core/LIS_RTM_FTable.c index a58ca909e..cca203585 100644 --- a/lis/core/LIS_RTM_FTable.c +++ b/lis/core/LIS_RTM_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_String_Utility.F90 b/lis/core/LIS_String_Utility.F90 index 137b4ebc1..02ad37869 100755 --- a/lis/core/LIS_String_Utility.F90 +++ b/lis/core/LIS_String_Utility.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_XMRG_Reader.F90 b/lis/core/LIS_XMRG_Reader.F90 index 3e82856f3..720d98568 100644 --- a/lis/core/LIS_XMRG_Reader.F90 +++ b/lis/core/LIS_XMRG_Reader.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_alb_FTable.c b/lis/core/LIS_alb_FTable.c index a075346ba..01e1add20 100644 --- a/lis/core/LIS_alb_FTable.c +++ b/lis/core/LIS_alb_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_albedoMod.F90 b/lis/core/LIS_albedoMod.F90 index cf124e2c1..17ba0a13c 100644 --- a/lis/core/LIS_albedoMod.F90 +++ b/lis/core/LIS_albedoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_appMod.F90 b/lis/core/LIS_appMod.F90 index 15499799c..8e5294cad 100644 --- a/lis/core/LIS_appMod.F90 +++ b/lis/core/LIS_appMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_biasestim_FTable.c b/lis/core/LIS_biasestim_FTable.c index 5c06675d6..d8401bc66 100755 --- a/lis/core/LIS_biasestim_FTable.c +++ b/lis/core/LIS_biasestim_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_constantsMod.F90 b/lis/core/LIS_constantsMod.F90 index 32dc0f86c..175db4a4f 100644 --- a/lis/core/LIS_constantsMod.F90 +++ b/lis/core/LIS_constantsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_coreMod.F90 b/lis/core/LIS_coreMod.F90 index 80e551c6f..41890898c 100644 --- a/lis/core/LIS_coreMod.F90 +++ b/lis/core/LIS_coreMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_create_subdirs.c b/lis/core/LIS_create_subdirs.c index 13772b8bb..79b8043cf 100644 --- a/lis/core/LIS_create_subdirs.c +++ b/lis/core/LIS_create_subdirs.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_dataAssimMod.F90 b/lis/core/LIS_dataAssimMod.F90 index 1b70c12c3..f1e77dddb 100644 --- a/lis/core/LIS_dataAssimMod.F90 +++ b/lis/core/LIS_dataAssimMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_dataassim_FTable.c b/lis/core/LIS_dataassim_FTable.c index 51bef70ef..fc3d2403b 100644 --- a/lis/core/LIS_dataassim_FTable.c +++ b/lis/core/LIS_dataassim_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_domainMod.F90 b/lis/core/LIS_domainMod.F90 index e9be57c8d..d263be277 100644 --- a/lis/core/LIS_domainMod.F90 +++ b/lis/core/LIS_domainMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_domain_FTable.c b/lis/core/LIS_domain_FTable.c index 35f3282be..cade1177e 100644 --- a/lis/core/LIS_domain_FTable.c +++ b/lis/core/LIS_domain_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_emissMod.F90 b/lis/core/LIS_emissMod.F90 index 8bd0969ad..eaa8453a7 100644 --- a/lis/core/LIS_emissMod.F90 +++ b/lis/core/LIS_emissMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_emiss_FTable.c b/lis/core/LIS_emiss_FTable.c index a89059926..6ddbc020c 100644 --- a/lis/core/LIS_emiss_FTable.c +++ b/lis/core/LIS_emiss_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_fileIOMod.F90 b/lis/core/LIS_fileIOMod.F90 index 35bb586dd..6ea72f840 100644 --- a/lis/core/LIS_fileIOMod.F90 +++ b/lis/core/LIS_fileIOMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_forecastAlg_FTable.c b/lis/core/LIS_forecastAlg_FTable.c index b982bfd39..1f854502b 100644 --- a/lis/core/LIS_forecastAlg_FTable.c +++ b/lis/core/LIS_forecastAlg_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_forecastMod.F90 b/lis/core/LIS_forecastMod.F90 index fc4112988..081f54c2d 100644 --- a/lis/core/LIS_forecastMod.F90 +++ b/lis/core/LIS_forecastMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_gfrac_FTable.c b/lis/core/LIS_gfrac_FTable.c index f728e2360..30ac8cb64 100644 --- a/lis/core/LIS_gfrac_FTable.c +++ b/lis/core/LIS_gfrac_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_glacierModelMod.F90 b/lis/core/LIS_glacierModelMod.F90 index 1d5b5a0d2..057e8f128 100644 --- a/lis/core/LIS_glacierModelMod.F90 +++ b/lis/core/LIS_glacierModelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_glaciermodel_FTable.c b/lis/core/LIS_glaciermodel_FTable.c index ca3568979..b991c6f2d 100644 --- a/lis/core/LIS_glaciermodel_FTable.c +++ b/lis/core/LIS_glaciermodel_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_gridmappingMod.F90 b/lis/core/LIS_gridmappingMod.F90 index 28b4c2412..004751fab 100644 --- a/lis/core/LIS_gridmappingMod.F90 +++ b/lis/core/LIS_gridmappingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_gswpMod.F90 b/lis/core/LIS_gswpMod.F90 index bd6699242..c79d81836 100644 --- a/lis/core/LIS_gswpMod.F90 +++ b/lis/core/LIS_gswpMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_histDataMod.F90 b/lis/core/LIS_histDataMod.F90 index f5e931293..30b7f15ad 100644 --- a/lis/core/LIS_histDataMod.F90 +++ b/lis/core/LIS_histDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_historyMod.F90 b/lis/core/LIS_historyMod.F90 index 26673d47e..eafc2f03a 100644 --- a/lis/core/LIS_historyMod.F90 +++ b/lis/core/LIS_historyMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_initialize_registries.F90 b/lis/core/LIS_initialize_registries.F90 index fbf8e9874..b92f66656 100644 --- a/lis/core/LIS_initialize_registries.F90 +++ b/lis/core/LIS_initialize_registries.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_irrigationMod.F90 b/lis/core/LIS_irrigationMod.F90 index 80c953a7d..3232071ef 100644 --- a/lis/core/LIS_irrigationMod.F90 +++ b/lis/core/LIS_irrigationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_irrigation_FTable.c b/lis/core/LIS_irrigation_FTable.c index f51424520..6a81b9659 100644 --- a/lis/core/LIS_irrigation_FTable.c +++ b/lis/core/LIS_irrigation_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_laisai_FTable.c b/lis/core/LIS_laisai_FTable.c index 8c18c778a..3de36b9f7 100644 --- a/lis/core/LIS_laisai_FTable.c +++ b/lis/core/LIS_laisai_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_lakemodelMod.F90 b/lis/core/LIS_lakemodelMod.F90 index b93a673ad..0c8effb04 100644 --- a/lis/core/LIS_lakemodelMod.F90 +++ b/lis/core/LIS_lakemodelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_lakemodel_FTable.c b/lis/core/LIS_lakemodel_FTable.c index 36482703d..194890152 100644 --- a/lis/core/LIS_lakemodel_FTable.c +++ b/lis/core/LIS_lakemodel_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_landslideMod.F90 b/lis/core/LIS_landslideMod.F90 index 7885fd3ab..43163de38 100644 --- a/lis/core/LIS_landslideMod.F90 +++ b/lis/core/LIS_landslideMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_landslide_FTable.c b/lis/core/LIS_landslide_FTable.c index a94d0d01e..3ec7b788c 100644 --- a/lis/core/LIS_landslide_FTable.c +++ b/lis/core/LIS_landslide_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_logMod.F90 b/lis/core/LIS_logMod.F90 index bfda37a9a..f6988dde7 100644 --- a/lis/core/LIS_logMod.F90 +++ b/lis/core/LIS_logMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_log_msgC.c b/lis/core/LIS_log_msgC.c index d3b0ddfbe..b9ced730e 100644 --- a/lis/core/LIS_log_msgC.c +++ b/lis/core/LIS_log_msgC.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_lsmMod.F90 b/lis/core/LIS_lsmMod.F90 index 6c9095374..f47f6e08e 100644 --- a/lis/core/LIS_lsmMod.F90 +++ b/lis/core/LIS_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_lsm_FTable.c b/lis/core/LIS_lsm_FTable.c index 29e14dc40..46271d765 100644 --- a/lis/core/LIS_lsm_FTable.c +++ b/lis/core/LIS_lsm_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_mapSoilType.F90 b/lis/core/LIS_mapSoilType.F90 index dced4aa66..3a3c0f133 100644 --- a/lis/core/LIS_mapSoilType.F90 +++ b/lis/core/LIS_mapSoilType.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_mapSurfaceModelType.F90 b/lis/core/LIS_mapSurfaceModelType.F90 index 91122b96f..df1ddb3fe 100644 --- a/lis/core/LIS_mapSurfaceModelType.F90 +++ b/lis/core/LIS_mapSurfaceModelType.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_memory_managementC.c b/lis/core/LIS_memory_managementC.c index a86c852c0..600400332 100644 --- a/lis/core/LIS_memory_managementC.c +++ b/lis/core/LIS_memory_managementC.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_metforcingMod.F90 b/lis/core/LIS_metforcingMod.F90 index 297cdec2b..5e4e8cf0f 100644 --- a/lis/core/LIS_metforcingMod.F90 +++ b/lis/core/LIS_metforcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_metforcing_FTable.c b/lis/core/LIS_metforcing_FTable.c index 1c9eae115..7e74b9c73 100644 --- a/lis/core/LIS_metforcing_FTable.c +++ b/lis/core/LIS_metforcing_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_microMetCorrection.F90 b/lis/core/LIS_microMetCorrection.F90 index ab012027e..d6620c478 100644 --- a/lis/core/LIS_microMetCorrection.F90 +++ b/lis/core/LIS_microMetCorrection.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_mpDecomp.c b/lis/core/LIS_mpDecomp.c index 1f5952278..2142d0270 100644 --- a/lis/core/LIS_mpDecomp.c +++ b/lis/core/LIS_mpDecomp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_mpiMod.F90 b/lis/core/LIS_mpiMod.F90 index 8f32d334a..f052024c3 100644 --- a/lis/core/LIS_mpiMod.F90 +++ b/lis/core/LIS_mpiMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_numerRecipesMod.F90 b/lis/core/LIS_numerRecipesMod.F90 index 0df44363c..4e281c98b 100644 --- a/lis/core/LIS_numerRecipesMod.F90 +++ b/lis/core/LIS_numerRecipesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_openwater_FTable.c b/lis/core/LIS_openwater_FTable.c index 264af3f02..cdeda93b9 100644 --- a/lis/core/LIS_openwater_FTable.c +++ b/lis/core/LIS_openwater_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_openwatermodelMod.F90 b/lis/core/LIS_openwatermodelMod.F90 index 2ccdf43d7..839abbce1 100644 --- a/lis/core/LIS_openwatermodelMod.F90 +++ b/lis/core/LIS_openwatermodelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_optUEMod.F90 b/lis/core/LIS_optUEMod.F90 index 19549341f..d638798df 100755 --- a/lis/core/LIS_optUEMod.F90 +++ b/lis/core/LIS_optUEMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_optUE_FTable.c b/lis/core/LIS_optUE_FTable.c index 35153c814..9f5fc225d 100755 --- a/lis/core/LIS_optUE_FTable.c +++ b/lis/core/LIS_optUE_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_paramsMod.F90 b/lis/core/LIS_paramsMod.F90 index 095fb9c5e..569c888b0 100644 --- a/lis/core/LIS_paramsMod.F90 +++ b/lis/core/LIS_paramsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_perturbMod.F90 b/lis/core/LIS_perturbMod.F90 index 1f5d097f8..bf603deca 100644 --- a/lis/core/LIS_perturbMod.F90 +++ b/lis/core/LIS_perturbMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_perturb_FTable.c b/lis/core/LIS_perturb_FTable.c index 827dcae8c..d9c1e12a7 100644 --- a/lis/core/LIS_perturb_FTable.c +++ b/lis/core/LIS_perturb_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_precisionMod.F90 b/lis/core/LIS_precisionMod.F90 index e29c66510..00da2e61b 100644 --- a/lis/core/LIS_precisionMod.F90 +++ b/lis/core/LIS_precisionMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_process_cmd_args.F90 b/lis/core/LIS_process_cmd_args.F90 index 270195020..44e1c1244 100644 --- a/lis/core/LIS_process_cmd_args.F90 +++ b/lis/core/LIS_process_cmd_args.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_ran2_gasdev.F90 b/lis/core/LIS_ran2_gasdev.F90 index 0ad111881..2833c94d9 100644 --- a/lis/core/LIS_ran2_gasdev.F90 +++ b/lis/core/LIS_ran2_gasdev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_readConfig.F90 b/lis/core/LIS_readConfig.F90 index 072060707..5ed1627d1 100644 --- a/lis/core/LIS_readConfig.F90 +++ b/lis/core/LIS_readConfig.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_readDAObsAttributes.F90 b/lis/core/LIS_readDAObsAttributes.F90 index b56c75f36..86fdd45d6 100644 --- a/lis/core/LIS_readDAObsAttributes.F90 +++ b/lis/core/LIS_readDAObsAttributes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_readPEDecSpaceAttributes.F90 b/lis/core/LIS_readPEDecSpaceAttributes.F90 index 476c9b857..67c83b1c1 100644 --- a/lis/core/LIS_readPEDecSpaceAttributes.F90 +++ b/lis/core/LIS_readPEDecSpaceAttributes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_roughness_FTable.c b/lis/core/LIS_roughness_FTable.c index 3ae81d1a6..2362550b2 100644 --- a/lis/core/LIS_roughness_FTable.c +++ b/lis/core/LIS_roughness_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_routingMod.F90 b/lis/core/LIS_routingMod.F90 index 1393e8eb9..cfcf172c3 100644 --- a/lis/core/LIS_routingMod.F90 +++ b/lis/core/LIS_routingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_routing_FTable.c b/lis/core/LIS_routing_FTable.c index 69a868970..d4c65b336 100644 --- a/lis/core/LIS_routing_FTable.c +++ b/lis/core/LIS_routing_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_runmode_FTable.c b/lis/core/LIS_runmode_FTable.c index af18bb974..484872587 100644 --- a/lis/core/LIS_runmode_FTable.c +++ b/lis/core/LIS_runmode_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_runoffdata_FTable.c b/lis/core/LIS_runoffdata_FTable.c index 0f4dc26c9..7249c554a 100644 --- a/lis/core/LIS_runoffdata_FTable.c +++ b/lis/core/LIS_runoffdata_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_snowMod.F90 b/lis/core/LIS_snowMod.F90 index 7b1d25c51..31b701d16 100644 --- a/lis/core/LIS_snowMod.F90 +++ b/lis/core/LIS_snowMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_soilsMod.F90 b/lis/core/LIS_soilsMod.F90 index a542db448..c44f275c5 100644 --- a/lis/core/LIS_soilsMod.F90 +++ b/lis/core/LIS_soilsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_spatialDownscalingMod.F90 b/lis/core/LIS_spatialDownscalingMod.F90 index 886371b69..efb2511e5 100644 --- a/lis/core/LIS_spatialDownscalingMod.F90 +++ b/lis/core/LIS_spatialDownscalingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_sublsm_FTable.c b/lis/core/LIS_sublsm_FTable.c index 5103e4a81..3cf5db8c4 100644 --- a/lis/core/LIS_sublsm_FTable.c +++ b/lis/core/LIS_sublsm_FTable.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_surfaceModelDataMod.F90 b/lis/core/LIS_surfaceModelDataMod.F90 index e1b980d53..074642a53 100644 --- a/lis/core/LIS_surfaceModelDataMod.F90 +++ b/lis/core/LIS_surfaceModelDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_surfaceModelMod.F90 b/lis/core/LIS_surfaceModelMod.F90 index d556913aa..0839ea430 100644 --- a/lis/core/LIS_surfaceModelMod.F90 +++ b/lis/core/LIS_surfaceModelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_tbotAdjustMod.F90 b/lis/core/LIS_tbotAdjustMod.F90 index c6610e358..287854d9f 100644 --- a/lis/core/LIS_tbotAdjustMod.F90 +++ b/lis/core/LIS_tbotAdjustMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_timeMgrMod.F90 b/lis/core/LIS_timeMgrMod.F90 index 4fda9f7e5..b11bb6e9f 100644 --- a/lis/core/LIS_timeMgrMod.F90 +++ b/lis/core/LIS_timeMgrMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_topoMod.F90 b/lis/core/LIS_topoMod.F90 index 81255d48f..8118a43b3 100644 --- a/lis/core/LIS_topoMod.F90 +++ b/lis/core/LIS_topoMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/LIS_vegDataMod.F90 b/lis/core/LIS_vegDataMod.F90 index ec5adf3cd..1ccf3eaf9 100644 --- a/lis/core/LIS_vegDataMod.F90 +++ b/lis/core/LIS_vegDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/fbil_module.F90 b/lis/core/fbil_module.F90 index 29acba2e8..21d4e3dae 100644 --- a/lis/core/fbil_module.F90 +++ b/lis/core/fbil_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/readzipf.c b/lis/core/readzipf.c index 5af14f8c8..b2781c0da 100644 --- a/lis/core/readzipf.c +++ b/lis/core/readzipf.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/xmrg_read_data_c.c b/lis/core/xmrg_read_data_c.c index c35130166..4ee5c7681 100644 --- a/lis/core/xmrg_read_data_c.c +++ b/lis/core/xmrg_read_data_c.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/xmrg_read_header_c.c b/lis/core/xmrg_read_header_c.c index 10d20944d..db31b0c38 100644 --- a/lis/core/xmrg_read_header_c.c +++ b/lis/core/xmrg_read_header_c.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/xmrg_reverse_byte.c b/lis/core/xmrg_reverse_byte.c index b1406a6b1..dcf0f013b 100644 --- a/lis/core/xmrg_reverse_byte.c +++ b/lis/core/xmrg_reverse_byte.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/core/xmrg_reverse_byte.h b/lis/core/xmrg_reverse_byte.h index b007ba7be..cb484be66 100644 --- a/lis/core/xmrg_reverse_byte.h +++ b/lis/core/xmrg_reverse_byte.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/0Intro_algorithms.txt b/lis/dataassim/algorithm/0Intro_algorithms.txt index d925c057c..d705e75d1 100644 --- a/lis/dataassim/algorithm/0Intro_algorithms.txt +++ b/lis/dataassim/algorithm/0Intro_algorithms.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/di/0Intro_di.txt b/lis/dataassim/algorithm/di/0Intro_di.txt index 57240fb24..b87556bb8 100644 --- a/lis/dataassim/algorithm/di/0Intro_di.txt +++ b/lis/dataassim/algorithm/di/0Intro_di.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/di/directInsertion_Mod.F90 b/lis/dataassim/algorithm/di/directInsertion_Mod.F90 index 8baa2517d..aa058d1df 100644 --- a/lis/dataassim/algorithm/di/directInsertion_Mod.F90 +++ b/lis/dataassim/algorithm/di/directInsertion_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/ekf/ekf_Mod.F90 b/lis/dataassim/algorithm/ekf/ekf_Mod.F90 index 71c9c24ce..c73e28a53 100644 --- a/lis/dataassim/algorithm/ekf/ekf_Mod.F90 +++ b/lis/dataassim/algorithm/ekf/ekf_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/0Intro_gmaoenkf.txt b/lis/dataassim/algorithm/enkf/0Intro_gmaoenkf.txt index 13444503a..3e0bbe997 100644 --- a/lis/dataassim/algorithm/enkf/0Intro_gmaoenkf.txt +++ b/lis/dataassim/algorithm/enkf/0Intro_gmaoenkf.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/enkf_Mod.F90 b/lis/dataassim/algorithm/enkf/enkf_Mod.F90 index 5e025fd96..afd733b42 100644 --- a/lis/dataassim/algorithm/enkf/enkf_Mod.F90 +++ b/lis/dataassim/algorithm/enkf/enkf_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/enkf_general.F90 b/lis/dataassim/algorithm/enkf/enkf_general.F90 index fceedb862..d94c011e4 100644 --- a/lis/dataassim/algorithm/enkf/enkf_general.F90 +++ b/lis/dataassim/algorithm/enkf/enkf_general.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/enkf_types.F90 b/lis/dataassim/algorithm/enkf/enkf_types.F90 index 23f267c19..21f6fed75 100644 --- a/lis/dataassim/algorithm/enkf/enkf_types.F90 +++ b/lis/dataassim/algorithm/enkf/enkf_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/gmaoenkf_module.F90.public b/lis/dataassim/algorithm/enkf/gmaoenkf_module.F90.public index e58d84a1d..e34dfa00a 100755 --- a/lis/dataassim/algorithm/enkf/gmaoenkf_module.F90.public +++ b/lis/dataassim/algorithm/enkf/gmaoenkf_module.F90.public @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/my_lu_decomp.F90 b/lis/dataassim/algorithm/enkf/my_lu_decomp.F90 index 8c9761614..7937838fe 100644 --- a/lis/dataassim/algorithm/enkf/my_lu_decomp.F90 +++ b/lis/dataassim/algorithm/enkf/my_lu_decomp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/my_matrix_functions.F90 b/lis/dataassim/algorithm/enkf/my_matrix_functions.F90 index eca124bc0..2a915fdaa 100644 --- a/lis/dataassim/algorithm/enkf/my_matrix_functions.F90 +++ b/lis/dataassim/algorithm/enkf/my_matrix_functions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enkf/nr_sort.F90 b/lis/dataassim/algorithm/enkf/nr_sort.F90 index eebb31bd1..8198ee809 100644 --- a/lis/dataassim/algorithm/enkf/nr_sort.F90 +++ b/lis/dataassim/algorithm/enkf/nr_sort.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/enks_general.F90 b/lis/dataassim/algorithm/enksgrace/enks_general.F90 index 8fd9f31df..ff73e9165 100644 --- a/lis/dataassim/algorithm/enksgrace/enks_general.F90 +++ b/lis/dataassim/algorithm/enksgrace/enks_general.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/enks_lu_decomp.F90 b/lis/dataassim/algorithm/enksgrace/enks_lu_decomp.F90 index e17c53a87..6b3ded8b4 100644 --- a/lis/dataassim/algorithm/enksgrace/enks_lu_decomp.F90 +++ b/lis/dataassim/algorithm/enksgrace/enks_lu_decomp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/enks_matrix_functions.F90 b/lis/dataassim/algorithm/enksgrace/enks_matrix_functions.F90 index eefe1b0df..f589b272b 100644 --- a/lis/dataassim/algorithm/enksgrace/enks_matrix_functions.F90 +++ b/lis/dataassim/algorithm/enksgrace/enks_matrix_functions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/enks_types.F90 b/lis/dataassim/algorithm/enksgrace/enks_types.F90 index 7125a5d28..63652e7d5 100644 --- a/lis/dataassim/algorithm/enksgrace/enks_types.F90 +++ b/lis/dataassim/algorithm/enksgrace/enks_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/enksgrace_Mod.F90 b/lis/dataassim/algorithm/enksgrace/enksgrace_Mod.F90 index c13e91078..48db84d36 100644 --- a/lis/dataassim/algorithm/enksgrace/enksgrace_Mod.F90 +++ b/lis/dataassim/algorithm/enksgrace/enksgrace_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/nr_fft.F90 b/lis/dataassim/algorithm/enksgrace/nr_fft.F90 index e66365ef8..0c8f6f502 100644 --- a/lis/dataassim/algorithm/enksgrace/nr_fft.F90 +++ b/lis/dataassim/algorithm/enksgrace/nr_fft.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/enksgrace/random_fields.F90.old b/lis/dataassim/algorithm/enksgrace/random_fields.F90.old index 24282ba63..308869666 100644 --- a/lis/dataassim/algorithm/enksgrace/random_fields.F90.old +++ b/lis/dataassim/algorithm/enksgrace/random_fields.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/ensrf/ensrf_Mod.F90 b/lis/dataassim/algorithm/ensrf/ensrf_Mod.F90 index 28ddc5e92..68e6cae2d 100644 --- a/lis/dataassim/algorithm/ensrf/ensrf_Mod.F90 +++ b/lis/dataassim/algorithm/ensrf/ensrf_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/ensrf/ensrf_general.F90 b/lis/dataassim/algorithm/ensrf/ensrf_general.F90 index cf4699dd1..b3a433c87 100644 --- a/lis/dataassim/algorithm/ensrf/ensrf_general.F90 +++ b/lis/dataassim/algorithm/ensrf/ensrf_general.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/ensrf/ensrf_types.F90 b/lis/dataassim/algorithm/ensrf/ensrf_types.F90 index b14cb7db4..cafb99a3f 100644 --- a/lis/dataassim/algorithm/ensrf/ensrf_types.F90 +++ b/lis/dataassim/algorithm/ensrf/ensrf_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/pf/pf_Mod.F90 b/lis/dataassim/algorithm/pf/pf_Mod.F90 index 1d45cceba..d668e604e 100644 --- a/lis/dataassim/algorithm/pf/pf_Mod.F90 +++ b/lis/dataassim/algorithm/pf/pf_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/pf/pf_general.F90 b/lis/dataassim/algorithm/pf/pf_general.F90 index 8efe0b8bd..af128e4a7 100644 --- a/lis/dataassim/algorithm/pf/pf_general.F90 +++ b/lis/dataassim/algorithm/pf/pf_general.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/algorithm/pf/pf_types.F90 b/lis/dataassim/algorithm/pf/pf_types.F90 index 769dc0797..02005c8fc 100644 --- a/lis/dataassim/algorithm/pf/pf_types.F90 +++ b/lis/dataassim/algorithm/pf/pf_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/biasEstimation/0Intro_biasest.txt b/lis/dataassim/biasEstimation/0Intro_biasest.txt index 1d8949746..5d02bd375 100644 --- a/lis/dataassim/biasEstimation/0Intro_biasest.txt +++ b/lis/dataassim/biasEstimation/0Intro_biasest.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/biasEstimation/gmaoBE/gmaobias_estimationMod.F90 b/lis/dataassim/biasEstimation/gmaoBE/gmaobias_estimationMod.F90 index c22f4cdc1..29181f5f5 100644 --- a/lis/dataassim/biasEstimation/gmaoBE/gmaobias_estimationMod.F90 +++ b/lis/dataassim/biasEstimation/gmaoBE/gmaobias_estimationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/0Intro_obs.txt b/lis/dataassim/obs/0Intro_obs.txt index 2133cca89..c63d2c8ae 100644 --- a/lis/dataassim/obs/0Intro_obs.txt +++ b/lis/dataassim/obs/0Intro_obs.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/AMSRE_SWE/AMSRE_SWE_Mod.F90 b/lis/dataassim/obs/AMSRE_SWE/AMSRE_SWE_Mod.F90 index f2d773e9c..0f26a1519 100644 --- a/lis/dataassim/obs/AMSRE_SWE/AMSRE_SWE_Mod.F90 +++ b/lis/dataassim/obs/AMSRE_SWE/AMSRE_SWE_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/AMSRE_SWE/read_AMSRE_SWE.F90 b/lis/dataassim/obs/AMSRE_SWE/read_AMSRE_SWE.F90 index e868c878a..f07fc1aba 100644 --- a/lis/dataassim/obs/AMSRE_SWE/read_AMSRE_SWE.F90 +++ b/lis/dataassim/obs/AMSRE_SWE/read_AMSRE_SWE.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/AMSRE_SWE/write_AMSRE_SWEobs.F90 b/lis/dataassim/obs/AMSRE_SWE/write_AMSRE_SWEobs.F90 index 28d79eaee..97fc07741 100644 --- a/lis/dataassim/obs/AMSRE_SWE/write_AMSRE_SWEobs.F90 +++ b/lis/dataassim/obs/AMSRE_SWE/write_AMSRE_SWEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SCF/0Intro_ansascf.txt b/lis/dataassim/obs/ANSA_SCF/0Intro_ansascf.txt index 1dd134778..df38845d1 100644 --- a/lis/dataassim/obs/ANSA_SCF/0Intro_ansascf.txt +++ b/lis/dataassim/obs/ANSA_SCF/0Intro_ansascf.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SCF/ANSASCFsnow_Mod.F90 b/lis/dataassim/obs/ANSA_SCF/ANSASCFsnow_Mod.F90 index f43157d0e..3e06cf0d2 100644 --- a/lis/dataassim/obs/ANSA_SCF/ANSASCFsnow_Mod.F90 +++ b/lis/dataassim/obs/ANSA_SCF/ANSASCFsnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SCF/read_ANSASCFsnow.F90 b/lis/dataassim/obs/ANSA_SCF/read_ANSASCFsnow.F90 index 11462afbf..76974389c 100644 --- a/lis/dataassim/obs/ANSA_SCF/read_ANSASCFsnow.F90 +++ b/lis/dataassim/obs/ANSA_SCF/read_ANSASCFsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SCF/write_ANSASCFsnow.F90 b/lis/dataassim/obs/ANSA_SCF/write_ANSASCFsnow.F90 index ed8fdec78..98723f86b 100644 --- a/lis/dataassim/obs/ANSA_SCF/write_ANSASCFsnow.F90 +++ b/lis/dataassim/obs/ANSA_SCF/write_ANSASCFsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SNWD/ANSASNWDsnow_Mod.F90 b/lis/dataassim/obs/ANSA_SNWD/ANSASNWDsnow_Mod.F90 index 718c6fab0..c28bf876f 100644 --- a/lis/dataassim/obs/ANSA_SNWD/ANSASNWDsnow_Mod.F90 +++ b/lis/dataassim/obs/ANSA_SNWD/ANSASNWDsnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SNWD/read_ANSASNWDsnow.F90 b/lis/dataassim/obs/ANSA_SNWD/read_ANSASNWDsnow.F90 index bf9abab7f..4562d7dfc 100644 --- a/lis/dataassim/obs/ANSA_SNWD/read_ANSASNWDsnow.F90 +++ b/lis/dataassim/obs/ANSA_SNWD/read_ANSASNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SNWD/write_ANSASNWDsnow.F90 b/lis/dataassim/obs/ANSA_SNWD/write_ANSASNWDsnow.F90 index 3068ab333..54f67e6a3 100644 --- a/lis/dataassim/obs/ANSA_SNWD/write_ANSASNWDsnow.F90 +++ b/lis/dataassim/obs/ANSA_SNWD/write_ANSASNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SWE/ANSASWEsnow_Mod.F90 b/lis/dataassim/obs/ANSA_SWE/ANSASWEsnow_Mod.F90 index 8384749cc..71e80bc67 100644 --- a/lis/dataassim/obs/ANSA_SWE/ANSASWEsnow_Mod.F90 +++ b/lis/dataassim/obs/ANSA_SWE/ANSASWEsnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SWE/read_ANSASWEsnow.F90 b/lis/dataassim/obs/ANSA_SWE/read_ANSASWEsnow.F90 index 343584ca8..70279d7d7 100644 --- a/lis/dataassim/obs/ANSA_SWE/read_ANSASWEsnow.F90 +++ b/lis/dataassim/obs/ANSA_SWE/read_ANSASWEsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ANSA_SWE/write_ANSASWEsnow.F90 b/lis/dataassim/obs/ANSA_SWE/write_ANSASWEsnow.F90 index b69ab04e8..bb3d2d43d 100644 --- a/lis/dataassim/obs/ANSA_SWE/write_ANSASWEsnow.F90 +++ b/lis/dataassim/obs/ANSA_SWE/write_ANSASWEsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASCAT_TUW/ASCAT_TUWsm_Mod.F90 b/lis/dataassim/obs/ASCAT_TUW/ASCAT_TUWsm_Mod.F90 index bd1f49d45..9e6abd2ec 100644 --- a/lis/dataassim/obs/ASCAT_TUW/ASCAT_TUWsm_Mod.F90 +++ b/lis/dataassim/obs/ASCAT_TUW/ASCAT_TUWsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASCAT_TUW/read_ASCAT_TUWsm.F90 b/lis/dataassim/obs/ASCAT_TUW/read_ASCAT_TUWsm.F90 index 5413b58eb..d23336e61 100644 --- a/lis/dataassim/obs/ASCAT_TUW/read_ASCAT_TUWsm.F90 +++ b/lis/dataassim/obs/ASCAT_TUW/read_ASCAT_TUWsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASCAT_TUW/write_ASCAT_TUWsmobs.F90 b/lis/dataassim/obs/ASCAT_TUW/write_ASCAT_TUWsmobs.F90 index b51335da5..b4d1a8f5d 100644 --- a/lis/dataassim/obs/ASCAT_TUW/write_ASCAT_TUWsmobs.F90 +++ b/lis/dataassim/obs/ASCAT_TUW/write_ASCAT_TUWsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASO_SWE/ASO_SWE_Mod.F90 b/lis/dataassim/obs/ASO_SWE/ASO_SWE_Mod.F90 index 9423f4e5b..28f95fbde 100755 --- a/lis/dataassim/obs/ASO_SWE/ASO_SWE_Mod.F90 +++ b/lis/dataassim/obs/ASO_SWE/ASO_SWE_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASO_SWE/read_ASO_SWE.F90 b/lis/dataassim/obs/ASO_SWE/read_ASO_SWE.F90 index ac5ce85fe..2bfb04eb2 100755 --- a/lis/dataassim/obs/ASO_SWE/read_ASO_SWE.F90 +++ b/lis/dataassim/obs/ASO_SWE/read_ASO_SWE.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ASO_SWE/write_ASO_SWEobs.F90 b/lis/dataassim/obs/ASO_SWE/write_ASO_SWEobs.F90 index a700f998d..e4191ca95 100755 --- a/lis/dataassim/obs/ASO_SWE/write_ASO_SWEobs.F90 +++ b/lis/dataassim/obs/ASO_SWE/write_ASO_SWEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDFS_GVF/CDFSgvf_Mod.F90 b/lis/dataassim/obs/CDFS_GVF/CDFSgvf_Mod.F90 index 05df435a9..2150d1b59 100644 --- a/lis/dataassim/obs/CDFS_GVF/CDFSgvf_Mod.F90 +++ b/lis/dataassim/obs/CDFS_GVF/CDFSgvf_Mod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDFS_GVF/read_CDFSgvf.F90 b/lis/dataassim/obs/CDFS_GVF/read_CDFSgvf.F90 index 4a42d45bf..1423f6f46 100644 --- a/lis/dataassim/obs/CDFS_GVF/read_CDFSgvf.F90 +++ b/lis/dataassim/obs/CDFS_GVF/read_CDFSgvf.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDFS_GVF/write_CDFSgvfobs.F90 b/lis/dataassim/obs/CDFS_GVF/write_CDFSgvfobs.F90 index d1835f74f..f8891bfda 100644 --- a/lis/dataassim/obs/CDFS_GVF/write_CDFSgvfobs.F90 +++ b/lis/dataassim/obs/CDFS_GVF/write_CDFSgvfobs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 index 875dd2207..2f0641188 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/cdfTransfer_NASASMAPsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 index d07c4df8c..0a8c597b8 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/read_cdfTransfer_NASASMAPsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 index 48aa3cbd7..e67e55e48 100644 --- a/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 +++ b/lis/dataassim/obs/CDF_Transfer_NASA_SMAPsm/write_cdfTransfer_NASASMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ESACCI_sm/ESACCI_sm_Mod.F90 b/lis/dataassim/obs/ESACCI_sm/ESACCI_sm_Mod.F90 index e7d757c16..7b9d8ce83 100644 --- a/lis/dataassim/obs/ESACCI_sm/ESACCI_sm_Mod.F90 +++ b/lis/dataassim/obs/ESACCI_sm/ESACCI_sm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ESACCI_sm/read_ESACCIsm.F90 b/lis/dataassim/obs/ESACCI_sm/read_ESACCIsm.F90 index 0f8480e5f..ca8fd23eb 100644 --- a/lis/dataassim/obs/ESACCI_sm/read_ESACCIsm.F90 +++ b/lis/dataassim/obs/ESACCI_sm/read_ESACCIsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ESACCI_sm/write_ESACCIsmobs.F90 b/lis/dataassim/obs/ESACCI_sm/write_ESACCIsmobs.F90 index 87d72b78b..c21f0d9ce 100644 --- a/lis/dataassim/obs/ESACCI_sm/write_ESACCIsmobs.F90 +++ b/lis/dataassim/obs/ESACCI_sm/write_ESACCIsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3SND/GCOMW_AMSR2L3SND_Mod.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3SND/GCOMW_AMSR2L3SND_Mod.F90 index bbf4259fa..e2ca6ecf9 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3SND/GCOMW_AMSR2L3SND_Mod.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3SND/GCOMW_AMSR2L3SND_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3SND/read_GCOMW_AMSR2L3SND.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3SND/read_GCOMW_AMSR2L3SND.F90 index 690f69c2d..9c532094e 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3SND/read_GCOMW_AMSR2L3SND.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3SND/read_GCOMW_AMSR2L3SND.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3SND/write_GCOMW_AMSR2L3SNDobs.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3SND/write_GCOMW_AMSR2L3SNDobs.F90 index 40c56f2fc..1f1395764 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3SND/write_GCOMW_AMSR2L3SNDobs.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3SND/write_GCOMW_AMSR2L3SNDobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_Mod.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_Mod.F90 index 1772cc261..57ed492bc 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_Mod.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3sm/GCOMW_AMSR2L3sm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3sm/read_GCOMW_AMSR2L3sm.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3sm/read_GCOMW_AMSR2L3sm.F90 index b038e2001..544bb08ee 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3sm/read_GCOMW_AMSR2L3sm.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3sm/read_GCOMW_AMSR2L3sm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GCOMW_AMSR2L3sm/write_GCOMW_AMSR2L3smobs.F90 b/lis/dataassim/obs/GCOMW_AMSR2L3sm/write_GCOMW_AMSR2L3smobs.F90 index a1a953e93..2b268ac76 100644 --- a/lis/dataassim/obs/GCOMW_AMSR2L3sm/write_GCOMW_AMSR2L3smobs.F90 +++ b/lis/dataassim/obs/GCOMW_AMSR2L3sm/write_GCOMW_AMSR2L3smobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_Albedo/GLASSalbedo_Mod.F90 b/lis/dataassim/obs/GLASS_Albedo/GLASSalbedo_Mod.F90 index 048629f91..cfd3f6718 100644 --- a/lis/dataassim/obs/GLASS_Albedo/GLASSalbedo_Mod.F90 +++ b/lis/dataassim/obs/GLASS_Albedo/GLASSalbedo_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_Albedo/read_GLASSalbedo.F90 b/lis/dataassim/obs/GLASS_Albedo/read_GLASSalbedo.F90 index 7a1e57ef5..588e0c8e3 100644 --- a/lis/dataassim/obs/GLASS_Albedo/read_GLASSalbedo.F90 +++ b/lis/dataassim/obs/GLASS_Albedo/read_GLASSalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_Albedo/write_GLASSalbedo.F90 b/lis/dataassim/obs/GLASS_Albedo/write_GLASSalbedo.F90 index 3b080780b..893d7e869 100644 --- a/lis/dataassim/obs/GLASS_Albedo/write_GLASSalbedo.F90 +++ b/lis/dataassim/obs/GLASS_Albedo/write_GLASSalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_LAI/GLASSlai_Mod.F90 b/lis/dataassim/obs/GLASS_LAI/GLASSlai_Mod.F90 index 9296bb665..56d350082 100644 --- a/lis/dataassim/obs/GLASS_LAI/GLASSlai_Mod.F90 +++ b/lis/dataassim/obs/GLASS_LAI/GLASSlai_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_LAI/read_GLASSlai.F90 b/lis/dataassim/obs/GLASS_LAI/read_GLASSlai.F90 index dd8ce922f..460db2782 100644 --- a/lis/dataassim/obs/GLASS_LAI/read_GLASSlai.F90 +++ b/lis/dataassim/obs/GLASS_LAI/read_GLASSlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GLASS_LAI/write_GLASSlai.F90 b/lis/dataassim/obs/GLASS_LAI/write_GLASSlai.F90 index 01a5634a1..f5e881032 100644 --- a/lis/dataassim/obs/GLASS_LAI/write_GLASSlai.F90 +++ b/lis/dataassim/obs/GLASS_LAI/write_GLASSlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GRACE/GRACEobs_module.F90 b/lis/dataassim/obs/GRACE/GRACEobs_module.F90 index 54a172e8a..1514d2d67 100644 --- a/lis/dataassim/obs/GRACE/GRACEobs_module.F90 +++ b/lis/dataassim/obs/GRACE/GRACEobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GRACE/read_GRACEobs.F90 b/lis/dataassim/obs/GRACE/read_GRACEobs.F90 index c85988a04..2fe175aab 100644 --- a/lis/dataassim/obs/GRACE/read_GRACEobs.F90 +++ b/lis/dataassim/obs/GRACE/read_GRACEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/GRACE/write_GRACEobs.F90 b/lis/dataassim/obs/GRACE/write_GRACEobs.F90 index a1ba7b639..d4726aa71 100644 --- a/lis/dataassim/obs/GRACE/write_GRACEobs.F90 +++ b/lis/dataassim/obs/GRACE/write_GRACEobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/IMS_sca/IMSsca_mod.F90 b/lis/dataassim/obs/IMS_sca/IMSsca_mod.F90 index 779fb8829..b012c76f1 100644 --- a/lis/dataassim/obs/IMS_sca/IMSsca_mod.F90 +++ b/lis/dataassim/obs/IMS_sca/IMSsca_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/IMS_sca/read_IMSsca.F90 b/lis/dataassim/obs/IMS_sca/read_IMSsca.F90 index 847602964..41e3704ea 100644 --- a/lis/dataassim/obs/IMS_sca/read_IMSsca.F90 +++ b/lis/dataassim/obs/IMS_sca/read_IMSsca.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/IMS_sca/write_IMSscaobs.F90 b/lis/dataassim/obs/IMS_sca/write_IMSscaobs.F90 index 708da6645..ba98aff99 100644 --- a/lis/dataassim/obs/IMS_sca/write_IMSscaobs.F90 +++ b/lis/dataassim/obs/IMS_sca/write_IMSscaobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ISCCP_Tskin/ISCCP_Tskin_module.F90 b/lis/dataassim/obs/ISCCP_Tskin/ISCCP_Tskin_module.F90 index 10eb2f898..88f711222 100644 --- a/lis/dataassim/obs/ISCCP_Tskin/ISCCP_Tskin_module.F90 +++ b/lis/dataassim/obs/ISCCP_Tskin/ISCCP_Tskin_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ISCCP_Tskin/read_ISCCP_Tskin.F90 b/lis/dataassim/obs/ISCCP_Tskin/read_ISCCP_Tskin.F90 index 46ae4129a..072dcc746 100644 --- a/lis/dataassim/obs/ISCCP_Tskin/read_ISCCP_Tskin.F90 +++ b/lis/dataassim/obs/ISCCP_Tskin/read_ISCCP_Tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/ISCCP_Tskin/write_ISCCP_Tskin.F90 b/lis/dataassim/obs/ISCCP_Tskin/write_ISCCP_Tskin.F90 index c51b2efbc..1de5d41cd 100644 --- a/lis/dataassim/obs/ISCCP_Tskin/write_ISCCP_Tskin.F90 +++ b/lis/dataassim/obs/ISCCP_Tskin/write_ISCCP_Tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/LPRM_AMSREsm/LPRM_AMSREsm_Mod.F90 b/lis/dataassim/obs/LPRM_AMSREsm/LPRM_AMSREsm_Mod.F90 index f0d9579ad..2ed18b44f 100644 --- a/lis/dataassim/obs/LPRM_AMSREsm/LPRM_AMSREsm_Mod.F90 +++ b/lis/dataassim/obs/LPRM_AMSREsm/LPRM_AMSREsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/LPRM_AMSREsm/read_LPRM_AMSREsm.F90 b/lis/dataassim/obs/LPRM_AMSREsm/read_LPRM_AMSREsm.F90 index 313c4a778..6eb11bd0f 100644 --- a/lis/dataassim/obs/LPRM_AMSREsm/read_LPRM_AMSREsm.F90 +++ b/lis/dataassim/obs/LPRM_AMSREsm/read_LPRM_AMSREsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/LPRM_AMSREsm/write_LPRM_AMSREsmobs.F90 b/lis/dataassim/obs/LPRM_AMSREsm/write_LPRM_AMSREsmobs.F90 index 772e9fcb0..2194b663c 100644 --- a/lis/dataassim/obs/LPRM_AMSREsm/write_LPRM_AMSREsmobs.F90 +++ b/lis/dataassim/obs/LPRM_AMSREsm/write_LPRM_AMSREsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MCD15A2H_LAI/MCD15A2Hlai_Mod.F90 b/lis/dataassim/obs/MCD15A2H_LAI/MCD15A2Hlai_Mod.F90 index c2fd6a1c6..121aef196 100755 --- a/lis/dataassim/obs/MCD15A2H_LAI/MCD15A2Hlai_Mod.F90 +++ b/lis/dataassim/obs/MCD15A2H_LAI/MCD15A2Hlai_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MCD15A2H_LAI/read_MCD15A2Hlai.F90 b/lis/dataassim/obs/MCD15A2H_LAI/read_MCD15A2Hlai.F90 index 418c9b3ab..846df80d2 100755 --- a/lis/dataassim/obs/MCD15A2H_LAI/read_MCD15A2Hlai.F90 +++ b/lis/dataassim/obs/MCD15A2H_LAI/read_MCD15A2Hlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MCD15A2H_LAI/write_MCD15A2Hlai.F90 b/lis/dataassim/obs/MCD15A2H_LAI/write_MCD15A2Hlai.F90 index bac4a3ef7..850c4115a 100755 --- a/lis/dataassim/obs/MCD15A2H_LAI/write_MCD15A2Hlai.F90 +++ b/lis/dataassim/obs/MCD15A2H_LAI/write_MCD15A2Hlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODIS_SPORT_LAI/MODISsportLAI_Mod.F90 b/lis/dataassim/obs/MODIS_SPORT_LAI/MODISsportLAI_Mod.F90 index 0f8a31929..05d5bfba6 100644 --- a/lis/dataassim/obs/MODIS_SPORT_LAI/MODISsportLAI_Mod.F90 +++ b/lis/dataassim/obs/MODIS_SPORT_LAI/MODISsportLAI_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODIS_SPORT_LAI/read_MODISsportLAI.F90 b/lis/dataassim/obs/MODIS_SPORT_LAI/read_MODISsportLAI.F90 index b219828c2..25e4df6e7 100644 --- a/lis/dataassim/obs/MODIS_SPORT_LAI/read_MODISsportLAI.F90 +++ b/lis/dataassim/obs/MODIS_SPORT_LAI/read_MODISsportLAI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODIS_SPORT_LAI/write_MODISsportLAI.F90 b/lis/dataassim/obs/MODIS_SPORT_LAI/write_MODISsportLAI.F90 index 15fb93f94..3a007e582 100644 --- a/lis/dataassim/obs/MODIS_SPORT_LAI/write_MODISsportLAI.F90 +++ b/lis/dataassim/obs/MODIS_SPORT_LAI/write_MODISsportLAI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODISsca/0Intro_modissca.txt b/lis/dataassim/obs/MODISsca/0Intro_modissca.txt index b0dbe9cab..77dbd8dbe 100644 --- a/lis/dataassim/obs/MODISsca/0Intro_modissca.txt +++ b/lis/dataassim/obs/MODISsca/0Intro_modissca.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODISsca/MODISscaobs_module.F90 b/lis/dataassim/obs/MODISsca/MODISscaobs_module.F90 index 99076f432..59c33d06f 100644 --- a/lis/dataassim/obs/MODISsca/MODISscaobs_module.F90 +++ b/lis/dataassim/obs/MODISsca/MODISscaobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODISsca/read_MODISscaobs.F90 b/lis/dataassim/obs/MODISsca/read_MODISscaobs.F90 index 2cb20f02b..4d6cc7f99 100644 --- a/lis/dataassim/obs/MODISsca/read_MODISscaobs.F90 +++ b/lis/dataassim/obs/MODISsca/read_MODISscaobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/MODISsca/write_MODISsca.F90 b/lis/dataassim/obs/MODISsca/write_MODISsca.F90 index 1f9c063c0..2a922508b 100644 --- a/lis/dataassim/obs/MODISsca/write_MODISsca.F90 +++ b/lis/dataassim/obs/MODISsca/write_MODISsca.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_AMSREsm/0Intro_nasaamsre.txt b/lis/dataassim/obs/NASA_AMSREsm/0Intro_nasaamsre.txt index c63254ff3..0d88ebe43 100644 --- a/lis/dataassim/obs/NASA_AMSREsm/0Intro_nasaamsre.txt +++ b/lis/dataassim/obs/NASA_AMSREsm/0Intro_nasaamsre.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_AMSREsm/NASA_AMSREsm_Mod.F90 b/lis/dataassim/obs/NASA_AMSREsm/NASA_AMSREsm_Mod.F90 index f3b5a7756..aba594355 100644 --- a/lis/dataassim/obs/NASA_AMSREsm/NASA_AMSREsm_Mod.F90 +++ b/lis/dataassim/obs/NASA_AMSREsm/NASA_AMSREsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_AMSREsm/read_NASA_AMSREsm.F90 b/lis/dataassim/obs/NASA_AMSREsm/read_NASA_AMSREsm.F90 index 18f7b647e..dc479dd81 100644 --- a/lis/dataassim/obs/NASA_AMSREsm/read_NASA_AMSREsm.F90 +++ b/lis/dataassim/obs/NASA_AMSREsm/read_NASA_AMSREsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_AMSREsm/write_NASA_AMSREsmobs.F90 b/lis/dataassim/obs/NASA_AMSREsm/write_NASA_AMSREsmobs.F90 index 506d41ca1..e5385c7fb 100644 --- a/lis/dataassim/obs/NASA_AMSREsm/write_NASA_AMSREsmobs.F90 +++ b/lis/dataassim/obs/NASA_AMSREsm/write_NASA_AMSREsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPsm/NASASMAPsm_Mod.F90 b/lis/dataassim/obs/NASA_SMAPsm/NASASMAPsm_Mod.F90 index b1623a59d..1e25325d3 100644 --- a/lis/dataassim/obs/NASA_SMAPsm/NASASMAPsm_Mod.F90 +++ b/lis/dataassim/obs/NASA_SMAPsm/NASASMAPsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPsm/read_NASASMAPsm.F90 b/lis/dataassim/obs/NASA_SMAPsm/read_NASASMAPsm.F90 index bc09f64ae..6022318da 100644 --- a/lis/dataassim/obs/NASA_SMAPsm/read_NASASMAPsm.F90 +++ b/lis/dataassim/obs/NASA_SMAPsm/read_NASASMAPsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPsm/write_NASASMAPsmobs.F90 b/lis/dataassim/obs/NASA_SMAPsm/write_NASASMAPsmobs.F90 index 41bbe7a56..86af0e4a2 100644 --- a/lis/dataassim/obs/NASA_SMAPsm/write_NASASMAPsmobs.F90 +++ b/lis/dataassim/obs/NASA_SMAPsm/write_NASASMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPvod/NASASMAPvod_Mod.F90 b/lis/dataassim/obs/NASA_SMAPvod/NASASMAPvod_Mod.F90 index 1d8a46104..d6aa14bcc 100644 --- a/lis/dataassim/obs/NASA_SMAPvod/NASASMAPvod_Mod.F90 +++ b/lis/dataassim/obs/NASA_SMAPvod/NASASMAPvod_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPvod/read_NASASMAPvod.F90 b/lis/dataassim/obs/NASA_SMAPvod/read_NASASMAPvod.F90 index 7c42ce63a..68efa597f 100644 --- a/lis/dataassim/obs/NASA_SMAPvod/read_NASASMAPvod.F90 +++ b/lis/dataassim/obs/NASA_SMAPvod/read_NASASMAPvod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/NASA_SMAPvod/write_NASASMAPvodobs.F90 b/lis/dataassim/obs/NASA_SMAPvod/write_NASASMAPvodobs.F90 index f996395c1..290be2181 100644 --- a/lis/dataassim/obs/NASA_SMAPvod/write_NASASMAPvodobs.F90 +++ b/lis/dataassim/obs/NASA_SMAPvod/write_NASASMAPvodobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/PMW_snow/0Intro_PMW_snow.txt b/lis/dataassim/obs/PMW_snow/0Intro_PMW_snow.txt index 7883d14a4..3f205fa6a 100755 --- a/lis/dataassim/obs/PMW_snow/0Intro_PMW_snow.txt +++ b/lis/dataassim/obs/PMW_snow/0Intro_PMW_snow.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/PMW_snow/PMW_snow_Mod.F90 b/lis/dataassim/obs/PMW_snow/PMW_snow_Mod.F90 index a510c2877..0a582c5d1 100755 --- a/lis/dataassim/obs/PMW_snow/PMW_snow_Mod.F90 +++ b/lis/dataassim/obs/PMW_snow/PMW_snow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/PMW_snow/read_PMW_snow.F90 b/lis/dataassim/obs/PMW_snow/read_PMW_snow.F90 index b73f21454..a979ee469 100755 --- a/lis/dataassim/obs/PMW_snow/read_PMW_snow.F90 +++ b/lis/dataassim/obs/PMW_snow/read_PMW_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/PMW_snow/write_PMW_snowobs.F90 b/lis/dataassim/obs/PMW_snow/write_PMW_snowobs.F90 index fc8d14c78..13a98b961 100755 --- a/lis/dataassim/obs/PMW_snow/write_PMW_snowobs.F90 +++ b/lis/dataassim/obs/PMW_snow/write_PMW_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/SMAPEOPLsm_Mod.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/SMAPEOPLsm_Mod.F90 index ada50c9f1..cba582eac 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/SMAPEOPLsm_Mod.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/SMAPEOPLsm_Mod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 index ee45b14d1..e7bba7a26 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/write_SMAPEOPLsmobs.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/write_SMAPEOPLsmobs.F90 index a1b1a948d..9654b1755 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/write_SMAPEOPLsmobs.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/write_SMAPEOPLsmobs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_NRTsm/SMAPNRTsm_Mod.F90 b/lis/dataassim/obs/SMAP_NRTsm/SMAPNRTsm_Mod.F90 index 076316fbf..5e4b98ba9 100755 --- a/lis/dataassim/obs/SMAP_NRTsm/SMAPNRTsm_Mod.F90 +++ b/lis/dataassim/obs/SMAP_NRTsm/SMAPNRTsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_NRTsm/create_filelist.c b/lis/dataassim/obs/SMAP_NRTsm/create_filelist.c index 77e9ff5c2..9768569ad 100644 --- a/lis/dataassim/obs/SMAP_NRTsm/create_filelist.c +++ b/lis/dataassim/obs/SMAP_NRTsm/create_filelist.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_NRTsm/read_SMAPNRTsm.F90 b/lis/dataassim/obs/SMAP_NRTsm/read_SMAPNRTsm.F90 index ebebe5ecf..07c15ac0c 100755 --- a/lis/dataassim/obs/SMAP_NRTsm/read_SMAPNRTsm.F90 +++ b/lis/dataassim/obs/SMAP_NRTsm/read_SMAPNRTsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMAP_NRTsm/write_SMAPNRTsmobs.F90 b/lis/dataassim/obs/SMAP_NRTsm/write_SMAPNRTsmobs.F90 index f0b66f24d..435e84f92 100755 --- a/lis/dataassim/obs/SMAP_NRTsm/write_SMAPNRTsmobs.F90 +++ b/lis/dataassim/obs/SMAP_NRTsm/write_SMAPNRTsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMMR_SNWD/SMMRSNWDsnow_Mod.F90 b/lis/dataassim/obs/SMMR_SNWD/SMMRSNWDsnow_Mod.F90 index d7b2ff9cf..db117d7b2 100644 --- a/lis/dataassim/obs/SMMR_SNWD/SMMRSNWDsnow_Mod.F90 +++ b/lis/dataassim/obs/SMMR_SNWD/SMMRSNWDsnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMMR_SNWD/read_SMMRSNWDsnow.F90 b/lis/dataassim/obs/SMMR_SNWD/read_SMMRSNWDsnow.F90 index 271ecfdc4..e93be3691 100644 --- a/lis/dataassim/obs/SMMR_SNWD/read_SMMRSNWDsnow.F90 +++ b/lis/dataassim/obs/SMMR_SNWD/read_SMMRSNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMMR_SNWD/write_SMMRSNWDsnow.F90 b/lis/dataassim/obs/SMMR_SNWD/write_SMMRSNWDsnow.F90 index cb48fd3b1..8819f976a 100644 --- a/lis/dataassim/obs/SMMR_SNWD/write_SMMRSNWDsnow.F90 +++ b/lis/dataassim/obs/SMMR_SNWD/write_SMMRSNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_AMSR2sm/SMOPS_AMSR2sm_Mod.F90 b/lis/dataassim/obs/SMOPS_AMSR2sm/SMOPS_AMSR2sm_Mod.F90 index 1eb06fe4c..4af9b1363 100755 --- a/lis/dataassim/obs/SMOPS_AMSR2sm/SMOPS_AMSR2sm_Mod.F90 +++ b/lis/dataassim/obs/SMOPS_AMSR2sm/SMOPS_AMSR2sm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90 b/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90 index b85046c00..c43a48a25 100755 --- a/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90 +++ b/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90.old b/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90.old index 60d1970a0..380f44324 100755 --- a/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90.old +++ b/lis/dataassim/obs/SMOPS_AMSR2sm/read_SMOPS_AMSR2sm.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_AMSR2sm/write_SMOPS_AMSR2smobs.F90 b/lis/dataassim/obs/SMOPS_AMSR2sm/write_SMOPS_AMSR2smobs.F90 index 4c9508d44..c1c18c646 100755 --- a/lis/dataassim/obs/SMOPS_AMSR2sm/write_SMOPS_AMSR2smobs.F90 +++ b/lis/dataassim/obs/SMOPS_AMSR2sm/write_SMOPS_AMSR2smobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_ASCATsm/SMOPS_ASCATsm_Mod.F90 b/lis/dataassim/obs/SMOPS_ASCATsm/SMOPS_ASCATsm_Mod.F90 index bcd2e8bab..a6bc95603 100755 --- a/lis/dataassim/obs/SMOPS_ASCATsm/SMOPS_ASCATsm_Mod.F90 +++ b/lis/dataassim/obs/SMOPS_ASCATsm/SMOPS_ASCATsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_ASCATsm/read_SMOPS_ASCATsm.F90 b/lis/dataassim/obs/SMOPS_ASCATsm/read_SMOPS_ASCATsm.F90 index 6ab989ec9..c1f382176 100755 --- a/lis/dataassim/obs/SMOPS_ASCATsm/read_SMOPS_ASCATsm.F90 +++ b/lis/dataassim/obs/SMOPS_ASCATsm/read_SMOPS_ASCATsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_ASCATsm/write_SMOPS_ASCATsmobs.F90 b/lis/dataassim/obs/SMOPS_ASCATsm/write_SMOPS_ASCATsmobs.F90 index 77b2aab8d..92398e6a9 100755 --- a/lis/dataassim/obs/SMOPS_ASCATsm/write_SMOPS_ASCATsmobs.F90 +++ b/lis/dataassim/obs/SMOPS_ASCATsm/write_SMOPS_ASCATsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90 b/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90 index 962e1b6c5..8e4603b71 100755 --- a/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90 +++ b/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90.old b/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90.old index b1b1185a1..6b31b933c 100755 --- a/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90.old +++ b/lis/dataassim/obs/SMOPS_SMAPsm/SMOPS_SMAPsm_Mod.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90 b/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90 index 0bdf6a63a..5ef01c296 100755 --- a/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90 +++ b/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90.old b/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90.old index 822ce5791..d7af58971 100755 --- a/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90.old +++ b/lis/dataassim/obs/SMOPS_SMAPsm/read_SMOPS_SMAPsm.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMAPsm/write_SMOPS_SMAPsmobs.F90 b/lis/dataassim/obs/SMOPS_SMAPsm/write_SMOPS_SMAPsmobs.F90 index f999d5c53..2e2fe725f 100755 --- a/lis/dataassim/obs/SMOPS_SMAPsm/write_SMOPS_SMAPsmobs.F90 +++ b/lis/dataassim/obs/SMOPS_SMAPsm/write_SMOPS_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMOSsm/SMOPS_SMOSsm_Mod.F90 b/lis/dataassim/obs/SMOPS_SMOSsm/SMOPS_SMOSsm_Mod.F90 index 80f9994f2..837dcb896 100755 --- a/lis/dataassim/obs/SMOPS_SMOSsm/SMOPS_SMOSsm_Mod.F90 +++ b/lis/dataassim/obs/SMOPS_SMOSsm/SMOPS_SMOSsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90 b/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90 index 50ba6dba8..22ee4fab8 100755 --- a/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90 +++ b/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90.old b/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90.old index 77d6da2d6..be936a5f4 100755 --- a/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90.old +++ b/lis/dataassim/obs/SMOPS_SMOSsm/read_SMOPS_SMOSsm.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOPS_SMOSsm/write_SMOPS_SMOSsmobs.F90 b/lis/dataassim/obs/SMOPS_SMOSsm/write_SMOPS_SMOSsmobs.F90 index 390617b6a..b4956ffeb 100755 --- a/lis/dataassim/obs/SMOPS_SMOSsm/write_SMOPS_SMOSsmobs.F90 +++ b/lis/dataassim/obs/SMOPS_SMOSsm/write_SMOPS_SMOSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_L2sm/SMOSL2sm_Mod.F90 b/lis/dataassim/obs/SMOS_L2sm/SMOSL2sm_Mod.F90 index 4a4cbf9ab..75e8bdef5 100644 --- a/lis/dataassim/obs/SMOS_L2sm/SMOSL2sm_Mod.F90 +++ b/lis/dataassim/obs/SMOS_L2sm/SMOSL2sm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_L2sm/read_SMOSL2sm.F90 b/lis/dataassim/obs/SMOS_L2sm/read_SMOSL2sm.F90 index 321d70d5c..b285861cc 100644 --- a/lis/dataassim/obs/SMOS_L2sm/read_SMOSL2sm.F90 +++ b/lis/dataassim/obs/SMOS_L2sm/read_SMOSL2sm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_L2sm/write_SMOSL2smobs.F90 b/lis/dataassim/obs/SMOS_L2sm/write_SMOSL2smobs.F90 index 127f4528d..bcfc49968 100644 --- a/lis/dataassim/obs/SMOS_L2sm/write_SMOSL2smobs.F90 +++ b/lis/dataassim/obs/SMOS_L2sm/write_SMOSL2smobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NESDIS/SMOSNESDISsm_Mod.F90 b/lis/dataassim/obs/SMOS_NESDIS/SMOSNESDISsm_Mod.F90 index 8c28c37fb..312774a7e 100644 --- a/lis/dataassim/obs/SMOS_NESDIS/SMOSNESDISsm_Mod.F90 +++ b/lis/dataassim/obs/SMOS_NESDIS/SMOSNESDISsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NESDIS/read_SMOSNESDISsm.F90 b/lis/dataassim/obs/SMOS_NESDIS/read_SMOSNESDISsm.F90 index 97aae6c0d..ee4de495c 100644 --- a/lis/dataassim/obs/SMOS_NESDIS/read_SMOSNESDISsm.F90 +++ b/lis/dataassim/obs/SMOS_NESDIS/read_SMOSNESDISsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NESDIS/write_SMOSNESDISsmobs.F90 b/lis/dataassim/obs/SMOS_NESDIS/write_SMOSNESDISsmobs.F90 index ec1122613..752372f25 100644 --- a/lis/dataassim/obs/SMOS_NESDIS/write_SMOSNESDISsmobs.F90 +++ b/lis/dataassim/obs/SMOS_NESDIS/write_SMOSNESDISsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_Mod.F90 b/lis/dataassim/obs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_Mod.F90 index 0b58b6af1..71ac96ac5 100644 --- a/lis/dataassim/obs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_Mod.F90 +++ b/lis/dataassim/obs/SMOS_NRTNN_L2sm/SMOSNRTNNL2sm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_SMOSNRTNNL2sm.F90 b/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_SMOSNRTNNL2sm.F90 index a3918cbbe..41fe0d2cc 100644 --- a/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_SMOSNRTNNL2sm.F90 +++ b/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_SMOSNRTNNL2sm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_dgg_lookup_table.F90 b/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_dgg_lookup_table.F90 index b554a9c58..39d70e26b 100644 --- a/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_dgg_lookup_table.F90 +++ b/lis/dataassim/obs/SMOS_NRTNN_L2sm/read_dgg_lookup_table.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SMOS_NRTNN_L2sm/write_SMOSNRTNNL2smobs.F90 b/lis/dataassim/obs/SMOS_NRTNN_L2sm/write_SMOSNRTNNL2smobs.F90 index 5ef2a45fa..5b0bc5ce5 100644 --- a/lis/dataassim/obs/SMOS_NRTNN_L2sm/write_SMOSNRTNNL2smobs.F90 +++ b/lis/dataassim/obs/SMOS_NRTNN_L2sm/write_SMOSNRTNNL2smobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODAS/SNODAS_Mod.F90 b/lis/dataassim/obs/SNODAS/SNODAS_Mod.F90 index d9864d730..799ded36e 100755 --- a/lis/dataassim/obs/SNODAS/SNODAS_Mod.F90 +++ b/lis/dataassim/obs/SNODAS/SNODAS_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODAS/read_SNODAS.F90 b/lis/dataassim/obs/SNODAS/read_SNODAS.F90 index 9e18673fb..f70415625 100755 --- a/lis/dataassim/obs/SNODAS/read_SNODAS.F90 +++ b/lis/dataassim/obs/SNODAS/read_SNODAS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODAS/write_SNODAS.F90 b/lis/dataassim/obs/SNODAS/write_SNODAS.F90 index 7161e9a79..57dd256b2 100755 --- a/lis/dataassim/obs/SNODAS/write_SNODAS.F90 +++ b/lis/dataassim/obs/SNODAS/write_SNODAS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODEP/SNODEPobs_Mod.F90 b/lis/dataassim/obs/SNODEP/SNODEPobs_Mod.F90 index f68935355..9bed12a9c 100644 --- a/lis/dataassim/obs/SNODEP/SNODEPobs_Mod.F90 +++ b/lis/dataassim/obs/SNODEP/SNODEPobs_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODEP/read_SNODEPobs.F90 b/lis/dataassim/obs/SNODEP/read_SNODEPobs.F90 index b191dac02..3841eb93c 100644 --- a/lis/dataassim/obs/SNODEP/read_SNODEPobs.F90 +++ b/lis/dataassim/obs/SNODEP/read_SNODEPobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SNODEP/write_SNODEPobs.F90 b/lis/dataassim/obs/SNODEP/write_SNODEPobs.F90 index b17bdec7a..371a04094 100644 --- a/lis/dataassim/obs/SNODEP/write_SNODEPobs.F90 +++ b/lis/dataassim/obs/SNODEP/write_SNODEPobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SSMI_SNWD/SSMISNWDsnow_Mod.F90 b/lis/dataassim/obs/SSMI_SNWD/SSMISNWDsnow_Mod.F90 index 0fe3be7d0..b5e5bfb05 100644 --- a/lis/dataassim/obs/SSMI_SNWD/SSMISNWDsnow_Mod.F90 +++ b/lis/dataassim/obs/SSMI_SNWD/SSMISNWDsnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SSMI_SNWD/read_SSMISNWDsnow.F90 b/lis/dataassim/obs/SSMI_SNWD/read_SSMISNWDsnow.F90 index 51cae7968..ccd82c0d4 100644 --- a/lis/dataassim/obs/SSMI_SNWD/read_SSMISNWDsnow.F90 +++ b/lis/dataassim/obs/SSMI_SNWD/read_SSMISNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SSMI_SNWD/write_SSMISNWDsnow.F90 b/lis/dataassim/obs/SSMI_SNWD/write_SSMISNWDsnow.F90 index 2777176c5..b006541c7 100644 --- a/lis/dataassim/obs/SSMI_SNWD/write_SSMISNWDsnow.F90 +++ b/lis/dataassim/obs/SSMI_SNWD/write_SSMISNWDsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SYN_LBAND_TB/SYN_LBAND_TB_Mod.F90 b/lis/dataassim/obs/SYN_LBAND_TB/SYN_LBAND_TB_Mod.F90 index 6bb02d647..f01fda03a 100644 --- a/lis/dataassim/obs/SYN_LBAND_TB/SYN_LBAND_TB_Mod.F90 +++ b/lis/dataassim/obs/SYN_LBAND_TB/SYN_LBAND_TB_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SYN_LBAND_TB/read_SYN_LBAND_TB.F90 b/lis/dataassim/obs/SYN_LBAND_TB/read_SYN_LBAND_TB.F90 index f7400d4eb..1fba808fc 100644 --- a/lis/dataassim/obs/SYN_LBAND_TB/read_SYN_LBAND_TB.F90 +++ b/lis/dataassim/obs/SYN_LBAND_TB/read_SYN_LBAND_TB.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/SYN_LBAND_TB/write_SYN_LBAND_TB.F90 b/lis/dataassim/obs/SYN_LBAND_TB/write_SYN_LBAND_TB.F90 index 076a11e75..6fd841614 100644 --- a/lis/dataassim/obs/SYN_LBAND_TB/write_SYN_LBAND_TB.F90 +++ b/lis/dataassim/obs/SYN_LBAND_TB/write_SYN_LBAND_TB.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/THySM/THySM_Mod.F90 b/lis/dataassim/obs/THySM/THySM_Mod.F90 index 2ce4b18c1..4d33ba397 100644 --- a/lis/dataassim/obs/THySM/THySM_Mod.F90 +++ b/lis/dataassim/obs/THySM/THySM_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/THySM/read_THySM.F90 b/lis/dataassim/obs/THySM/read_THySM.F90 index 0ab2e4fcc..5c085d0e8 100644 --- a/lis/dataassim/obs/THySM/read_THySM.F90 +++ b/lis/dataassim/obs/THySM/read_THySM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/THySM/write_THySM.F90 b/lis/dataassim/obs/THySM/write_THySM.F90 index 0d14d67e5..c0b2e6817 100644 --- a/lis/dataassim/obs/THySM/write_THySM.F90 +++ b/lis/dataassim/obs/THySM/write_THySM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/USAFSI/USAFSIobs_Mod.F90 b/lis/dataassim/obs/USAFSI/USAFSIobs_Mod.F90 index c5001481c..1f90e4101 100644 --- a/lis/dataassim/obs/USAFSI/USAFSIobs_Mod.F90 +++ b/lis/dataassim/obs/USAFSI/USAFSIobs_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/USAFSI/read_USAFSIobs.F90 b/lis/dataassim/obs/USAFSI/read_USAFSIobs.F90 index acbf18357..58f6a6982 100644 --- a/lis/dataassim/obs/USAFSI/read_USAFSIobs.F90 +++ b/lis/dataassim/obs/USAFSI/read_USAFSIobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/USAFSI/write_USAFSIobs.F90 b/lis/dataassim/obs/USAFSI/write_USAFSIobs.F90 index 2e326b39f..838e25755 100644 --- a/lis/dataassim/obs/USAFSI/write_USAFSIobs.F90 +++ b/lis/dataassim/obs/USAFSI/write_USAFSIobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/VIIRS_GVF/VIIRSgvf_Mod.F90 b/lis/dataassim/obs/VIIRS_GVF/VIIRSgvf_Mod.F90 index 059ae39d6..0c1744825 100644 --- a/lis/dataassim/obs/VIIRS_GVF/VIIRSgvf_Mod.F90 +++ b/lis/dataassim/obs/VIIRS_GVF/VIIRSgvf_Mod.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/VIIRS_GVF/read_VIIRSgvf.F90 b/lis/dataassim/obs/VIIRS_GVF/read_VIIRSgvf.F90 index 51e0c9613..962dd08b7 100644 --- a/lis/dataassim/obs/VIIRS_GVF/read_VIIRSgvf.F90 +++ b/lis/dataassim/obs/VIIRS_GVF/read_VIIRSgvf.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/VIIRS_GVF/write_VIIRSgvfobs.F90 b/lis/dataassim/obs/VIIRS_GVF/write_VIIRSgvfobs.F90 index edc3452a1..0396170b4 100644 --- a/lis/dataassim/obs/VIIRS_GVF/write_VIIRSgvfobs.F90 +++ b/lis/dataassim/obs/VIIRS_GVF/write_VIIRSgvfobs.F90 @@ -3,7 +3,7 @@ ! Land Information System Framework (LISF) ! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WUS_UCLAsnow/WUS_UCLAsnowMod.F90 b/lis/dataassim/obs/WUS_UCLAsnow/WUS_UCLAsnowMod.F90 index 9e5655821..571558607 100755 --- a/lis/dataassim/obs/WUS_UCLAsnow/WUS_UCLAsnowMod.F90 +++ b/lis/dataassim/obs/WUS_UCLAsnow/WUS_UCLAsnowMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WUS_UCLAsnow/read_WUS_UCLAsnow.F90 b/lis/dataassim/obs/WUS_UCLAsnow/read_WUS_UCLAsnow.F90 index 5fb3bccd5..b21308c1f 100755 --- a/lis/dataassim/obs/WUS_UCLAsnow/read_WUS_UCLAsnow.F90 +++ b/lis/dataassim/obs/WUS_UCLAsnow/read_WUS_UCLAsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WUS_UCLAsnow/write_WUS_UCLAsnow.F90 b/lis/dataassim/obs/WUS_UCLAsnow/write_WUS_UCLAsnow.F90 index 1f84bf86e..e6c751d1c 100755 --- a/lis/dataassim/obs/WUS_UCLAsnow/write_WUS_UCLAsnow.F90 +++ b/lis/dataassim/obs/WUS_UCLAsnow/write_WUS_UCLAsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_Cband_sm/WindSatCsm_Mod.F90 b/lis/dataassim/obs/WindSat_Cband_sm/WindSatCsm_Mod.F90 index 6c6a329fc..3dcfa32f4 100644 --- a/lis/dataassim/obs/WindSat_Cband_sm/WindSatCsm_Mod.F90 +++ b/lis/dataassim/obs/WindSat_Cband_sm/WindSatCsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_Cband_sm/read_WindSatCsm.F90 b/lis/dataassim/obs/WindSat_Cband_sm/read_WindSatCsm.F90 index 20102aa5e..83857c281 100644 --- a/lis/dataassim/obs/WindSat_Cband_sm/read_WindSatCsm.F90 +++ b/lis/dataassim/obs/WindSat_Cband_sm/read_WindSatCsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_Cband_sm/write_WindSatCsmobs.F90 b/lis/dataassim/obs/WindSat_Cband_sm/write_WindSatCsmobs.F90 index 6d8c8a37e..74328c767 100644 --- a/lis/dataassim/obs/WindSat_Cband_sm/write_WindSatCsmobs.F90 +++ b/lis/dataassim/obs/WindSat_Cband_sm/write_WindSatCsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_sm/0Intro_windsat.txt b/lis/dataassim/obs/WindSat_sm/0Intro_windsat.txt index 625b2f49e..bde1a75db 100644 --- a/lis/dataassim/obs/WindSat_sm/0Intro_windsat.txt +++ b/lis/dataassim/obs/WindSat_sm/0Intro_windsat.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_sm/WindSatsm_Mod.F90 b/lis/dataassim/obs/WindSat_sm/WindSatsm_Mod.F90 index e235807d8..bdf5c5c11 100644 --- a/lis/dataassim/obs/WindSat_sm/WindSatsm_Mod.F90 +++ b/lis/dataassim/obs/WindSat_sm/WindSatsm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_sm/read_WindSatsm.F90 b/lis/dataassim/obs/WindSat_sm/read_WindSatsm.F90 index 85f7e824a..0f691f12f 100644 --- a/lis/dataassim/obs/WindSat_sm/read_WindSatsm.F90 +++ b/lis/dataassim/obs/WindSat_sm/read_WindSatsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/WindSat_sm/write_WindSatsmobs.F90 b/lis/dataassim/obs/WindSat_sm/write_WindSatsmobs.F90 index dd74b3450..f7a10d678 100644 --- a/lis/dataassim/obs/WindSat_sm/write_WindSatsmobs.F90 +++ b/lis/dataassim/obs/WindSat_sm/write_WindSatsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/hydrowebWL/hydrowebWLobs_module.F90 b/lis/dataassim/obs/hydrowebWL/hydrowebWLobs_module.F90 index e95e13b8b..c4eaa03b2 100755 --- a/lis/dataassim/obs/hydrowebWL/hydrowebWLobs_module.F90 +++ b/lis/dataassim/obs/hydrowebWL/hydrowebWLobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/hydrowebWL/read_hydrowebWLobs.F90 b/lis/dataassim/obs/hydrowebWL/read_hydrowebWLobs.F90 index 3a2b71a72..0bb91ddb7 100755 --- a/lis/dataassim/obs/hydrowebWL/read_hydrowebWLobs.F90 +++ b/lis/dataassim/obs/hydrowebWL/read_hydrowebWLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/hydrowebWL/write_hydrowebWLobs.F90 b/lis/dataassim/obs/hydrowebWL/write_hydrowebWLobs.F90 index c41a4a581..a0125edb6 100755 --- a/lis/dataassim/obs/hydrowebWL/write_hydrowebWLobs.F90 +++ b/lis/dataassim/obs/hydrowebWL/write_hydrowebWLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/multisynsmobs/multisynsmobs_Mod.F90 b/lis/dataassim/obs/multisynsmobs/multisynsmobs_Mod.F90 index 5fc1791e8..b4cf4d49c 100644 --- a/lis/dataassim/obs/multisynsmobs/multisynsmobs_Mod.F90 +++ b/lis/dataassim/obs/multisynsmobs/multisynsmobs_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/multisynsmobs/read_multisynsmobs.F90 b/lis/dataassim/obs/multisynsmobs/read_multisynsmobs.F90 index cf8ac4e42..cb849ce0f 100644 --- a/lis/dataassim/obs/multisynsmobs/read_multisynsmobs.F90 +++ b/lis/dataassim/obs/multisynsmobs/read_multisynsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/pildas/pildassmobs_module.F90 b/lis/dataassim/obs/pildas/pildassmobs_module.F90 index 5e040a568..e5b214c4b 100644 --- a/lis/dataassim/obs/pildas/pildassmobs_module.F90 +++ b/lis/dataassim/obs/pildas/pildassmobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/pildas/read_pildassmobs.F90 b/lis/dataassim/obs/pildas/read_pildassmobs.F90 index 2258b81bb..ee1904b60 100644 --- a/lis/dataassim/obs/pildas/read_pildassmobs.F90 +++ b/lis/dataassim/obs/pildas/read_pildassmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/pildas/write_pildassmobs.F90 b/lis/dataassim/obs/pildas/write_pildassmobs.F90 index 6a014fc86..4db10a3d7 100644 --- a/lis/dataassim/obs/pildas/write_pildassmobs.F90 +++ b/lis/dataassim/obs/pildas/write_pildassmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/simGRACE_JPL/read_simGRACEJPLobs.F90 b/lis/dataassim/obs/simGRACE_JPL/read_simGRACEJPLobs.F90 index 88ece79a3..9d963e478 100644 --- a/lis/dataassim/obs/simGRACE_JPL/read_simGRACEJPLobs.F90 +++ b/lis/dataassim/obs/simGRACE_JPL/read_simGRACEJPLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/simGRACE_JPL/simGRACEJPLobs_module.F90 b/lis/dataassim/obs/simGRACE_JPL/simGRACEJPLobs_module.F90 index 81bb11386..6961f5db9 100644 --- a/lis/dataassim/obs/simGRACE_JPL/simGRACEJPLobs_module.F90 +++ b/lis/dataassim/obs/simGRACE_JPL/simGRACEJPLobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/simGRACE_JPL/write_simGRACEJPLobs.F90 b/lis/dataassim/obs/simGRACE_JPL/write_simGRACEJPLobs.F90 index 466afabfd..8a1abaafe 100644 --- a/lis/dataassim/obs/simGRACE_JPL/write_simGRACEJPLobs.F90 +++ b/lis/dataassim/obs/simGRACE_JPL/write_simGRACEJPLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticSnowTb/read_syntheticSnowTbObs.F90 b/lis/dataassim/obs/syntheticSnowTb/read_syntheticSnowTbObs.F90 index 1abb8a97a..9998db0f5 100755 --- a/lis/dataassim/obs/syntheticSnowTb/read_syntheticSnowTbObs.F90 +++ b/lis/dataassim/obs/syntheticSnowTb/read_syntheticSnowTbObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticSnowTb/syntheticSnowTbObs_Mod.F90 b/lis/dataassim/obs/syntheticSnowTb/syntheticSnowTbObs_Mod.F90 index ae585393e..f5667f830 100755 --- a/lis/dataassim/obs/syntheticSnowTb/syntheticSnowTbObs_Mod.F90 +++ b/lis/dataassim/obs/syntheticSnowTb/syntheticSnowTbObs_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticSnowTb/write_syntheticSnowTbObs.F90 b/lis/dataassim/obs/syntheticSnowTb/write_syntheticSnowTbObs.F90 index 5b3a81326..022b49223 100755 --- a/lis/dataassim/obs/syntheticSnowTb/write_syntheticSnowTbObs.F90 +++ b/lis/dataassim/obs/syntheticSnowTb/write_syntheticSnowTbObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticlst/read_syntheticlstobs.F90 b/lis/dataassim/obs/syntheticlst/read_syntheticlstobs.F90 index c38ebd59f..56bea06e0 100755 --- a/lis/dataassim/obs/syntheticlst/read_syntheticlstobs.F90 +++ b/lis/dataassim/obs/syntheticlst/read_syntheticlstobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticlst/syntheticlstobs_module.F90 b/lis/dataassim/obs/syntheticlst/syntheticlstobs_module.F90 index eb27853ac..29818e8cd 100755 --- a/lis/dataassim/obs/syntheticlst/syntheticlstobs_module.F90 +++ b/lis/dataassim/obs/syntheticlst/syntheticlstobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsf/read_syntheticsfobs.F90 b/lis/dataassim/obs/syntheticsf/read_syntheticsfobs.F90 index cb17efa39..f56ba540c 100644 --- a/lis/dataassim/obs/syntheticsf/read_syntheticsfobs.F90 +++ b/lis/dataassim/obs/syntheticsf/read_syntheticsfobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsf/syntheticsfobs_module.F90 b/lis/dataassim/obs/syntheticsf/syntheticsfobs_module.F90 index 18279c4b7..7d193dab2 100644 --- a/lis/dataassim/obs/syntheticsf/syntheticsfobs_module.F90 +++ b/lis/dataassim/obs/syntheticsf/syntheticsfobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsf/write_syntheticsfobs.F90 b/lis/dataassim/obs/syntheticsf/write_syntheticsfobs.F90 index 42d66d84a..879c23b5d 100644 --- a/lis/dataassim/obs/syntheticsf/write_syntheticsfobs.F90 +++ b/lis/dataassim/obs/syntheticsf/write_syntheticsfobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsm/read_syntheticsmobs.F90 b/lis/dataassim/obs/syntheticsm/read_syntheticsmobs.F90 index 1cb1c8594..da6443d7a 100644 --- a/lis/dataassim/obs/syntheticsm/read_syntheticsmobs.F90 +++ b/lis/dataassim/obs/syntheticsm/read_syntheticsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsm/syntheticsmobs_module.F90 b/lis/dataassim/obs/syntheticsm/syntheticsmobs_module.F90 index 7bfdeaf7c..9970f2c3d 100644 --- a/lis/dataassim/obs/syntheticsm/syntheticsmobs_module.F90 +++ b/lis/dataassim/obs/syntheticsm/syntheticsmobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsm/write_syntheticsmobs.F90 b/lis/dataassim/obs/syntheticsm/write_syntheticsmobs.F90 index 49542260e..965a0a5b9 100644 --- a/lis/dataassim/obs/syntheticsm/write_syntheticsmobs.F90 +++ b/lis/dataassim/obs/syntheticsm/write_syntheticsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsnd/read_syntheticsndobs.F90 b/lis/dataassim/obs/syntheticsnd/read_syntheticsndobs.F90 index e25c70e6f..8639ff7a3 100644 --- a/lis/dataassim/obs/syntheticsnd/read_syntheticsndobs.F90 +++ b/lis/dataassim/obs/syntheticsnd/read_syntheticsndobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsnd/syntheticsndobs_module.F90 b/lis/dataassim/obs/syntheticsnd/syntheticsndobs_module.F90 index da09d1a10..b57823179 100644 --- a/lis/dataassim/obs/syntheticsnd/syntheticsndobs_module.F90 +++ b/lis/dataassim/obs/syntheticsnd/syntheticsndobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticsnd/write_syntheticsndobs.F90 b/lis/dataassim/obs/syntheticsnd/write_syntheticsndobs.F90 index a91450dc0..72904613e 100644 --- a/lis/dataassim/obs/syntheticsnd/write_syntheticsndobs.F90 +++ b/lis/dataassim/obs/syntheticsnd/write_syntheticsndobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticswe/read_syntheticsweobs.F90 b/lis/dataassim/obs/syntheticswe/read_syntheticsweobs.F90 index 5839a5378..19fad505b 100644 --- a/lis/dataassim/obs/syntheticswe/read_syntheticsweobs.F90 +++ b/lis/dataassim/obs/syntheticswe/read_syntheticsweobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticswe/syntheticsweobs_module.F90 b/lis/dataassim/obs/syntheticswe/syntheticsweobs_module.F90 index cc81fc02a..dbab99075 100644 --- a/lis/dataassim/obs/syntheticswe/syntheticsweobs_module.F90 +++ b/lis/dataassim/obs/syntheticswe/syntheticsweobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticswe/write_syntheticsweobs.F90 b/lis/dataassim/obs/syntheticswe/write_syntheticsweobs.F90 index 09bf3b3d2..3c53b7ab1 100755 --- a/lis/dataassim/obs/syntheticswe/write_syntheticsweobs.F90 +++ b/lis/dataassim/obs/syntheticswe/write_syntheticsweobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticwl/read_syntheticwlobs.F90 b/lis/dataassim/obs/syntheticwl/read_syntheticwlobs.F90 index 996f66b2f..3182efd6f 100644 --- a/lis/dataassim/obs/syntheticwl/read_syntheticwlobs.F90 +++ b/lis/dataassim/obs/syntheticwl/read_syntheticwlobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticwl/syntheticwlobs_module.F90 b/lis/dataassim/obs/syntheticwl/syntheticwlobs_module.F90 index 1a2760dae..59227a43a 100644 --- a/lis/dataassim/obs/syntheticwl/syntheticwlobs_module.F90 +++ b/lis/dataassim/obs/syntheticwl/syntheticwlobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/obs/syntheticwl/write_syntheticwlobs.F90 b/lis/dataassim/obs/syntheticwl/write_syntheticwlobs.F90 index 655c19106..c9ad6c304 100644 --- a/lis/dataassim/obs/syntheticwl/write_syntheticwlobs.F90 +++ b/lis/dataassim/obs/syntheticwl/write_syntheticwlobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/0Intro_algorithms.txt b/lis/dataassim/perturb/0Intro_algorithms.txt index 88fd3f745..05870bef0 100644 --- a/lis/dataassim/perturb/0Intro_algorithms.txt +++ b/lis/dataassim/perturb/0Intro_algorithms.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/0Intro_gmao.txt b/lis/dataassim/perturb/gmaopert/0Intro_gmao.txt index a2ab44558..89c67fb63 100644 --- a/lis/dataassim/perturb/gmaopert/0Intro_gmao.txt +++ b/lis/dataassim/perturb/gmaopert/0Intro_gmao.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/gmaopert_Mod.F90 b/lis/dataassim/perturb/gmaopert/gmaopert_Mod.F90 index f69c9dc07..fdc579282 100644 --- a/lis/dataassim/perturb/gmaopert/gmaopert_Mod.F90 +++ b/lis/dataassim/perturb/gmaopert/gmaopert_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/landpert_module.F90 b/lis/dataassim/perturb/gmaopert/landpert_module.F90 index 1fbd8cfa2..925dc4a5e 100644 --- a/lis/dataassim/perturb/gmaopert/landpert_module.F90 +++ b/lis/dataassim/perturb/gmaopert/landpert_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/landpert_routines.F90 b/lis/dataassim/perturb/gmaopert/landpert_routines.F90 index f8847d5b9..7291913f0 100644 --- a/lis/dataassim/perturb/gmaopert/landpert_routines.F90 +++ b/lis/dataassim/perturb/gmaopert/landpert_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/nr_jacobi.F90 b/lis/dataassim/perturb/gmaopert/nr_jacobi.F90 index c99c5bd69..8b76f8cfd 100644 --- a/lis/dataassim/perturb/gmaopert/nr_jacobi.F90 +++ b/lis/dataassim/perturb/gmaopert/nr_jacobi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/gmaopert/random_fields.F90 b/lis/dataassim/perturb/gmaopert/random_fields.F90 index 75b25d9f2..b04dd928d 100644 --- a/lis/dataassim/perturb/gmaopert/random_fields.F90 +++ b/lis/dataassim/perturb/gmaopert/random_fields.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/dataassim/perturb/uniform/uniformPert_Mod.F90 b/lis/dataassim/perturb/uniform/uniformPert_Mod.F90 index 9cd67fac7..eafd84f43 100644 --- a/lis/dataassim/perturb/uniform/uniformPert_Mod.F90 +++ b/lis/dataassim/perturb/uniform/uniformPert_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/0Intro_domains.txt b/lis/domains/0Intro_domains.txt index 5d059cdf5..f64feb1e5 100644 --- a/lis/domains/0Intro_domains.txt +++ b/lis/domains/0Intro_domains.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/UTM/0Intro_utm.txt b/lis/domains/UTM/0Intro_utm.txt index 4aebb546c..4954352d5 100644 --- a/lis/domains/UTM/0Intro_utm.txt +++ b/lis/domains/UTM/0Intro_utm.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/UTM/readinput_UTM.F90 b/lis/domains/UTM/readinput_UTM.F90 index 4726d6ed4..ea95cf2e2 100644 --- a/lis/domains/UTM/readinput_UTM.F90 +++ b/lis/domains/UTM/readinput_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/catchment/createtiles_catch.F90 b/lis/domains/catchment/createtiles_catch.F90 index dbdd6653d..a102d2796 100644 --- a/lis/domains/catchment/createtiles_catch.F90 +++ b/lis/domains/catchment/createtiles_catch.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/catchment/qs.F90 b/lis/domains/catchment/qs.F90 index 54e2a6479..efbe58247 100644 --- a/lis/domains/catchment/qs.F90 +++ b/lis/domains/catchment/qs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/catchment/readinput_catch.F90 b/lis/domains/catchment/readinput_catch.F90 index 20616089f..2aec19393 100644 --- a/lis/domains/catchment/readinput_catch.F90 +++ b/lis/domains/catchment/readinput_catch.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/catchment/tile_coord_routines.F90 b/lis/domains/catchment/tile_coord_routines.F90 index 8c9875ed0..1d8ecb0a0 100644 --- a/lis/domains/catchment/tile_coord_routines.F90 +++ b/lis/domains/catchment/tile_coord_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/catchment/tile_coord_types.F90 b/lis/domains/catchment/tile_coord_types.F90 index 7ffd43875..cf7b36890 100644 --- a/lis/domains/catchment/tile_coord_types.F90 +++ b/lis/domains/catchment/tile_coord_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/gaussian/readinput_gaussian.F90 b/lis/domains/gaussian/readinput_gaussian.F90 index 53d8da038..06c510dad 100644 --- a/lis/domains/gaussian/readinput_gaussian.F90 +++ b/lis/domains/gaussian/readinput_gaussian.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/hrap/readinput_hrap.F90 b/lis/domains/hrap/readinput_hrap.F90 index e0b30523d..62b0a1fb2 100755 --- a/lis/domains/hrap/readinput_hrap.F90 +++ b/lis/domains/hrap/readinput_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/lambert/0Intro_lambert.txt b/lis/domains/lambert/0Intro_lambert.txt index 1a9711de1..1f5008a12 100644 --- a/lis/domains/lambert/0Intro_lambert.txt +++ b/lis/domains/lambert/0Intro_lambert.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/lambert/readinput_lambert.F90 b/lis/domains/lambert/readinput_lambert.F90 index cb67f4412..0b77e73a2 100644 --- a/lis/domains/lambert/readinput_lambert.F90 +++ b/lis/domains/lambert/readinput_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/latlon/0Intro_latlon.txt b/lis/domains/latlon/0Intro_latlon.txt index b8821128a..e1b687e77 100644 --- a/lis/domains/latlon/0Intro_latlon.txt +++ b/lis/domains/latlon/0Intro_latlon.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/latlon/readinput_latlon.F90 b/lis/domains/latlon/readinput_latlon.F90 index 8763622d2..6a363c4b7 100644 --- a/lis/domains/latlon/readinput_latlon.F90 +++ b/lis/domains/latlon/readinput_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/merc/0Intro_merc.txt b/lis/domains/merc/0Intro_merc.txt index 5041ed27f..e3f49160a 100644 --- a/lis/domains/merc/0Intro_merc.txt +++ b/lis/domains/merc/0Intro_merc.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/merc/readinput_merc.F90 b/lis/domains/merc/readinput_merc.F90 index 7bafcf059..967aa8188 100644 --- a/lis/domains/merc/readinput_merc.F90 +++ b/lis/domains/merc/readinput_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/polar/0Intro_polar.txt b/lis/domains/polar/0Intro_polar.txt index 68449ea32..83ea82038 100644 --- a/lis/domains/polar/0Intro_polar.txt +++ b/lis/domains/polar/0Intro_polar.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/domains/polar/readinput_polar.F90 b/lis/domains/polar/readinput_polar.F90 index 0c506c1d6..6bdfa8f5a 100644 --- a/lis/domains/polar/readinput_polar.F90 +++ b/lis/domains/polar/readinput_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/forecast/algorithm/ESPboot/ESPboot_Mod.F90 b/lis/forecast/algorithm/ESPboot/ESPboot_Mod.F90 index 2a7cc62a8..049f74a7c 100644 --- a/lis/forecast/algorithm/ESPboot/ESPboot_Mod.F90 +++ b/lis/forecast/algorithm/ESPboot/ESPboot_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/forecast/algorithm/ESPconv/ESPconv_Mod.F90 b/lis/forecast/algorithm/ESPconv/ESPconv_Mod.F90 index d19c52f47..7e12e52b9 100644 --- a/lis/forecast/algorithm/ESPconv/ESPconv_Mod.F90 +++ b/lis/forecast/algorithm/ESPconv/ESPconv_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/0Intro_interp.txt b/lis/interp/0Intro_interp.txt index 80a710542..55db7d59a 100644 --- a/lis/interp/0Intro_interp.txt +++ b/lis/interp/0Intro_interp.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/UTM_utils.F90 b/lis/interp/UTM_utils.F90 index 10d93511a..ad73bbce1 100755 --- a/lis/interp/UTM_utils.F90 +++ b/lis/interp/UTM_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/bilinear_interp.F90 b/lis/interp/bilinear_interp.F90 index 3032866d3..80bce38c1 100644 --- a/lis/interp/bilinear_interp.F90 +++ b/lis/interp/bilinear_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/bilinear_interp_input.F90 b/lis/interp/bilinear_interp_input.F90 index 1cb5d48d9..85b388c5b 100644 --- a/lis/interp/bilinear_interp_input.F90 +++ b/lis/interp/bilinear_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/bilinear_interp_input_withgrid.F90 b/lis/interp/bilinear_interp_input_withgrid.F90 index 39f9de86f..d5ad38d7a 100644 --- a/lis/interp/bilinear_interp_input_withgrid.F90 +++ b/lis/interp/bilinear_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/breakpt_module.F90 b/lis/interp/breakpt_module.F90 index ffff42ba5..d34f10322 100644 --- a/lis/interp/breakpt_module.F90 +++ b/lis/interp/breakpt_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord.F90 b/lis/interp/compute_earth_coord.F90 index 56d2fcff3..403777b5d 100644 --- a/lis/interp/compute_earth_coord.F90 +++ b/lis/interp/compute_earth_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_UTM.F90 b/lis/interp/compute_earth_coord_UTM.F90 index c0fe404fc..14f16f52d 100644 --- a/lis/interp/compute_earth_coord_UTM.F90 +++ b/lis/interp/compute_earth_coord_UTM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_ease.F90 b/lis/interp/compute_earth_coord_ease.F90 index 25429a2e7..ed9335514 100644 --- a/lis/interp/compute_earth_coord_ease.F90 +++ b/lis/interp/compute_earth_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_gauss.F90 b/lis/interp/compute_earth_coord_gauss.F90 index 6d93fc250..76e3c153a 100644 --- a/lis/interp/compute_earth_coord_gauss.F90 +++ b/lis/interp/compute_earth_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_hrap.F90 b/lis/interp/compute_earth_coord_hrap.F90 index 9aa26fa3c..89896f981 100644 --- a/lis/interp/compute_earth_coord_hrap.F90 +++ b/lis/interp/compute_earth_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_lambert.F90 b/lis/interp/compute_earth_coord_lambert.F90 index 83b0896b5..b8551e31b 100644 --- a/lis/interp/compute_earth_coord_lambert.F90 +++ b/lis/interp/compute_earth_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_latlon.F90 b/lis/interp/compute_earth_coord_latlon.F90 index 019cfe338..918e7e099 100644 --- a/lis/interp/compute_earth_coord_latlon.F90 +++ b/lis/interp/compute_earth_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_latlon_ll.F90 b/lis/interp/compute_earth_coord_latlon_ll.F90 index ab5977ec1..d49d02514 100644 --- a/lis/interp/compute_earth_coord_latlon_ll.F90 +++ b/lis/interp/compute_earth_coord_latlon_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_ll.F90 b/lis/interp/compute_earth_coord_ll.F90 index 13a4ee541..d3ef91711 100644 --- a/lis/interp/compute_earth_coord_ll.F90 +++ b/lis/interp/compute_earth_coord_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_merc.F90 b/lis/interp/compute_earth_coord_merc.F90 index b682811f3..cb41179a3 100644 --- a/lis/interp/compute_earth_coord_merc.F90 +++ b/lis/interp/compute_earth_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_earth_coord_polar.F90 b/lis/interp/compute_earth_coord_polar.F90 index a52479036..18fe0dbdc 100644 --- a/lis/interp/compute_earth_coord_polar.F90 +++ b/lis/interp/compute_earth_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord.F90 b/lis/interp/compute_grid_coord.F90 index 9fb8d88ed..5d0a1af59 100644 --- a/lis/interp/compute_grid_coord.F90 +++ b/lis/interp/compute_grid_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_ease.F90 b/lis/interp/compute_grid_coord_ease.F90 index 964852e4f..3ee5c05a4 100644 --- a/lis/interp/compute_grid_coord_ease.F90 +++ b/lis/interp/compute_grid_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_gauss.F90 b/lis/interp/compute_grid_coord_gauss.F90 index d6e9293f3..69113d5cc 100644 --- a/lis/interp/compute_grid_coord_gauss.F90 +++ b/lis/interp/compute_grid_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_hrap.F90 b/lis/interp/compute_grid_coord_hrap.F90 index 5c579cb3d..fbb2ea87c 100644 --- a/lis/interp/compute_grid_coord_hrap.F90 +++ b/lis/interp/compute_grid_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_lambert.F90 b/lis/interp/compute_grid_coord_lambert.F90 index e03c817d2..81b278ff8 100644 --- a/lis/interp/compute_grid_coord_lambert.F90 +++ b/lis/interp/compute_grid_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_latlon.F90 b/lis/interp/compute_grid_coord_latlon.F90 index fec4e79b8..4bc53bd51 100644 --- a/lis/interp/compute_grid_coord_latlon.F90 +++ b/lis/interp/compute_grid_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_merc.F90 b/lis/interp/compute_grid_coord_merc.F90 index 51a0737fe..1fb522c17 100644 --- a/lis/interp/compute_grid_coord_merc.F90 +++ b/lis/interp/compute_grid_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_grid_coord_polar.F90 b/lis/interp/compute_grid_coord_polar.F90 index bc8f620af..d6063e186 100644 --- a/lis/interp/compute_grid_coord_polar.F90 +++ b/lis/interp/compute_grid_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_stnwts.F90 b/lis/interp/compute_stnwts.F90 index 02a2201f4..762746da9 100644 --- a/lis/interp/compute_stnwts.F90 +++ b/lis/interp/compute_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/compute_vinterp_weights.F90 b/lis/interp/compute_vinterp_weights.F90 index b79853dfe..a0120dfd2 100755 --- a/lis/interp/compute_vinterp_weights.F90 +++ b/lis/interp/compute_vinterp_weights.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/conserv_interp.F90 b/lis/interp/conserv_interp.F90 index 3c9572c34..43e8f0a7f 100644 --- a/lis/interp/conserv_interp.F90 +++ b/lis/interp/conserv_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/conserv_interp_input.F90 b/lis/interp/conserv_interp_input.F90 index dc47686e5..add261db0 100644 --- a/lis/interp/conserv_interp_input.F90 +++ b/lis/interp/conserv_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/conserv_interp_input_withgrid.F90 b/lis/interp/conserv_interp_input_withgrid.F90 index dc66f0574..358c0a47b 100644 --- a/lis/interp/conserv_interp_input_withgrid.F90 +++ b/lis/interp/conserv_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/defineLocalDomain.F90 b/lis/interp/defineLocalDomain.F90 index fece7cc2f..41f991113 100644 --- a/lis/interp/defineLocalDomain.F90 +++ b/lis/interp/defineLocalDomain.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/diff_lon.F90 b/lis/interp/diff_lon.F90 index a8115c107..122c1957d 100644 --- a/lis/interp/diff_lon.F90 +++ b/lis/interp/diff_lon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/easeV2_utils.F90 b/lis/interp/easeV2_utils.F90 index 63103440a..53d6abfe8 100644 --- a/lis/interp/easeV2_utils.F90 +++ b/lis/interp/easeV2_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/ezlh_convert.F90 b/lis/interp/ezlh_convert.F90 index d86cb9a4f..e83289fd5 100755 --- a/lis/interp/ezlh_convert.F90 +++ b/lis/interp/ezlh_convert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/ezlh_inverse.F90 b/lis/interp/ezlh_inverse.F90 index dce789cfe..91843a741 100755 --- a/lis/interp/ezlh_inverse.F90 +++ b/lis/interp/ezlh_inverse.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/gaussian_mod.F90.keep b/lis/interp/gaussian_mod.F90.keep index 94ec55616..b316ad13c 100644 --- a/lis/interp/gaussian_mod.F90.keep +++ b/lis/interp/gaussian_mod.F90.keep @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/gaussian_quadrature.F90 b/lis/interp/gaussian_quadrature.F90 index 015064f65..371053a76 100644 --- a/lis/interp/gaussian_quadrature.F90 +++ b/lis/interp/gaussian_quadrature.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/gaussian_routines.F90 b/lis/interp/gaussian_routines.F90 index 283fc4458..d23a4b99f 100644 --- a/lis/interp/gaussian_routines.F90 +++ b/lis/interp/gaussian_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/gausslat.F90 b/lis/interp/gausslat.F90 index 20128406c..b91e70d45 100644 --- a/lis/interp/gausslat.F90 +++ b/lis/interp/gausslat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/get_fieldpos.F90 b/lis/interp/get_fieldpos.F90 index 3e201feea..9f3dcde14 100644 --- a/lis/interp/get_fieldpos.F90 +++ b/lis/interp/get_fieldpos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/hrapToLatLon.F90 b/lis/interp/hrapToLatLon.F90 index 3df38eb5f..018f87d1f 100644 --- a/lis/interp/hrapToLatLon.F90 +++ b/lis/interp/hrapToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/idw_module.F90 b/lis/interp/idw_module.F90 index ca7d3cdc5..bfb1eeb84 100644 --- a/lis/interp/idw_module.F90 +++ b/lis/interp/idw_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/interp_stndata.F90 b/lis/interp/interp_stndata.F90 index 3537788f8..2b7c9c44f 100644 --- a/lis/interp/interp_stndata.F90 +++ b/lis/interp/interp_stndata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/latlonTohrap.F90 b/lis/interp/latlonTohrap.F90 index 8f74cbe88..27fc4a909 100644 --- a/lis/interp/latlonTohrap.F90 +++ b/lis/interp/latlonTohrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/latlonTopolar.F90 b/lis/interp/latlonTopolar.F90 index 14dee4feb..490db8e11 100644 --- a/lis/interp/latlonTopolar.F90 +++ b/lis/interp/latlonTopolar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/lltops.F90 b/lis/interp/lltops.F90 index 4f3661ab7..7812c9917 100644 --- a/lis/interp/lltops.F90 +++ b/lis/interp/lltops.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/map_utils.F90 b/lis/interp/map_utils.F90 index 43df2ac20..fe34ea71f 100644 --- a/lis/interp/map_utils.F90 +++ b/lis/interp/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/mqb_module.F90 b/lis/interp/mqb_module.F90 index 9e9937644..4a411b007 100644 --- a/lis/interp/mqb_module.F90 +++ b/lis/interp/mqb_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/neighbor_interp.F90 b/lis/interp/neighbor_interp.F90 index b8430ccd1..5aaeac61d 100644 --- a/lis/interp/neighbor_interp.F90 +++ b/lis/interp/neighbor_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/neighbor_interp_input.F90 b/lis/interp/neighbor_interp_input.F90 index 94882e174..5519dd069 100644 --- a/lis/interp/neighbor_interp_input.F90 +++ b/lis/interp/neighbor_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/neighbor_interp_input_withgrid.F90 b/lis/interp/neighbor_interp_input_withgrid.F90 index b86b15013..26acd8583 100644 --- a/lis/interp/neighbor_interp_input_withgrid.F90 +++ b/lis/interp/neighbor_interp_input_withgrid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/normalize_stnwts.F90 b/lis/interp/normalize_stnwts.F90 index 0f8e5d480..d95252415 100644 --- a/lis/interp/normalize_stnwts.F90 +++ b/lis/interp/normalize_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/polarToLatLon.F90 b/lis/interp/polarToLatLon.F90 index 4aee0e4a3..e4a200ae9 100644 --- a/lis/interp/polarToLatLon.F90 +++ b/lis/interp/polarToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/polfixs.F90 b/lis/interp/polfixs.F90 index 576f3ba8d..d99a4ccde 100644 --- a/lis/interp/polfixs.F90 +++ b/lis/interp/polfixs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/pstoll.F90 b/lis/interp/pstoll.F90 index 0a8818363..165f0cd44 100644 --- a/lis/interp/pstoll.F90 +++ b/lis/interp/pstoll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/snsoidxyTolatlon.F90 b/lis/interp/snsoidxyTolatlon.F90 index ff01f8e08..26654f9ce 100755 --- a/lis/interp/snsoidxyTolatlon.F90 +++ b/lis/interp/snsoidxyTolatlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/stninterp_module.F90 b/lis/interp/stninterp_module.F90 index 56e7944cc..d7809af9e 100644 --- a/lis/interp/stninterp_module.F90 +++ b/lis/interp/stninterp_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/upscaleByAveraging.F90 b/lis/interp/upscaleByAveraging.F90 index a67930f03..77b55dfc2 100644 --- a/lis/interp/upscaleByAveraging.F90 +++ b/lis/interp/upscaleByAveraging.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/upscaleByAveraging_input.F90 b/lis/interp/upscaleByAveraging_input.F90 index b21876ef1..fb9d2933b 100644 --- a/lis/interp/upscaleByAveraging_input.F90 +++ b/lis/interp/upscaleByAveraging_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/upscaleByWeightedAveraging.F90 b/lis/interp/upscaleByWeightedAveraging.F90 index 89a9aa66d..4599e6787 100644 --- a/lis/interp/upscaleByWeightedAveraging.F90 +++ b/lis/interp/upscaleByWeightedAveraging.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/upscaleByWeightedAveraging_input.F90 b/lis/interp/upscaleByWeightedAveraging_input.F90 index 8e747f47f..510e11a2d 100644 --- a/lis/interp/upscaleByWeightedAveraging_input.F90 +++ b/lis/interp/upscaleByWeightedAveraging_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/interp/zterp.F90 b/lis/interp/zterp.F90 index 4d5628747..96e90ad10 100644 --- a/lis/interp/zterp.F90 +++ b/lis/interp/zterp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/irrigation/drip/drip_irrigationMod.F90 b/lis/irrigation/drip/drip_irrigationMod.F90 index 08de11066..64499a345 100644 --- a/lis/irrigation/drip/drip_irrigationMod.F90 +++ b/lis/irrigation/drip/drip_irrigationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/irrigation/flood/flood_irrigationMod.F90 b/lis/irrigation/flood/flood_irrigationMod.F90 index fec2f5984..5c2655ea5 100644 --- a/lis/irrigation/flood/flood_irrigationMod.F90 +++ b/lis/irrigation/flood/flood_irrigationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/irrigation/sprinkler/sprinkler_irrigationMod.F90 b/lis/irrigation/sprinkler/sprinkler_irrigationMod.F90 index 8e412d315..8732ad27e 100755 --- a/lis/irrigation/sprinkler/sprinkler_irrigationMod.F90 +++ b/lis/irrigation/sprinkler/sprinkler_irrigationMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/atm.F90.turnoff b/lis/lib/lis-cmem3/atm.F90.turnoff index f678a7ab5..5cb5b938c 100755 --- a/lis/lib/lis-cmem3/atm.F90.turnoff +++ b/lis/lib/lis-cmem3/atm.F90.turnoff @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/desert.F90 b/lis/lib/lis-cmem3/desert.F90 index 0d77f975b..ba91a0bba 100755 --- a/lis/lib/lis-cmem3/desert.F90 +++ b/lis/lib/lis-cmem3/desert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/dieldesert_sub.F90 b/lis/lib/lis-cmem3/dieldesert_sub.F90 index 19186aa68..e4c1e23ae 100755 --- a/lis/lib/lis-cmem3/dieldesert_sub.F90 +++ b/lis/lib/lis-cmem3/dieldesert_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/dielice_sub.F90 b/lis/lib/lis-cmem3/dielice_sub.F90 index f3eae22d7..4bd03c553 100755 --- a/lis/lib/lis-cmem3/dielice_sub.F90 +++ b/lis/lib/lis-cmem3/dielice_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/dielsoil_sub.F90 b/lis/lib/lis-cmem3/dielsoil_sub.F90 index c4d4340c9..7367446d2 100755 --- a/lis/lib/lis-cmem3/dielsoil_sub.F90 +++ b/lis/lib/lis-cmem3/dielsoil_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/dielwat_sub.F90 b/lis/lib/lis-cmem3/dielwat_sub.F90 index 130275b7c..22ed5b9e0 100755 --- a/lis/lib/lis-cmem3/dielwat_sub.F90 +++ b/lis/lib/lis-cmem3/dielwat_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/fresnel_sub.F90 b/lis/lib/lis-cmem3/fresnel_sub.F90 index c261dc0ee..ec4af7d19 100755 --- a/lis/lib/lis-cmem3/fresnel_sub.F90 +++ b/lis/lib/lis-cmem3/fresnel_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/liebe89_sub.F90.turnoff b/lis/lib/lis-cmem3/liebe89_sub.F90.turnoff index 58aaff927..3d14fb7af 100755 --- a/lis/lib/lis-cmem3/liebe89_sub.F90.turnoff +++ b/lis/lib/lis-cmem3/liebe89_sub.F90.turnoff @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/lis_mem.F90 b/lis/lib/lis-cmem3/lis_mem.F90 index f37f728e2..5e63048ac 100755 --- a/lis/lib/lis-cmem3/lis_mem.F90 +++ b/lis/lib/lis-cmem3/lis_mem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/rghref_sub.F90 b/lis/lib/lis-cmem3/rghref_sub.F90 index 8f1712717..7c14a46a6 100755 --- a/lis/lib/lis-cmem3/rghref_sub.F90 +++ b/lis/lib/lis-cmem3/rghref_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/snow.F90 b/lis/lib/lis-cmem3/snow.F90 index 6b9f4f2a1..752e8dfac 100755 --- a/lis/lib/lis-cmem3/snow.F90 +++ b/lis/lib/lis-cmem3/snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/soil.F90 b/lis/lib/lis-cmem3/soil.F90 index 7b8dc1cfb..2cb2c48c4 100755 --- a/lis/lib/lis-cmem3/soil.F90 +++ b/lis/lib/lis-cmem3/soil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/veg.F90 b/lis/lib/lis-cmem3/veg.F90 index e14d2e2bb..e7e947e99 100755 --- a/lis/lib/lis-cmem3/veg.F90 +++ b/lis/lib/lis-cmem3/veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/veg_sub.F90 b/lis/lib/lis-cmem3/veg_sub.F90 index cb4ab3850..d9e7c0631 100755 --- a/lis/lib/lis-cmem3/veg_sub.F90 +++ b/lis/lib/lis-cmem3/veg_sub.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-cmem3/water.F90 b/lis/lib/lis-cmem3/water.F90 index 7ffcbd397..27e0178da 100755 --- a/lis/lib/lis-cmem3/water.F90 +++ b/lis/lib/lis-cmem3/water.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/CRTM_MW_Land_SfcOptics.f90 b/lis/lib/lis-crtm/CRTM_MW_Land_SfcOptics.f90 index b802598f9..655166f30 100644 --- a/lis/lib/lis-crtm/CRTM_MW_Land_SfcOptics.f90 +++ b/lis/lib/lis-crtm/CRTM_MW_Land_SfcOptics.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/CRTM_MW_Snow_SfcOptics.f90 b/lis/lib/lis-crtm/CRTM_MW_Snow_SfcOptics.f90 index 1db3270a3..381016424 100644 --- a/lis/lib/lis-crtm/CRTM_MW_Snow_SfcOptics.f90 +++ b/lis/lib/lis-crtm/CRTM_MW_Snow_SfcOptics.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/CRTM_Surface_Define.f90 b/lis/lib/lis-crtm/CRTM_Surface_Define.f90 index 2ac1ae74d..ba273c09e 100644 --- a/lis/lib/lis-crtm/CRTM_Surface_Define.f90 +++ b/lis/lib/lis-crtm/CRTM_Surface_Define.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/NESDIS_LandEM_Module.f90 b/lis/lib/lis-crtm/NESDIS_LandEM_Module.f90 index 9759b1259..cfc312113 100644 --- a/lis/lib/lis-crtm/NESDIS_LandEM_Module.f90 +++ b/lis/lib/lis-crtm/NESDIS_LandEM_Module.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/README b/lis/lib/lis-crtm/README index f266ff353..0bb4e35c2 100644 --- a/lis/lib/lis-crtm/README +++ b/lis/lib/lis-crtm/README @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/lib/lis-crtm/Set_CRTM_Environment.sh b/lis/lib/lis-crtm/Set_CRTM_Environment.sh index 943c55f2d..54e9c7e61 100755 --- a/lis/lib/lis-crtm/Set_CRTM_Environment.sh +++ b/lis/lib/lis-crtm/Set_CRTM_Environment.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/make/build_version.sh b/lis/make/build_version.sh index f4c2a39df..eb162cf14 100644 --- a/lis/make/build_version.sh +++ b/lis/make/build_version.sh @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/make/makedep.py b/lis/make/makedep.py index a7d033e9c..daec48a11 100755 --- a/lis/make/makedep.py +++ b/lis/make/makedep.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/make/plugins.py b/lis/make/plugins.py index a9b163790..a3fb119aa 100755 --- a/lis/make/plugins.py +++ b/lis/make/plugins.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/0Intro_3B42RT.txt b/lis/metforcing/3B42RT/0Intro_3B42RT.txt index f9ee767f0..b51071dbb 100644 --- a/lis/metforcing/3B42RT/0Intro_3B42RT.txt +++ b/lis/metforcing/3B42RT/0Intro_3B42RT.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/TRMM3B42RT_forcingMod.F90 b/lis/metforcing/3B42RT/TRMM3B42RT_forcingMod.F90 index 5923ff666..2d2538e66 100644 --- a/lis/metforcing/3B42RT/TRMM3B42RT_forcingMod.F90 +++ b/lis/metforcing/3B42RT/TRMM3B42RT_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/finalize_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/finalize_TRMM3B42RT.F90 index f4e5e34b2..899b0d4fd 100644 --- a/lis/metforcing/3B42RT/finalize_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/finalize_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/get_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/get_TRMM3B42RT.F90 index f490fe433..e45622002 100644 --- a/lis/metforcing/3B42RT/get_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/get_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/interp_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/interp_TRMM3B42RT.F90 index a81284d3a..63ab5a1dc 100644 --- a/lis/metforcing/3B42RT/interp_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/interp_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/read_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/read_TRMM3B42RT.F90 index f52ae1ce6..394cf1558 100644 --- a/lis/metforcing/3B42RT/read_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/read_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/readcrd_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/readcrd_TRMM3B42RT.F90 index 693fe84be..9534d4fa7 100644 --- a/lis/metforcing/3B42RT/readcrd_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/readcrd_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RT/timeinterp_TRMM3B42RT.F90 b/lis/metforcing/3B42RT/timeinterp_TRMM3B42RT.F90 index 5b0ba84df..9aac05113 100644 --- a/lis/metforcing/3B42RT/timeinterp_TRMM3B42RT.F90 +++ b/lis/metforcing/3B42RT/timeinterp_TRMM3B42RT.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/0Intro_3B42RTV7.txt b/lis/metforcing/3B42RTV7/0Intro_3B42RTV7.txt index fbcf7190b..345143da4 100644 --- a/lis/metforcing/3B42RTV7/0Intro_3B42RTV7.txt +++ b/lis/metforcing/3B42RTV7/0Intro_3B42RTV7.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 b/lis/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 index d1198cdd6..36bb22e51 100644 --- a/lis/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 +++ b/lis/metforcing/3B42RTV7/TRMM3B42RTV7_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 index 1f58eb638..148a9f4f6 100644 --- a/lis/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/finalize_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 index 5a2d1845f..bf5ecec0d 100644 --- a/lis/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/get_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 index 4465d6d61..bdb0f3068 100644 --- a/lis/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/interp_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 index e10f9893f..8d30f0711 100644 --- a/lis/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/read_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 index 8321af514..a73846038 100644 --- a/lis/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/readcrd_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 b/lis/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 index 880db1b6a..144158a91 100644 --- a/lis/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 +++ b/lis/metforcing/3B42RTV7/timeinterp_TRMM3B42RTV7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/0Intro_3B42V6.txt b/lis/metforcing/3B42V6/0Intro_3B42V6.txt index a58564fdd..68bf99241 100644 --- a/lis/metforcing/3B42V6/0Intro_3B42V6.txt +++ b/lis/metforcing/3B42V6/0Intro_3B42V6.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 b/lis/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 index 681663f3e..c9bff7d25 100644 --- a/lis/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 +++ b/lis/metforcing/3B42V6/TRMM3B42V6_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/finalize_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/finalize_TRMM3B42V6.F90 index baa1447f7..1dce901df 100644 --- a/lis/metforcing/3B42V6/finalize_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/finalize_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/get_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/get_TRMM3B42V6.F90 index 3fd877fc0..1d5f14e64 100644 --- a/lis/metforcing/3B42V6/get_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/get_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/interp_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/interp_TRMM3B42V6.F90 index 8edff81d0..a0ad841aa 100644 --- a/lis/metforcing/3B42V6/interp_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/interp_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/read_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/read_TRMM3B42V6.F90 index 624c8cc35..1c6cbba54 100644 --- a/lis/metforcing/3B42V6/read_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/read_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 index fc36780c4..ace53336d 100644 --- a/lis/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/readcrd_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 b/lis/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 index 990054dfc..6e0bf8b03 100644 --- a/lis/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 +++ b/lis/metforcing/3B42V6/timeinterp_TRMM3B42V6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/0Intro_3B42V7.txt b/lis/metforcing/3B42V7/0Intro_3B42V7.txt index dd6f8a858..f1d982d13 100644 --- a/lis/metforcing/3B42V7/0Intro_3B42V7.txt +++ b/lis/metforcing/3B42V7/0Intro_3B42V7.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 b/lis/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 index a9f61a5c6..a76aa9fbd 100644 --- a/lis/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 +++ b/lis/metforcing/3B42V7/TRMM3B42V7_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/finalize_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/finalize_TRMM3B42V7.F90 index d0aba143f..77e6bab50 100644 --- a/lis/metforcing/3B42V7/finalize_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/finalize_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/get_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/get_TRMM3B42V7.F90 index a1010072d..274bebd83 100644 --- a/lis/metforcing/3B42V7/get_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/get_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/interp_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/interp_TRMM3B42V7.F90 index 5ecc310be..7b6f8cc01 100644 --- a/lis/metforcing/3B42V7/interp_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/interp_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/read_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/read_TRMM3B42V7.F90 index 33e4e8c7b..065501039 100644 --- a/lis/metforcing/3B42V7/read_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/read_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 index 73b81efc9..12c42eb86 100644 --- a/lis/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/readcrd_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 b/lis/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 index f5647ae5b..1fbb5f513 100644 --- a/lis/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 +++ b/lis/metforcing/3B42V7/timeinterp_TRMM3B42V7.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/AWAP_forcingMod.F90 b/lis/metforcing/AWAP/AWAP_forcingMod.F90 index a592d98b4..0fb51fb76 100644 --- a/lis/metforcing/AWAP/AWAP_forcingMod.F90 +++ b/lis/metforcing/AWAP/AWAP_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/AWAPfile.F90 b/lis/metforcing/AWAP/AWAPfile.F90 index e4a218bbe..2ddd41570 100644 --- a/lis/metforcing/AWAP/AWAPfile.F90 +++ b/lis/metforcing/AWAP/AWAPfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/finalize_AWAP.F90 b/lis/metforcing/AWAP/finalize_AWAP.F90 index ed2a29c81..cc4cae47e 100644 --- a/lis/metforcing/AWAP/finalize_AWAP.F90 +++ b/lis/metforcing/AWAP/finalize_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/get_AWAP.F90 b/lis/metforcing/AWAP/get_AWAP.F90 index a328a8f5c..8299f136f 100644 --- a/lis/metforcing/AWAP/get_AWAP.F90 +++ b/lis/metforcing/AWAP/get_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/interp_AWAP.F90 b/lis/metforcing/AWAP/interp_AWAP.F90 index e6bd2f865..6fd2fd934 100644 --- a/lis/metforcing/AWAP/interp_AWAP.F90 +++ b/lis/metforcing/AWAP/interp_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/read_AWAP.F90 b/lis/metforcing/AWAP/read_AWAP.F90 index e252e9817..9e238cb86 100644 --- a/lis/metforcing/AWAP/read_AWAP.F90 +++ b/lis/metforcing/AWAP/read_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/readcrd_AWAP.F90 b/lis/metforcing/AWAP/readcrd_AWAP.F90 index ed9f3f2ac..30a0d86fc 100644 --- a/lis/metforcing/AWAP/readcrd_AWAP.F90 +++ b/lis/metforcing/AWAP/readcrd_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/reset_AWAP.F90 b/lis/metforcing/AWAP/reset_AWAP.F90 index 657bca30d..edbc57786 100644 --- a/lis/metforcing/AWAP/reset_AWAP.F90 +++ b/lis/metforcing/AWAP/reset_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWAP/timeinterp_AWAP.F90 b/lis/metforcing/AWAP/timeinterp_AWAP.F90 index d7457d736..7c86936f8 100644 --- a/lis/metforcing/AWAP/timeinterp_AWAP.F90 +++ b/lis/metforcing/AWAP/timeinterp_AWAP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/AWRAL_forcingMod.F90 b/lis/metforcing/AWRAL/AWRAL_forcingMod.F90 index ac37eccb5..b73c80bc5 100644 --- a/lis/metforcing/AWRAL/AWRAL_forcingMod.F90 +++ b/lis/metforcing/AWRAL/AWRAL_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/finalize_AWRAL.F90 b/lis/metforcing/AWRAL/finalize_AWRAL.F90 index 704359403..75052144f 100644 --- a/lis/metforcing/AWRAL/finalize_AWRAL.F90 +++ b/lis/metforcing/AWRAL/finalize_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/get_AWRAL.F90 b/lis/metforcing/AWRAL/get_AWRAL.F90 index d4d46ee17..ebc184e6b 100644 --- a/lis/metforcing/AWRAL/get_AWRAL.F90 +++ b/lis/metforcing/AWRAL/get_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/interp_AWRAL.F90 b/lis/metforcing/AWRAL/interp_AWRAL.F90 index 5714179ca..5b71e5f6a 100644 --- a/lis/metforcing/AWRAL/interp_AWRAL.F90 +++ b/lis/metforcing/AWRAL/interp_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/read_AWRAL.F90 b/lis/metforcing/AWRAL/read_AWRAL.F90 index b2a3cb1d7..80bf7f732 100644 --- a/lis/metforcing/AWRAL/read_AWRAL.F90 +++ b/lis/metforcing/AWRAL/read_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/readcrd_AWRAL.F90 b/lis/metforcing/AWRAL/readcrd_AWRAL.F90 index b27ace4f8..a279a6266 100644 --- a/lis/metforcing/AWRAL/readcrd_AWRAL.F90 +++ b/lis/metforcing/AWRAL/readcrd_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/reset_AWRAL.F90 b/lis/metforcing/AWRAL/reset_AWRAL.F90 index 2bf5e8386..b6eb06f73 100644 --- a/lis/metforcing/AWRAL/reset_AWRAL.F90 +++ b/lis/metforcing/AWRAL/reset_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/AWRAL/timeinterp_AWRAL.F90 b/lis/metforcing/AWRAL/timeinterp_AWRAL.F90 index 00781f551..419ff83a2 100644 --- a/lis/metforcing/AWRAL/timeinterp_AWRAL.F90 +++ b/lis/metforcing/AWRAL/timeinterp_AWRAL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/0Intro_Bondville.txt b/lis/metforcing/Bondville/0Intro_Bondville.txt index 9a06e40a1..a6a0d7c50 100644 --- a/lis/metforcing/Bondville/0Intro_Bondville.txt +++ b/lis/metforcing/Bondville/0Intro_Bondville.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/Bondville_forcingMod.F90 b/lis/metforcing/Bondville/Bondville_forcingMod.F90 index 26ce4cc6c..3efc4f48e 100644 --- a/lis/metforcing/Bondville/Bondville_forcingMod.F90 +++ b/lis/metforcing/Bondville/Bondville_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/finalize_Bondville.F90 b/lis/metforcing/Bondville/finalize_Bondville.F90 index 777dfe9a0..b112933b1 100644 --- a/lis/metforcing/Bondville/finalize_Bondville.F90 +++ b/lis/metforcing/Bondville/finalize_Bondville.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/get_Bondville.F90 b/lis/metforcing/Bondville/get_Bondville.F90 index b3679f891..2cbbbf115 100644 --- a/lis/metforcing/Bondville/get_Bondville.F90 +++ b/lis/metforcing/Bondville/get_Bondville.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/read_Bondville.F90 b/lis/metforcing/Bondville/read_Bondville.F90 index 639013cb5..eb1973806 100644 --- a/lis/metforcing/Bondville/read_Bondville.F90 +++ b/lis/metforcing/Bondville/read_Bondville.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/readcrd_Bondville.F90 b/lis/metforcing/Bondville/readcrd_Bondville.F90 index 5369c5e27..039518726 100644 --- a/lis/metforcing/Bondville/readcrd_Bondville.F90 +++ b/lis/metforcing/Bondville/readcrd_Bondville.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Bondville/timeinterp_Bondville.F90 b/lis/metforcing/Bondville/timeinterp_Bondville.F90 index 431938c64..b59ff0d1a 100644 --- a/lis/metforcing/Bondville/timeinterp_Bondville.F90 +++ b/lis/metforcing/Bondville/timeinterp_Bondville.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/COAMPSout_forcingMod.F90 b/lis/metforcing/COAMPSout/COAMPSout_forcingMod.F90 index ccb247f8c..e10d66e69 100755 --- a/lis/metforcing/COAMPSout/COAMPSout_forcingMod.F90 +++ b/lis/metforcing/COAMPSout/COAMPSout_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/finalize_COAMPSout.F90 b/lis/metforcing/COAMPSout/finalize_COAMPSout.F90 index 3311a03e7..acaa7cbf8 100755 --- a/lis/metforcing/COAMPSout/finalize_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/finalize_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/get_COAMPSout.F90 b/lis/metforcing/COAMPSout/get_COAMPSout.F90 index b93b60aa4..e912995b7 100755 --- a/lis/metforcing/COAMPSout/get_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/get_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/read_COAMPSout.F90 b/lis/metforcing/COAMPSout/read_COAMPSout.F90 index c379f3a2c..1d3d5a373 100755 --- a/lis/metforcing/COAMPSout/read_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/read_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/readcrd_COAMPSout.F90 b/lis/metforcing/COAMPSout/readcrd_COAMPSout.F90 index 1a01664d6..96a7fc68c 100755 --- a/lis/metforcing/COAMPSout/readcrd_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/readcrd_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/reset_COAMPSout.F90 b/lis/metforcing/COAMPSout/reset_COAMPSout.F90 index 0efed5044..4338cc0ed 100755 --- a/lis/metforcing/COAMPSout/reset_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/reset_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/COAMPSout/timeinterp_COAMPSout.F90 b/lis/metforcing/COAMPSout/timeinterp_COAMPSout.F90 index 421f870fc..e09bad862 100755 --- a/lis/metforcing/COAMPSout/timeinterp_COAMPSout.F90 +++ b/lis/metforcing/COAMPSout/timeinterp_COAMPSout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/HiMATGMU_forcingMod.F90 b/lis/metforcing/HiMAT_GMU/HiMATGMU_forcingMod.F90 index f7232df95..a5b72f03e 100644 --- a/lis/metforcing/HiMAT_GMU/HiMATGMU_forcingMod.F90 +++ b/lis/metforcing/HiMAT_GMU/HiMATGMU_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/HiMATGMUfile.F90 b/lis/metforcing/HiMAT_GMU/HiMATGMUfile.F90 index 4169748f3..6fd5d4ac7 100644 --- a/lis/metforcing/HiMAT_GMU/HiMATGMUfile.F90 +++ b/lis/metforcing/HiMAT_GMU/HiMATGMUfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/finalize_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/finalize_HiMATGMU.F90 index 7446866cb..679fb565c 100644 --- a/lis/metforcing/HiMAT_GMU/finalize_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/finalize_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/get_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/get_HiMATGMU.F90 index 882cf5d39..e7353fa84 100644 --- a/lis/metforcing/HiMAT_GMU/get_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/get_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/interp_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/interp_HiMATGMU.F90 index 14e11c022..46914bca5 100644 --- a/lis/metforcing/HiMAT_GMU/interp_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/interp_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/read_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/read_HiMATGMU.F90 index f50c540b3..42c98ead3 100644 --- a/lis/metforcing/HiMAT_GMU/read_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/read_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/readcrd_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/readcrd_HiMATGMU.F90 index c21bedacd..62477c313 100644 --- a/lis/metforcing/HiMAT_GMU/readcrd_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/readcrd_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/reset_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/reset_HiMATGMU.F90 index 2cbf7e7ea..daeb42ea8 100644 --- a/lis/metforcing/HiMAT_GMU/reset_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/reset_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/HiMAT_GMU/timeinterp_HiMATGMU.F90 b/lis/metforcing/HiMAT_GMU/timeinterp_HiMATGMU.F90 index 299fa0a87..5ba708f53 100644 --- a/lis/metforcing/HiMAT_GMU/timeinterp_HiMATGMU.F90 +++ b/lis/metforcing/HiMAT_GMU/timeinterp_HiMATGMU.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/0Intro_Loobos.txt b/lis/metforcing/Loobos/0Intro_Loobos.txt index fe5cda43d..3d79d3ac4 100755 --- a/lis/metforcing/Loobos/0Intro_Loobos.txt +++ b/lis/metforcing/Loobos/0Intro_Loobos.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/Loobos_forcingMod.F90 b/lis/metforcing/Loobos/Loobos_forcingMod.F90 index dce85b59d..2510fcb61 100755 --- a/lis/metforcing/Loobos/Loobos_forcingMod.F90 +++ b/lis/metforcing/Loobos/Loobos_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/0Intro_Bondville.txt b/lis/metforcing/Loobos/code/0Intro_Bondville.txt index 9a06e40a1..a6a0d7c50 100755 --- a/lis/metforcing/Loobos/code/0Intro_Bondville.txt +++ b/lis/metforcing/Loobos/code/0Intro_Bondville.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/Loobos_forcingMod.F90 b/lis/metforcing/Loobos/code/Loobos_forcingMod.F90 index 5115350aa..7aa7054fb 100755 --- a/lis/metforcing/Loobos/code/Loobos_forcingMod.F90 +++ b/lis/metforcing/Loobos/code/Loobos_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/finalize_Loobos.F90 b/lis/metforcing/Loobos/code/finalize_Loobos.F90 index 777dfe9a0..b112933b1 100755 --- a/lis/metforcing/Loobos/code/finalize_Loobos.F90 +++ b/lis/metforcing/Loobos/code/finalize_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/get_Loobos.F90 b/lis/metforcing/Loobos/code/get_Loobos.F90 index b3679f891..2cbbbf115 100755 --- a/lis/metforcing/Loobos/code/get_Loobos.F90 +++ b/lis/metforcing/Loobos/code/get_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/read_Loobos.F90 b/lis/metforcing/Loobos/code/read_Loobos.F90 index 95338bc3f..c42847486 100755 --- a/lis/metforcing/Loobos/code/read_Loobos.F90 +++ b/lis/metforcing/Loobos/code/read_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/readcrd_Loobos.F90 b/lis/metforcing/Loobos/code/readcrd_Loobos.F90 index 618fba5f6..8223f30c6 100755 --- a/lis/metforcing/Loobos/code/readcrd_Loobos.F90 +++ b/lis/metforcing/Loobos/code/readcrd_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/code/timeinterp_Loobos.F90 b/lis/metforcing/Loobos/code/timeinterp_Loobos.F90 index 044e67bcf..736901dc2 100755 --- a/lis/metforcing/Loobos/code/timeinterp_Loobos.F90 +++ b/lis/metforcing/Loobos/code/timeinterp_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/finalize_Loobos.F90 b/lis/metforcing/Loobos/finalize_Loobos.F90 index 84ef69c16..28b4f7231 100755 --- a/lis/metforcing/Loobos/finalize_Loobos.F90 +++ b/lis/metforcing/Loobos/finalize_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/get_Loobos.F90 b/lis/metforcing/Loobos/get_Loobos.F90 index 3763c9f06..8762d1d93 100755 --- a/lis/metforcing/Loobos/get_Loobos.F90 +++ b/lis/metforcing/Loobos/get_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/read_Loobos.F90 b/lis/metforcing/Loobos/read_Loobos.F90 index 7da9ba284..230c2445c 100755 --- a/lis/metforcing/Loobos/read_Loobos.F90 +++ b/lis/metforcing/Loobos/read_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/readcrd_Loobos.F90 b/lis/metforcing/Loobos/readcrd_Loobos.F90 index 9c8a4a5a6..8bfb96efd 100755 --- a/lis/metforcing/Loobos/readcrd_Loobos.F90 +++ b/lis/metforcing/Loobos/readcrd_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/Loobos/timeinterp_Loobos.F90 b/lis/metforcing/Loobos/timeinterp_Loobos.F90 index 7448df5a8..4e1e1c74b 100755 --- a/lis/metforcing/Loobos/timeinterp_Loobos.F90 +++ b/lis/metforcing/Loobos/timeinterp_Loobos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/PALSmetdata_forcingMod.F90 b/lis/metforcing/PALSmetdata/PALSmetdata_forcingMod.F90 index 085c955f7..deaa3379a 100644 --- a/lis/metforcing/PALSmetdata/PALSmetdata_forcingMod.F90 +++ b/lis/metforcing/PALSmetdata/PALSmetdata_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/finalize_PALSmetdata.F90 b/lis/metforcing/PALSmetdata/finalize_PALSmetdata.F90 index 4c3f12739..904c959ca 100644 --- a/lis/metforcing/PALSmetdata/finalize_PALSmetdata.F90 +++ b/lis/metforcing/PALSmetdata/finalize_PALSmetdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/get_PALSmetdata.F90 b/lis/metforcing/PALSmetdata/get_PALSmetdata.F90 index f79ef8444..241834d3a 100644 --- a/lis/metforcing/PALSmetdata/get_PALSmetdata.F90 +++ b/lis/metforcing/PALSmetdata/get_PALSmetdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/readcrd_PALSmetdata.F90 b/lis/metforcing/PALSmetdata/readcrd_PALSmetdata.F90 index f81444c10..67fa648bf 100644 --- a/lis/metforcing/PALSmetdata/readcrd_PALSmetdata.F90 +++ b/lis/metforcing/PALSmetdata/readcrd_PALSmetdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/reset_PALSmetdata.F90 b/lis/metforcing/PALSmetdata/reset_PALSmetdata.F90 index dd8c69d6b..a7a2fba3c 100644 --- a/lis/metforcing/PALSmetdata/reset_PALSmetdata.F90 +++ b/lis/metforcing/PALSmetdata/reset_PALSmetdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/PALSmetdata/timeinterp_PALSmetdata.F90 b/lis/metforcing/PALSmetdata/timeinterp_PALSmetdata.F90 index b481eb0f4..49a907752 100644 --- a/lis/metforcing/PALSmetdata/timeinterp_PALSmetdata.F90 +++ b/lis/metforcing/PALSmetdata/timeinterp_PALSmetdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/0Intro_rfe2daily.txt b/lis/metforcing/RFE2Daily/0Intro_rfe2daily.txt index 1427f72eb..12fb7c5f2 100644 --- a/lis/metforcing/RFE2Daily/0Intro_rfe2daily.txt +++ b/lis/metforcing/RFE2Daily/0Intro_rfe2daily.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 b/lis/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 index 5afaeb30c..32df3f9bc 100644 --- a/lis/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 +++ b/lis/metforcing/RFE2Daily/RFE2Daily_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/finalize_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/finalize_RFE2Daily.F90 index c0d9fe95c..0d1755d27 100644 --- a/lis/metforcing/RFE2Daily/finalize_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/finalize_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/get_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/get_RFE2Daily.F90 index 427385923..31057c3bf 100644 --- a/lis/metforcing/RFE2Daily/get_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/get_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 index 153ad9483..9fd004597 100644 --- a/lis/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/readcrd_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 index 142ccbde4..a8974722d 100644 --- a/lis/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/readprecip_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/reproject_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/reproject_RFE2Daily.F90 index e1ab2c518..42e698dd8 100644 --- a/lis/metforcing/RFE2Daily/reproject_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/reproject_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 b/lis/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 index f291b6cd5..b97720d6f 100644 --- a/lis/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 +++ b/lis/metforcing/RFE2Daily/timeinterp_RFE2Daily.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/0Intro_rfe2gdas.txt b/lis/metforcing/RFE2gdas/0Intro_rfe2gdas.txt index b4e9d5102..73f781347 100644 --- a/lis/metforcing/RFE2gdas/0Intro_rfe2gdas.txt +++ b/lis/metforcing/RFE2gdas/0Intro_rfe2gdas.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 b/lis/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 index ef113a562..893ab94a8 100644 --- a/lis/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 +++ b/lis/metforcing/RFE2gdas/RFE2gdas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/finalize_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/finalize_RFE2gdas.F90 index 7afbcc88c..32a3e7bcc 100644 --- a/lis/metforcing/RFE2gdas/finalize_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/finalize_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/get_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/get_RFE2gdas.F90 index 2d4310d55..904973719 100644 --- a/lis/metforcing/RFE2gdas/get_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/get_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/readRFE2gdascrd.F90 b/lis/metforcing/RFE2gdas/readRFE2gdascrd.F90 index a6abe8b25..7367a200d 100644 --- a/lis/metforcing/RFE2gdas/readRFE2gdascrd.F90 +++ b/lis/metforcing/RFE2gdas/readRFE2gdascrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 index 7d76f91b9..73247bde9 100644 --- a/lis/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/readprecip_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/reproject_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/reproject_RFE2gdas.F90 index 4f8d8dbda..12cee3830 100644 --- a/lis/metforcing/RFE2gdas/reproject_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/reproject_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/reset_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/reset_RFE2gdas.F90 index 8a86d0bc6..f0a30cd31 100644 --- a/lis/metforcing/RFE2gdas/reset_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/reset_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 b/lis/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 index 58f60fbf2..f005264e1 100644 --- a/lis/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 +++ b/lis/metforcing/RFE2gdas/timeinterp_RFE2gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/0Intro_WRF_AKdomain.txt b/lis/metforcing/WRFAKdom/0Intro_WRF_AKdomain.txt index 799a31357..0ff988425 100644 --- a/lis/metforcing/WRFAKdom/0Intro_WRF_AKdomain.txt +++ b/lis/metforcing/WRFAKdom/0Intro_WRF_AKdomain.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 b/lis/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 index c592ec75b..5addf1906 100644 --- a/lis/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 +++ b/lis/metforcing/WRFAKdom/WRF_AKdom_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/finalize_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/finalize_WRF_AKdom.F90 index 8d19ccc09..0d4bace47 100644 --- a/lis/metforcing/WRFAKdom/finalize_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/finalize_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/get_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/get_WRF_AKdom.F90 index 5e6cdf186..1018e643d 100644 --- a/lis/metforcing/WRFAKdom/get_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/get_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/read_WRFAK_elev.F90 b/lis/metforcing/WRFAKdom/read_WRFAK_elev.F90 index cfadedb92..fe4524b3c 100644 --- a/lis/metforcing/WRFAKdom/read_WRFAK_elev.F90 +++ b/lis/metforcing/WRFAKdom/read_WRFAK_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/read_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/read_WRF_AKdom.F90 index 9411427dd..c3705053b 100644 --- a/lis/metforcing/WRFAKdom/read_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/read_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 index b1d5f17f0..9550b30b2 100644 --- a/lis/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/readconfig_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/reset_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/reset_WRF_AKdom.F90 index c7ce529b4..82e52d34f 100644 --- a/lis/metforcing/WRFAKdom/reset_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/reset_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFAKdom/timeinterp_WRF_AKdom.F90 b/lis/metforcing/WRFAKdom/timeinterp_WRF_AKdom.F90 index b2ad6f836..eb12d8766 100644 --- a/lis/metforcing/WRFAKdom/timeinterp_WRF_AKdom.F90 +++ b/lis/metforcing/WRFAKdom/timeinterp_WRF_AKdom.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/0Intro_wrfout.txt b/lis/metforcing/WRFout/0Intro_wrfout.txt index bd5327974..0c2872168 100644 --- a/lis/metforcing/WRFout/0Intro_wrfout.txt +++ b/lis/metforcing/WRFout/0Intro_wrfout.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/WRFout_forcingMod.F90 b/lis/metforcing/WRFout/WRFout_forcingMod.F90 index d4108f74d..1d14995f9 100644 --- a/lis/metforcing/WRFout/WRFout_forcingMod.F90 +++ b/lis/metforcing/WRFout/WRFout_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/finalize_WRFout.F90 b/lis/metforcing/WRFout/finalize_WRFout.F90 index 5459e4022..9b0a5c4d6 100644 --- a/lis/metforcing/WRFout/finalize_WRFout.F90 +++ b/lis/metforcing/WRFout/finalize_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/get_WRFout.F90 b/lis/metforcing/WRFout/get_WRFout.F90 index 19792add0..1e3156655 100644 --- a/lis/metforcing/WRFout/get_WRFout.F90 +++ b/lis/metforcing/WRFout/get_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/read_WRFout.F90 b/lis/metforcing/WRFout/read_WRFout.F90 index 936d3a9fd..aca161c57 100644 --- a/lis/metforcing/WRFout/read_WRFout.F90 +++ b/lis/metforcing/WRFout/read_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/readcrd_WRFout.F90 b/lis/metforcing/WRFout/readcrd_WRFout.F90 index c35e522f6..9987165ce 100644 --- a/lis/metforcing/WRFout/readcrd_WRFout.F90 +++ b/lis/metforcing/WRFout/readcrd_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/reset_WRFout.F90 b/lis/metforcing/WRFout/reset_WRFout.F90 index 45140d8cb..196fac027 100644 --- a/lis/metforcing/WRFout/reset_WRFout.F90 +++ b/lis/metforcing/WRFout/reset_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFout/timeinterp_WRFout.F90 b/lis/metforcing/WRFout/timeinterp_WRFout.F90 index 0ec781d36..ff93bc288 100644 --- a/lis/metforcing/WRFout/timeinterp_WRFout.F90 +++ b/lis/metforcing/WRFout/timeinterp_WRFout.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/0Intro_WRFoutv2.txt b/lis/metforcing/WRFoutv2/0Intro_WRFoutv2.txt index d4184af06..522db3728 100644 --- a/lis/metforcing/WRFoutv2/0Intro_WRFoutv2.txt +++ b/lis/metforcing/WRFoutv2/0Intro_WRFoutv2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 b/lis/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 index 2d6d9f861..67bf95f3d 100644 --- a/lis/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 +++ b/lis/metforcing/WRFoutv2/WRFoutv2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/finalize_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/finalize_WRFoutv2.F90 index 139dd0e82..215dcb891 100644 --- a/lis/metforcing/WRFoutv2/finalize_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/finalize_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/get_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/get_WRFoutv2.F90 index b1a4101c4..c29e2aacc 100644 --- a/lis/metforcing/WRFoutv2/get_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/get_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/read_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/read_WRFoutv2.F90 index 9a4d0b916..62ef489eb 100644 --- a/lis/metforcing/WRFoutv2/read_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/read_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 b/lis/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 index f88165a26..c436be473 100644 --- a/lis/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 +++ b/lis/metforcing/WRFoutv2/read_WRFoutv2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 index 8969b85f7..45089b20a 100644 --- a/lis/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/readconfig_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/reset_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/reset_WRFoutv2.F90 index 1db445435..d19e574ff 100644 --- a/lis/metforcing/WRFoutv2/reset_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/reset_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/WRFoutv2/timeinterp_WRFoutv2.F90 b/lis/metforcing/WRFoutv2/timeinterp_WRFoutv2.F90 index 65c6f19e8..200fec839 100644 --- a/lis/metforcing/WRFoutv2/timeinterp_WRFoutv2.F90 +++ b/lis/metforcing/WRFoutv2/timeinterp_WRFoutv2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/0Intro_agrmetradps.txt b/lis/metforcing/agrradps/0Intro_agrmetradps.txt index 756b12f9b..f8ca0356b 100644 --- a/lis/metforcing/agrradps/0Intro_agrmetradps.txt +++ b/lis/metforcing/agrradps/0Intro_agrmetradps.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/agrlwdn.F90 b/lis/metforcing/agrradps/agrlwdn.F90 index 6a859fa7f..2ddfb3a99 100644 --- a/lis/metforcing/agrradps/agrlwdn.F90 +++ b/lis/metforcing/agrradps/agrlwdn.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/agrradps_filenames.F90 b/lis/metforcing/agrradps/agrradps_filenames.F90 index a0bc16ea4..a890a5093 100644 --- a/lis/metforcing/agrradps/agrradps_filenames.F90 +++ b/lis/metforcing/agrradps/agrradps_filenames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/agrradps_forcingMod.F90 b/lis/metforcing/agrradps/agrradps_forcingMod.F90 index a1b599e43..410ac94c6 100644 --- a/lis/metforcing/agrradps/agrradps_forcingMod.F90 +++ b/lis/metforcing/agrradps/agrradps_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/finalize_agrradps.F90 b/lis/metforcing/agrradps/finalize_agrradps.F90 index 35e5102d9..795ba9104 100644 --- a/lis/metforcing/agrradps/finalize_agrradps.F90 +++ b/lis/metforcing/agrradps/finalize_agrradps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/get_agrradps.F90 b/lis/metforcing/agrradps/get_agrradps.F90 index c01695486..7eee12819 100644 --- a/lis/metforcing/agrradps/get_agrradps.F90 +++ b/lis/metforcing/agrradps/get_agrradps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/interp_agrradpsvar.F90 b/lis/metforcing/agrradps/interp_agrradpsvar.F90 index 25602012a..35631e29e 100644 --- a/lis/metforcing/agrradps/interp_agrradpsvar.F90 +++ b/lis/metforcing/agrradps/interp_agrradpsvar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/read_agrradps.F90 b/lis/metforcing/agrradps/read_agrradps.F90 index 389a49fe5..cc96d2433 100644 --- a/lis/metforcing/agrradps/read_agrradps.F90 +++ b/lis/metforcing/agrradps/read_agrradps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/readcrd_agrradps.F90 b/lis/metforcing/agrradps/readcrd_agrradps.F90 index 2475f4a69..00bae94ea 100644 --- a/lis/metforcing/agrradps/readcrd_agrradps.F90 +++ b/lis/metforcing/agrradps/readcrd_agrradps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/agrradps/timeinterp_agrradps.F90 b/lis/metforcing/agrradps/timeinterp_agrradps.F90 index 564298457..e73bc00ee 100644 --- a/lis/metforcing/agrradps/timeinterp_agrradps.F90 +++ b/lis/metforcing/agrradps/timeinterp_agrradps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/chirps2_forcingMod.F90 b/lis/metforcing/chirps2/chirps2_forcingMod.F90 index aa85ef527..53d19fe69 100644 --- a/lis/metforcing/chirps2/chirps2_forcingMod.F90 +++ b/lis/metforcing/chirps2/chirps2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/finalize_chirps2.F90 b/lis/metforcing/chirps2/finalize_chirps2.F90 index b28ec12b8..b29a3dbef 100644 --- a/lis/metforcing/chirps2/finalize_chirps2.F90 +++ b/lis/metforcing/chirps2/finalize_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/get_chirps2.F90 b/lis/metforcing/chirps2/get_chirps2.F90 index a985680e6..d28cf65d7 100644 --- a/lis/metforcing/chirps2/get_chirps2.F90 +++ b/lis/metforcing/chirps2/get_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/read_chirps2.F90 b/lis/metforcing/chirps2/read_chirps2.F90 index c10ab2847..498f6d3f5 100644 --- a/lis/metforcing/chirps2/read_chirps2.F90 +++ b/lis/metforcing/chirps2/read_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/readconfig_chirps2.F90 b/lis/metforcing/chirps2/readconfig_chirps2.F90 index c4ce8f7ac..3bdf86d8e 100644 --- a/lis/metforcing/chirps2/readconfig_chirps2.F90 +++ b/lis/metforcing/chirps2/readconfig_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/reset_chirps2.F90 b/lis/metforcing/chirps2/reset_chirps2.F90 index 5d103a480..84b405b6e 100644 --- a/lis/metforcing/chirps2/reset_chirps2.F90 +++ b/lis/metforcing/chirps2/reset_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/chirps2/timeinterp_chirps2.F90 b/lis/metforcing/chirps2/timeinterp_chirps2.F90 index 70f04c860..1e080c3e5 100644 --- a/lis/metforcing/chirps2/timeinterp_chirps2.F90 +++ b/lis/metforcing/chirps2/timeinterp_chirps2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/climatology_SpatialInterpMod.F90 b/lis/metforcing/climatology/climatology_SpatialInterpMod.F90 index 21970f4d2..d6fe13f5c 100644 --- a/lis/metforcing/climatology/climatology_SpatialInterpMod.F90 +++ b/lis/metforcing/climatology/climatology_SpatialInterpMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/climatology_VariablesMod.F90 b/lis/metforcing/climatology/climatology_VariablesMod.F90 index 4087baa02..6a51d31af 100644 --- a/lis/metforcing/climatology/climatology_VariablesMod.F90 +++ b/lis/metforcing/climatology/climatology_VariablesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/climatology_forcingMod.F90 b/lis/metforcing/climatology/climatology_forcingMod.F90 index 832799694..e53a06887 100644 --- a/lis/metforcing/climatology/climatology_forcingMod.F90 +++ b/lis/metforcing/climatology/climatology_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/finalize_climatology.F90 b/lis/metforcing/climatology/finalize_climatology.F90 index 935356806..fd0afadc9 100644 --- a/lis/metforcing/climatology/finalize_climatology.F90 +++ b/lis/metforcing/climatology/finalize_climatology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/get_climatology.F90 b/lis/metforcing/climatology/get_climatology.F90 index 126893718..fee6b5705 100644 --- a/lis/metforcing/climatology/get_climatology.F90 +++ b/lis/metforcing/climatology/get_climatology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/get_climatology_filename.F90 b/lis/metforcing/climatology/get_climatology_filename.F90 index 292ae47b8..ab85777cb 100755 --- a/lis/metforcing/climatology/get_climatology_filename.F90 +++ b/lis/metforcing/climatology/get_climatology_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/readcrd_climatology.F90 b/lis/metforcing/climatology/readcrd_climatology.F90 index a50f74767..ab9a822ac 100644 --- a/lis/metforcing/climatology/readcrd_climatology.F90 +++ b/lis/metforcing/climatology/readcrd_climatology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/reset_climatology.F90 b/lis/metforcing/climatology/reset_climatology.F90 index 602c8c617..cacf9c847 100644 --- a/lis/metforcing/climatology/reset_climatology.F90 +++ b/lis/metforcing/climatology/reset_climatology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/climatology/timeinterp_climatology.F90 b/lis/metforcing/climatology/timeinterp_climatology.F90 index d6e7c2d3d..bf65b71d5 100644 --- a/lis/metforcing/climatology/timeinterp_climatology.F90 +++ b/lis/metforcing/climatology/timeinterp_climatology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/0Intro_cmap.txt b/lis/metforcing/cmap/0Intro_cmap.txt index 27ca3ad11..826606afa 100644 --- a/lis/metforcing/cmap/0Intro_cmap.txt +++ b/lis/metforcing/cmap/0Intro_cmap.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/cmap_forcingMod.F90 b/lis/metforcing/cmap/cmap_forcingMod.F90 index 73df757b0..cda7b5a07 100644 --- a/lis/metforcing/cmap/cmap_forcingMod.F90 +++ b/lis/metforcing/cmap/cmap_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/cmap_reset_interp_input.F90 b/lis/metforcing/cmap/cmap_reset_interp_input.F90 index ea20fb5a6..eb6134004 100644 --- a/lis/metforcing/cmap/cmap_reset_interp_input.F90 +++ b/lis/metforcing/cmap/cmap_reset_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/finalize_cmap.F90 b/lis/metforcing/cmap/finalize_cmap.F90 index 9b740bde1..7f5e376d0 100644 --- a/lis/metforcing/cmap/finalize_cmap.F90 +++ b/lis/metforcing/cmap/finalize_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/get_cmap.F90 b/lis/metforcing/cmap/get_cmap.F90 index eae05cc71..23f3416b6 100644 --- a/lis/metforcing/cmap/get_cmap.F90 +++ b/lis/metforcing/cmap/get_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/interp_cmap.F90 b/lis/metforcing/cmap/interp_cmap.F90 index 00f7a641a..8e9d2e2b3 100644 --- a/lis/metforcing/cmap/interp_cmap.F90 +++ b/lis/metforcing/cmap/interp_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/read_cmap.F90 b/lis/metforcing/cmap/read_cmap.F90 index d0a1acee0..56e9c992b 100644 --- a/lis/metforcing/cmap/read_cmap.F90 +++ b/lis/metforcing/cmap/read_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/readcrd_cmap.F90 b/lis/metforcing/cmap/readcrd_cmap.F90 index fb56fd248..d69c19afa 100644 --- a/lis/metforcing/cmap/readcrd_cmap.F90 +++ b/lis/metforcing/cmap/readcrd_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmap/timeinterp_cmap.F90 b/lis/metforcing/cmap/timeinterp_cmap.F90 index ada7238c2..90e5d65bc 100644 --- a/lis/metforcing/cmap/timeinterp_cmap.F90 +++ b/lis/metforcing/cmap/timeinterp_cmap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/0Intro_cmorph.txt b/lis/metforcing/cmorph/0Intro_cmorph.txt index dadc067a1..baeea1144 100644 --- a/lis/metforcing/cmorph/0Intro_cmorph.txt +++ b/lis/metforcing/cmorph/0Intro_cmorph.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/cm_readzipf.c b/lis/metforcing/cmorph/cm_readzipf.c index 78e48f9b7..4bdf9a6c9 100644 --- a/lis/metforcing/cmorph/cm_readzipf.c +++ b/lis/metforcing/cmorph/cm_readzipf.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/cmorph_forcingMod.F90 b/lis/metforcing/cmorph/cmorph_forcingMod.F90 index fb570d50b..ceaa83c6c 100644 --- a/lis/metforcing/cmorph/cmorph_forcingMod.F90 +++ b/lis/metforcing/cmorph/cmorph_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/finalize_cmorph.F90 b/lis/metforcing/cmorph/finalize_cmorph.F90 index 4ea5f3b2e..3871e42cc 100644 --- a/lis/metforcing/cmorph/finalize_cmorph.F90 +++ b/lis/metforcing/cmorph/finalize_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/fmktime.c b/lis/metforcing/cmorph/fmktime.c index f875c7c42..ab59a0a99 100755 --- a/lis/metforcing/cmorph/fmktime.c +++ b/lis/metforcing/cmorph/fmktime.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/get_cmorph.F90 b/lis/metforcing/cmorph/get_cmorph.F90 index b8ed7fcc6..8649e0be6 100644 --- a/lis/metforcing/cmorph/get_cmorph.F90 +++ b/lis/metforcing/cmorph/get_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/interp_cmorph.F90 b/lis/metforcing/cmorph/interp_cmorph.F90 index c6c456960..d27314a97 100644 --- a/lis/metforcing/cmorph/interp_cmorph.F90 +++ b/lis/metforcing/cmorph/interp_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/read_cmorph.F90 b/lis/metforcing/cmorph/read_cmorph.F90 index 1aeb0b1df..51975f396 100644 --- a/lis/metforcing/cmorph/read_cmorph.F90 +++ b/lis/metforcing/cmorph/read_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/readcrd_cmorph.F90 b/lis/metforcing/cmorph/readcrd_cmorph.F90 index c202f522c..f983f2ec0 100644 --- a/lis/metforcing/cmorph/readcrd_cmorph.F90 +++ b/lis/metforcing/cmorph/readcrd_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/cmorph/timeinterp_cmorph.F90 b/lis/metforcing/cmorph/timeinterp_cmorph.F90 index 45e492a35..8f3d38ab2 100644 --- a/lis/metforcing/cmorph/timeinterp_cmorph.F90 +++ b/lis/metforcing/cmorph/timeinterp_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/0Intro_ecmwf.txt b/lis/metforcing/ecmwf/0Intro_ecmwf.txt index b80a8e876..846d58410 100644 --- a/lis/metforcing/ecmwf/0Intro_ecmwf.txt +++ b/lis/metforcing/ecmwf/0Intro_ecmwf.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/ecmwf_forcingMod.F90 b/lis/metforcing/ecmwf/ecmwf_forcingMod.F90 index e4eafc90b..0d70e9456 100644 --- a/lis/metforcing/ecmwf/ecmwf_forcingMod.F90 +++ b/lis/metforcing/ecmwf/ecmwf_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/finalize_ecmwf.F90 b/lis/metforcing/ecmwf/finalize_ecmwf.F90 index f05b68612..13a620c37 100644 --- a/lis/metforcing/ecmwf/finalize_ecmwf.F90 +++ b/lis/metforcing/ecmwf/finalize_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/get_ecmwf.F90 b/lis/metforcing/ecmwf/get_ecmwf.F90 index fb5ed6a7b..26051188e 100644 --- a/lis/metforcing/ecmwf/get_ecmwf.F90 +++ b/lis/metforcing/ecmwf/get_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/read_ecmwf.F90 b/lis/metforcing/ecmwf/read_ecmwf.F90 index f13e32009..0ef807606 100644 --- a/lis/metforcing/ecmwf/read_ecmwf.F90 +++ b/lis/metforcing/ecmwf/read_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/read_ecmwf_elev.F90 b/lis/metforcing/ecmwf/read_ecmwf_elev.F90 index c3e442394..7ce034031 100644 --- a/lis/metforcing/ecmwf/read_ecmwf_elev.F90 +++ b/lis/metforcing/ecmwf/read_ecmwf_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/readcrd_ecmwf.F90 b/lis/metforcing/ecmwf/readcrd_ecmwf.F90 index d23cf4136..f46e83243 100644 --- a/lis/metforcing/ecmwf/readcrd_ecmwf.F90 +++ b/lis/metforcing/ecmwf/readcrd_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/reset_ecmwf.F90 b/lis/metforcing/ecmwf/reset_ecmwf.F90 index 3bf54e0f4..75c966e5b 100644 --- a/lis/metforcing/ecmwf/reset_ecmwf.F90 +++ b/lis/metforcing/ecmwf/reset_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/ecmwf/timeinterp_ecmwf.F90 b/lis/metforcing/ecmwf/timeinterp_ecmwf.F90 index 2482dcf20..cb44f3e67 100644 --- a/lis/metforcing/ecmwf/timeinterp_ecmwf.F90 +++ b/lis/metforcing/ecmwf/timeinterp_ecmwf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/era5_forcingMod.F90 b/lis/metforcing/era5/era5_forcingMod.F90 index 18a359fb4..d6403b1d5 100644 --- a/lis/metforcing/era5/era5_forcingMod.F90 +++ b/lis/metforcing/era5/era5_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/finalize_era5.F90 b/lis/metforcing/era5/finalize_era5.F90 index 7e72e3818..22abea03a 100644 --- a/lis/metforcing/era5/finalize_era5.F90 +++ b/lis/metforcing/era5/finalize_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/get_era5.F90 b/lis/metforcing/era5/get_era5.F90 index e6588d5e5..fe19541a8 100644 --- a/lis/metforcing/era5/get_era5.F90 +++ b/lis/metforcing/era5/get_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/read_era5.F90 b/lis/metforcing/era5/read_era5.F90 index 10c0c3bb5..0a44e8f99 100644 --- a/lis/metforcing/era5/read_era5.F90 +++ b/lis/metforcing/era5/read_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/read_era5_elev.F90 b/lis/metforcing/era5/read_era5_elev.F90 index 7ad666620..b8a2c89c8 100644 --- a/lis/metforcing/era5/read_era5_elev.F90 +++ b/lis/metforcing/era5/read_era5_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/readcrd_era5.F90 b/lis/metforcing/era5/readcrd_era5.F90 index b94abcd44..480549bef 100644 --- a/lis/metforcing/era5/readcrd_era5.F90 +++ b/lis/metforcing/era5/readcrd_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/reset_era5.F90 b/lis/metforcing/era5/reset_era5.F90 index f5ad200f3..e9e19f31c 100644 --- a/lis/metforcing/era5/reset_era5.F90 +++ b/lis/metforcing/era5/reset_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/era5/timeinterp_era5.F90 b/lis/metforcing/era5/timeinterp_era5.F90 index a3a5b430d..bbcacee96 100644 --- a/lis/metforcing/era5/timeinterp_era5.F90 +++ b/lis/metforcing/era5/timeinterp_era5.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/finalize_galwem.F90 b/lis/metforcing/galwem/finalize_galwem.F90 index 6a1871ed1..6ec94e9a0 100644 --- a/lis/metforcing/galwem/finalize_galwem.F90 +++ b/lis/metforcing/galwem/finalize_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/galwem_forcingMod.F90 b/lis/metforcing/galwem/galwem_forcingMod.F90 index d6e0e30c0..1068d7a8d 100644 --- a/lis/metforcing/galwem/galwem_forcingMod.F90 +++ b/lis/metforcing/galwem/galwem_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index a029b5109..914a1860f 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/read_galwem.F90 b/lis/metforcing/galwem/read_galwem.F90 index 229c180c7..6356b1a6b 100644 --- a/lis/metforcing/galwem/read_galwem.F90 +++ b/lis/metforcing/galwem/read_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/readcrd_galwem.F90 b/lis/metforcing/galwem/readcrd_galwem.F90 index 8d6125ecc..7ad1cc6df 100644 --- a/lis/metforcing/galwem/readcrd_galwem.F90 +++ b/lis/metforcing/galwem/readcrd_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/reset_galwem.F90 b/lis/metforcing/galwem/reset_galwem.F90 index 32b62bc37..1a0b2486e 100644 --- a/lis/metforcing/galwem/reset_galwem.F90 +++ b/lis/metforcing/galwem/reset_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem/timeinterp_galwem.F90 b/lis/metforcing/galwem/timeinterp_galwem.F90 index 50eef25ac..c8d160e31 100644 --- a/lis/metforcing/galwem/timeinterp_galwem.F90 +++ b/lis/metforcing/galwem/timeinterp_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/finalize_galwemge.F90 b/lis/metforcing/galwem_ge/finalize_galwemge.F90 index e0866af94..525d7f153 100644 --- a/lis/metforcing/galwem_ge/finalize_galwemge.F90 +++ b/lis/metforcing/galwem_ge/finalize_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/galwemge_forcingMod.F90 b/lis/metforcing/galwem_ge/galwemge_forcingMod.F90 index 664d7e807..bb63cb7f7 100644 --- a/lis/metforcing/galwem_ge/galwemge_forcingMod.F90 +++ b/lis/metforcing/galwem_ge/galwemge_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/get_galwemge.F90 b/lis/metforcing/galwem_ge/get_galwemge.F90 index ba353729e..5b8120dae 100644 --- a/lis/metforcing/galwem_ge/get_galwemge.F90 +++ b/lis/metforcing/galwem_ge/get_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/read_galwemge.F90 b/lis/metforcing/galwem_ge/read_galwemge.F90 index 10870c11d..ce43a1f21 100644 --- a/lis/metforcing/galwem_ge/read_galwemge.F90 +++ b/lis/metforcing/galwem_ge/read_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/readcrd_galwemge.F90 b/lis/metforcing/galwem_ge/readcrd_galwemge.F90 index 038ab9fd0..87339d5c9 100644 --- a/lis/metforcing/galwem_ge/readcrd_galwemge.F90 +++ b/lis/metforcing/galwem_ge/readcrd_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/reset_galwemge.F90 b/lis/metforcing/galwem_ge/reset_galwemge.F90 index c54c80289..7bcd64181 100644 --- a/lis/metforcing/galwem_ge/reset_galwemge.F90 +++ b/lis/metforcing/galwem_ge/reset_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/galwem_ge/timeinterp_galwemge.F90 b/lis/metforcing/galwem_ge/timeinterp_galwemge.F90 index 61f8afc0e..7c794961f 100644 --- a/lis/metforcing/galwem_ge/timeinterp_galwemge.F90 +++ b/lis/metforcing/galwem_ge/timeinterp_galwemge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/0Intro_gdas.txt b/lis/metforcing/gdas/0Intro_gdas.txt index c127d0719..dc8906d76 100644 --- a/lis/metforcing/gdas/0Intro_gdas.txt +++ b/lis/metforcing/gdas/0Intro_gdas.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/create_gdasf9_filename.F90 b/lis/metforcing/gdas/create_gdasf9_filename.F90 index dce891ee5..394cfa013 100644 --- a/lis/metforcing/gdas/create_gdasf9_filename.F90 +++ b/lis/metforcing/gdas/create_gdasf9_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/create_gdasfilename.F90 b/lis/metforcing/gdas/create_gdasfilename.F90 index 5efc7f019..f07ab5598 100644 --- a/lis/metforcing/gdas/create_gdasfilename.F90 +++ b/lis/metforcing/gdas/create_gdasfilename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/finalize_gdas.F90 b/lis/metforcing/gdas/finalize_gdas.F90 index a523155df..51e0ecbfa 100644 --- a/lis/metforcing/gdas/finalize_gdas.F90 +++ b/lis/metforcing/gdas/finalize_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/gdas_forcingMod.F90 b/lis/metforcing/gdas/gdas_forcingMod.F90 index e7134ca20..a2911b2c4 100644 --- a/lis/metforcing/gdas/gdas_forcingMod.F90 +++ b/lis/metforcing/gdas/gdas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/gdas_reset_interp_input.F90 b/lis/metforcing/gdas/gdas_reset_interp_input.F90 index 96de7ffab..c6f75bcd8 100644 --- a/lis/metforcing/gdas/gdas_reset_interp_input.F90 +++ b/lis/metforcing/gdas/gdas_reset_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/get_gdas.F90 b/lis/metforcing/gdas/get_gdas.F90 index 0fc3a5cb8..b5aa88596 100644 --- a/lis/metforcing/gdas/get_gdas.F90 +++ b/lis/metforcing/gdas/get_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/read_gdas.F90 b/lis/metforcing/gdas/read_gdas.F90 index e55443fa9..81ff49115 100644 --- a/lis/metforcing/gdas/read_gdas.F90 +++ b/lis/metforcing/gdas/read_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/read_gdas_elev.F90 b/lis/metforcing/gdas/read_gdas_elev.F90 index d998b6fc0..175402692 100644 --- a/lis/metforcing/gdas/read_gdas_elev.F90 +++ b/lis/metforcing/gdas/read_gdas_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/readcrd_gdas.F90 b/lis/metforcing/gdas/readcrd_gdas.F90 index a4646843a..7999e3805 100644 --- a/lis/metforcing/gdas/readcrd_gdas.F90 +++ b/lis/metforcing/gdas/readcrd_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/reset_gdas.F90 b/lis/metforcing/gdas/reset_gdas.F90 index f5ae4c8c9..ab53ccad0 100644 --- a/lis/metforcing/gdas/reset_gdas.F90 +++ b/lis/metforcing/gdas/reset_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdas/timeinterp_gdas.F90 b/lis/metforcing/gdas/timeinterp_gdas.F90 index 837a765a0..c4cb0ecf5 100644 --- a/lis/metforcing/gdas/timeinterp_gdas.F90 +++ b/lis/metforcing/gdas/timeinterp_gdas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/create_gdasT1534filename.F90 b/lis/metforcing/gdasT1534/create_gdasT1534filename.F90 index de8db80d5..f289e0543 100644 --- a/lis/metforcing/gdasT1534/create_gdasT1534filename.F90 +++ b/lis/metforcing/gdasT1534/create_gdasT1534filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/finalize_gdasT1534.F90 b/lis/metforcing/gdasT1534/finalize_gdasT1534.F90 index da22450e1..f36de2027 100644 --- a/lis/metforcing/gdasT1534/finalize_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/finalize_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/gdasT1534_forcingMod.F90 b/lis/metforcing/gdasT1534/gdasT1534_forcingMod.F90 index 7cf4d22a2..c0dd820c3 100644 --- a/lis/metforcing/gdasT1534/gdasT1534_forcingMod.F90 +++ b/lis/metforcing/gdasT1534/gdasT1534_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/get_gdasT1534.F90 b/lis/metforcing/gdasT1534/get_gdasT1534.F90 index 68eac731f..fa8c63ea9 100644 --- a/lis/metforcing/gdasT1534/get_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/get_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/read_gdasT1534.F90 b/lis/metforcing/gdasT1534/read_gdasT1534.F90 index f0c72120e..cb59de1f9 100644 --- a/lis/metforcing/gdasT1534/read_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/read_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/readcrd_gdasT1534.F90 b/lis/metforcing/gdasT1534/readcrd_gdasT1534.F90 index f8899dd9a..9cbc5191c 100644 --- a/lis/metforcing/gdasT1534/readcrd_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/readcrd_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/reset_gdasT1534.F90 b/lis/metforcing/gdasT1534/reset_gdasT1534.F90 index eebf40d7b..1fa7db36d 100644 --- a/lis/metforcing/gdasT1534/reset_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/reset_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gdasT1534/timeinterp_gdasT1534.F90 b/lis/metforcing/gdasT1534/timeinterp_gdasT1534.F90 index 7f836f4d3..d01628203 100644 --- a/lis/metforcing/gdasT1534/timeinterp_gdasT1534.F90 +++ b/lis/metforcing/gdasT1534/timeinterp_gdasT1534.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/finalize_gddp.F90 b/lis/metforcing/gddp/finalize_gddp.F90 index 0a53441dd..ba71f399a 100644 --- a/lis/metforcing/gddp/finalize_gddp.F90 +++ b/lis/metforcing/gddp/finalize_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/gddp_forcingMod.F90 b/lis/metforcing/gddp/gddp_forcingMod.F90 index 404e1e6da..5f507adc1 100644 --- a/lis/metforcing/gddp/gddp_forcingMod.F90 +++ b/lis/metforcing/gddp/gddp_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/get_gddp.F90 b/lis/metforcing/gddp/get_gddp.F90 index 00dc03c82..df5016339 100644 --- a/lis/metforcing/gddp/get_gddp.F90 +++ b/lis/metforcing/gddp/get_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/read_gddp.F90 b/lis/metforcing/gddp/read_gddp.F90 index 402994d9a..069f0a888 100644 --- a/lis/metforcing/gddp/read_gddp.F90 +++ b/lis/metforcing/gddp/read_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/readcrd_gddp.F90 b/lis/metforcing/gddp/readcrd_gddp.F90 index 71675f217..e4bd4caaa 100644 --- a/lis/metforcing/gddp/readcrd_gddp.F90 +++ b/lis/metforcing/gddp/readcrd_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/reset_gddp.F90 b/lis/metforcing/gddp/reset_gddp.F90 index 9ed5640a0..a90e9a6a8 100644 --- a/lis/metforcing/gddp/reset_gddp.F90 +++ b/lis/metforcing/gddp/reset_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gddp/timeinterp_gddp.F90 b/lis/metforcing/gddp/timeinterp_gddp.F90 index 7af3e42d5..b61ee5fa3 100644 --- a/lis/metforcing/gddp/timeinterp_gddp.F90 +++ b/lis/metforcing/gddp/timeinterp_gddp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/0Intro_gefs.txt b/lis/metforcing/gefs/0Intro_gefs.txt index 6d961601b..c02e5ce2e 100644 --- a/lis/metforcing/gefs/0Intro_gefs.txt +++ b/lis/metforcing/gefs/0Intro_gefs.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/finalize_gefs.F90 b/lis/metforcing/gefs/finalize_gefs.F90 index 83a837d94..9c182249e 100644 --- a/lis/metforcing/gefs/finalize_gefs.F90 +++ b/lis/metforcing/gefs/finalize_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/gefs_forcingMod.F90 b/lis/metforcing/gefs/gefs_forcingMod.F90 index 59e9b779c..140eace4e 100644 --- a/lis/metforcing/gefs/gefs_forcingMod.F90 +++ b/lis/metforcing/gefs/gefs_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/get_gefs.F90 b/lis/metforcing/gefs/get_gefs.F90 index 7dbd5e532..e7823da20 100644 --- a/lis/metforcing/gefs/get_gefs.F90 +++ b/lis/metforcing/gefs/get_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/interp_gefs.F90 b/lis/metforcing/gefs/interp_gefs.F90 index 1dd8c8c4d..8fe0e1dfd 100644 --- a/lis/metforcing/gefs/interp_gefs.F90 +++ b/lis/metforcing/gefs/interp_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/read_gefs_operational.F90 b/lis/metforcing/gefs/read_gefs_operational.F90 index 92d81274b..fa1fe7d94 100644 --- a/lis/metforcing/gefs/read_gefs_operational.F90 +++ b/lis/metforcing/gefs/read_gefs_operational.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/read_gefs_reforecast.F90 b/lis/metforcing/gefs/read_gefs_reforecast.F90 index 2dc3a49f2..a846ac3db 100644 --- a/lis/metforcing/gefs/read_gefs_reforecast.F90 +++ b/lis/metforcing/gefs/read_gefs_reforecast.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/readcrd_gefs.F90 b/lis/metforcing/gefs/readcrd_gefs.F90 index 0ff56e5a9..67b8a46a1 100644 --- a/lis/metforcing/gefs/readcrd_gefs.F90 +++ b/lis/metforcing/gefs/readcrd_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/reset_gefs.F90 b/lis/metforcing/gefs/reset_gefs.F90 index 983f0b4f1..0efeaa95c 100644 --- a/lis/metforcing/gefs/reset_gefs.F90 +++ b/lis/metforcing/gefs/reset_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gefs/timeinterp_gefs.F90 b/lis/metforcing/gefs/timeinterp_gefs.F90 index 1c2a0e7b4..6cb3a4fe3 100644 --- a/lis/metforcing/gefs/timeinterp_gefs.F90 +++ b/lis/metforcing/gefs/timeinterp_gefs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/0Intro_genEnsFcst.txt b/lis/metforcing/genEnsFcst/0Intro_genEnsFcst.txt index 487210e68..0134efa2e 100644 --- a/lis/metforcing/genEnsFcst/0Intro_genEnsFcst.txt +++ b/lis/metforcing/genEnsFcst/0Intro_genEnsFcst.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/finalize_genEnsFcst.F90 b/lis/metforcing/genEnsFcst/finalize_genEnsFcst.F90 index 89674465e..bc209cb2f 100644 --- a/lis/metforcing/genEnsFcst/finalize_genEnsFcst.F90 +++ b/lis/metforcing/genEnsFcst/finalize_genEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/genEnsFcst_SpatialInterpMod.F90 b/lis/metforcing/genEnsFcst/genEnsFcst_SpatialInterpMod.F90 index e66516094..536fdb172 100644 --- a/lis/metforcing/genEnsFcst/genEnsFcst_SpatialInterpMod.F90 +++ b/lis/metforcing/genEnsFcst/genEnsFcst_SpatialInterpMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/genEnsFcst_VariablesMod.F90 b/lis/metforcing/genEnsFcst/genEnsFcst_VariablesMod.F90 index a30de1526..1e5d5c746 100644 --- a/lis/metforcing/genEnsFcst/genEnsFcst_VariablesMod.F90 +++ b/lis/metforcing/genEnsFcst/genEnsFcst_VariablesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/genEnsFcst_forcingMod.F90 b/lis/metforcing/genEnsFcst/genEnsFcst_forcingMod.F90 index 072940384..e5d599270 100644 --- a/lis/metforcing/genEnsFcst/genEnsFcst_forcingMod.F90 +++ b/lis/metforcing/genEnsFcst/genEnsFcst_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/get_genEnsFcst.F90 b/lis/metforcing/genEnsFcst/get_genEnsFcst.F90 index 935cad130..4770224c9 100644 --- a/lis/metforcing/genEnsFcst/get_genEnsFcst.F90 +++ b/lis/metforcing/genEnsFcst/get_genEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/get_genEnsFcst_filename.F90 b/lis/metforcing/genEnsFcst/get_genEnsFcst_filename.F90 index 3e2ad01d8..a2039a23b 100755 --- a/lis/metforcing/genEnsFcst/get_genEnsFcst_filename.F90 +++ b/lis/metforcing/genEnsFcst/get_genEnsFcst_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/readcrd_genEnsFcst.F90 b/lis/metforcing/genEnsFcst/readcrd_genEnsFcst.F90 index a2cdc6d2e..55e90017a 100644 --- a/lis/metforcing/genEnsFcst/readcrd_genEnsFcst.F90 +++ b/lis/metforcing/genEnsFcst/readcrd_genEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/reset_genEnsFcst.F90 b/lis/metforcing/genEnsFcst/reset_genEnsFcst.F90 index 668bb2ffe..3f8bb5250 100644 --- a/lis/metforcing/genEnsFcst/reset_genEnsFcst.F90 +++ b/lis/metforcing/genEnsFcst/reset_genEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genEnsFcst/timeinterp_genEnsFcst.F90 b/lis/metforcing/genEnsFcst/timeinterp_genEnsFcst.F90 index aa7abcbc1..4d6fe9197 100644 --- a/lis/metforcing/genEnsFcst/timeinterp_genEnsFcst.F90 +++ b/lis/metforcing/genEnsFcst/timeinterp_genEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/0Intro_metForceGenerated.txt b/lis/metforcing/genMetForc/0Intro_metForceGenerated.txt index 56df3b319..834dee977 100644 --- a/lis/metforcing/genMetForc/0Intro_metForceGenerated.txt +++ b/lis/metforcing/genMetForc/0Intro_metForceGenerated.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/finalize_metForcGenerated.F90 b/lis/metforcing/genMetForc/finalize_metForcGenerated.F90 index c2807fbf4..7233a3740 100644 --- a/lis/metforcing/genMetForc/finalize_metForcGenerated.F90 +++ b/lis/metforcing/genMetForc/finalize_metForcGenerated.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/get_metForcGen_filename.F90 b/lis/metforcing/genMetForc/get_metForcGen_filename.F90 index ad78a0281..722494dca 100755 --- a/lis/metforcing/genMetForc/get_metForcGen_filename.F90 +++ b/lis/metforcing/genMetForc/get_metForcGen_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/get_metForcGenerated.F90 b/lis/metforcing/genMetForc/get_metForcGenerated.F90 index d7418dace..9facf7a3b 100644 --- a/lis/metforcing/genMetForc/get_metForcGenerated.F90 +++ b/lis/metforcing/genMetForc/get_metForcGenerated.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/metForcGen_SpatialInterpMod.F90 b/lis/metforcing/genMetForc/metForcGen_SpatialInterpMod.F90 index e4850af6a..05a0e465d 100644 --- a/lis/metforcing/genMetForc/metForcGen_SpatialInterpMod.F90 +++ b/lis/metforcing/genMetForc/metForcGen_SpatialInterpMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/metForcGen_VariablesMod.F90 b/lis/metforcing/genMetForc/metForcGen_VariablesMod.F90 index e67f8d8d2..e8071319d 100644 --- a/lis/metforcing/genMetForc/metForcGen_VariablesMod.F90 +++ b/lis/metforcing/genMetForc/metForcGen_VariablesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/metForcGenerated_forcingMod.F90 b/lis/metforcing/genMetForc/metForcGenerated_forcingMod.F90 index ae7836048..a49db65ee 100644 --- a/lis/metforcing/genMetForc/metForcGenerated_forcingMod.F90 +++ b/lis/metforcing/genMetForc/metForcGenerated_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/readcrd_metForcGenerated.F90 b/lis/metforcing/genMetForc/readcrd_metForcGenerated.F90 index 6a4af7450..1110cd958 100644 --- a/lis/metforcing/genMetForc/readcrd_metForcGenerated.F90 +++ b/lis/metforcing/genMetForc/readcrd_metForcGenerated.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/reset_metForcGenerated.F90 b/lis/metforcing/genMetForc/reset_metForcGenerated.F90 index b43f8f836..97ba428df 100644 --- a/lis/metforcing/genMetForc/reset_metForcGenerated.F90 +++ b/lis/metforcing/genMetForc/reset_metForcGenerated.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/genMetForc/timeinterp_metForcGenerated.F90 b/lis/metforcing/genMetForc/timeinterp_metForcGenerated.F90 index 1bb0fb421..fb876e263 100644 --- a/lis/metforcing/genMetForc/timeinterp_metForcGenerated.F90 +++ b/lis/metforcing/genMetForc/timeinterp_metForcGenerated.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/finalize_geos5fcst.F90 b/lis/metforcing/geos5fcst/finalize_geos5fcst.F90 index 364da8803..8fc8deed6 100644 --- a/lis/metforcing/geos5fcst/finalize_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/finalize_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/geos5fcst_forcingMod.F90 b/lis/metforcing/geos5fcst/geos5fcst_forcingMod.F90 index da197b744..b359039e2 100644 --- a/lis/metforcing/geos5fcst/geos5fcst_forcingMod.F90 +++ b/lis/metforcing/geos5fcst/geos5fcst_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/get_geos5fcst.F90 b/lis/metforcing/geos5fcst/get_geos5fcst.F90 index c54fd8c42..d12623722 100644 --- a/lis/metforcing/geos5fcst/get_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/get_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/interp_geos5fcst.F90 b/lis/metforcing/geos5fcst/interp_geos5fcst.F90 index 3406781f9..873ce2ad4 100644 --- a/lis/metforcing/geos5fcst/interp_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/interp_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/read_geos5fcst.F90 b/lis/metforcing/geos5fcst/read_geos5fcst.F90 index c2ab2c0df..fc469cc30 100644 --- a/lis/metforcing/geos5fcst/read_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/read_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/readcrd_geos5fcst.F90 b/lis/metforcing/geos5fcst/readcrd_geos5fcst.F90 index 94b8f554f..94743ed17 100644 --- a/lis/metforcing/geos5fcst/readcrd_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/readcrd_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/reset_geos5fcst.F90 b/lis/metforcing/geos5fcst/reset_geos5fcst.F90 index 23bac3cc9..a40b5fc86 100644 --- a/lis/metforcing/geos5fcst/reset_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/reset_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos5fcst/timeinterp_geos5fcst.F90 b/lis/metforcing/geos5fcst/timeinterp_geos5fcst.F90 index b4472fad9..c259fcf95 100644 --- a/lis/metforcing/geos5fcst/timeinterp_geos5fcst.F90 +++ b/lis/metforcing/geos5fcst/timeinterp_geos5fcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/0Intro_geosit.txt b/lis/metforcing/geos_it/0Intro_geosit.txt index 55b2f8f29..8d4a473a6 100644 --- a/lis/metforcing/geos_it/0Intro_geosit.txt +++ b/lis/metforcing/geos_it/0Intro_geosit.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/finalize_geosit.F90 b/lis/metforcing/geos_it/finalize_geosit.F90 index 565a97409..7db1e7fce 100644 --- a/lis/metforcing/geos_it/finalize_geosit.F90 +++ b/lis/metforcing/geos_it/finalize_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/geosit_forcingMod.F90 b/lis/metforcing/geos_it/geosit_forcingMod.F90 index f271caf0c..d6400de1d 100644 --- a/lis/metforcing/geos_it/geosit_forcingMod.F90 +++ b/lis/metforcing/geos_it/geosit_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/get_geosit.F90 b/lis/metforcing/geos_it/get_geosit.F90 index bd5b1eaa2..46795255d 100644 --- a/lis/metforcing/geos_it/get_geosit.F90 +++ b/lis/metforcing/geos_it/get_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/read_geosit.F90 b/lis/metforcing/geos_it/read_geosit.F90 index 8e34b9381..2901d76c1 100644 --- a/lis/metforcing/geos_it/read_geosit.F90 +++ b/lis/metforcing/geos_it/read_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/read_geosit_elev.F90 b/lis/metforcing/geos_it/read_geosit_elev.F90 index 8660048f7..032d2a680 100644 --- a/lis/metforcing/geos_it/read_geosit_elev.F90 +++ b/lis/metforcing/geos_it/read_geosit_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/readcrd_geosit.F90 b/lis/metforcing/geos_it/readcrd_geosit.F90 index 6aba34e62..9a2cd790a 100644 --- a/lis/metforcing/geos_it/readcrd_geosit.F90 +++ b/lis/metforcing/geos_it/readcrd_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/reset_geosit.F90 b/lis/metforcing/geos_it/reset_geosit.F90 index e1032bc2a..0dd025d37 100644 --- a/lis/metforcing/geos_it/reset_geosit.F90 +++ b/lis/metforcing/geos_it/reset_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/geos_it/timeinterp_geosit.F90 b/lis/metforcing/geos_it/timeinterp_geosit.F90 index d62624b60..ccffec411 100644 --- a/lis/metforcing/geos_it/timeinterp_geosit.F90 +++ b/lis/metforcing/geos_it/timeinterp_geosit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/0Intro_gfs.txt b/lis/metforcing/gfs/0Intro_gfs.txt index 77498e9b6..9da706974 100644 --- a/lis/metforcing/gfs/0Intro_gfs.txt +++ b/lis/metforcing/gfs/0Intro_gfs.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/create_gfs_f0backup_filename.F90 b/lis/metforcing/gfs/create_gfs_f0backup_filename.F90 index 37f420574..55adfea55 100644 --- a/lis/metforcing/gfs/create_gfs_f0backup_filename.F90 +++ b/lis/metforcing/gfs/create_gfs_f0backup_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/create_gfsfilename.F90 b/lis/metforcing/gfs/create_gfsfilename.F90 index 710e78263..81e4d22cc 100644 --- a/lis/metforcing/gfs/create_gfsfilename.F90 +++ b/lis/metforcing/gfs/create_gfsfilename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/finalize_gfs.F90 b/lis/metforcing/gfs/finalize_gfs.F90 index 25cc1de77..3a84b34ea 100644 --- a/lis/metforcing/gfs/finalize_gfs.F90 +++ b/lis/metforcing/gfs/finalize_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/get_gfs.F90 b/lis/metforcing/gfs/get_gfs.F90 index 024e5cd08..7dd0c9aba 100644 --- a/lis/metforcing/gfs/get_gfs.F90 +++ b/lis/metforcing/gfs/get_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/gfs_forcingMod.F90 b/lis/metforcing/gfs/gfs_forcingMod.F90 index e864098fc..00cb4736e 100644 --- a/lis/metforcing/gfs/gfs_forcingMod.F90 +++ b/lis/metforcing/gfs/gfs_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/read_gfs.F90 b/lis/metforcing/gfs/read_gfs.F90 index 4adf4cdfa..4de9d1889 100644 --- a/lis/metforcing/gfs/read_gfs.F90 +++ b/lis/metforcing/gfs/read_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/read_gfs_elev.F90 b/lis/metforcing/gfs/read_gfs_elev.F90 index 06cdfa4fa..8a827a815 100644 --- a/lis/metforcing/gfs/read_gfs_elev.F90 +++ b/lis/metforcing/gfs/read_gfs_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/readcrd_gfs.F90 b/lis/metforcing/gfs/readcrd_gfs.F90 index ea640077a..55c41d883 100644 --- a/lis/metforcing/gfs/readcrd_gfs.F90 +++ b/lis/metforcing/gfs/readcrd_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gfs/timeinterp_gfs.F90 b/lis/metforcing/gfs/timeinterp_gfs.F90 index 0bab2ed5a..195454c5f 100644 --- a/lis/metforcing/gfs/timeinterp_gfs.F90 +++ b/lis/metforcing/gfs/timeinterp_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/0Intro_gldas.txt b/lis/metforcing/gldas/0Intro_gldas.txt index 4b3324829..f4cf6ab64 100644 --- a/lis/metforcing/gldas/0Intro_gldas.txt +++ b/lis/metforcing/gldas/0Intro_gldas.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/fillgaps_gldas.F90 b/lis/metforcing/gldas/fillgaps_gldas.F90 index ded212945..a79867198 100644 --- a/lis/metforcing/gldas/fillgaps_gldas.F90 +++ b/lis/metforcing/gldas/fillgaps_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/finalize_gldas.F90 b/lis/metforcing/gldas/finalize_gldas.F90 index 2e5c4d5e3..162ce12e4 100644 --- a/lis/metforcing/gldas/finalize_gldas.F90 +++ b/lis/metforcing/gldas/finalize_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/get_gldas.F90 b/lis/metforcing/gldas/get_gldas.F90 index f1e90d693..e2fc4e6ce 100644 --- a/lis/metforcing/gldas/get_gldas.F90 +++ b/lis/metforcing/gldas/get_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/gldas_forcingMod.F90 b/lis/metforcing/gldas/gldas_forcingMod.F90 index 81fa8feae..6abec86f2 100644 --- a/lis/metforcing/gldas/gldas_forcingMod.F90 +++ b/lis/metforcing/gldas/gldas_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/read_gldas.F90 b/lis/metforcing/gldas/read_gldas.F90 index c1774ce8d..fc810e489 100644 --- a/lis/metforcing/gldas/read_gldas.F90 +++ b/lis/metforcing/gldas/read_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/readcrd_gldas.F90 b/lis/metforcing/gldas/readcrd_gldas.F90 index 1f1c1b03f..fba42e185 100644 --- a/lis/metforcing/gldas/readcrd_gldas.F90 +++ b/lis/metforcing/gldas/readcrd_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gldas/timeinterp_gldas.F90 b/lis/metforcing/gldas/timeinterp_gldas.F90 index 735309442..2c63222e7 100644 --- a/lis/metforcing/gldas/timeinterp_gldas.F90 +++ b/lis/metforcing/gldas/timeinterp_gldas.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/0Intro_gswp1.txt b/lis/metforcing/gswp1/0Intro_gswp1.txt index cc829d1f3..9a2f9c7dd 100644 --- a/lis/metforcing/gswp1/0Intro_gswp1.txt +++ b/lis/metforcing/gswp1/0Intro_gswp1.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/finalize_gswp1.F90 b/lis/metforcing/gswp1/finalize_gswp1.F90 index 1913b02db..dbe6229c9 100644 --- a/lis/metforcing/gswp1/finalize_gswp1.F90 +++ b/lis/metforcing/gswp1/finalize_gswp1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/get_gswp1.F90 b/lis/metforcing/gswp1/get_gswp1.F90 index 3be9355d9..fd837188b 100644 --- a/lis/metforcing/gswp1/get_gswp1.F90 +++ b/lis/metforcing/gswp1/get_gswp1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/gswp1_forcingMod.F90 b/lis/metforcing/gswp1/gswp1_forcingMod.F90 index 5a4eea886..f90667e8a 100644 --- a/lis/metforcing/gswp1/gswp1_forcingMod.F90 +++ b/lis/metforcing/gswp1/gswp1_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/read_gswp1.F90 b/lis/metforcing/gswp1/read_gswp1.F90 index 47cd0c71e..90aa06022 100644 --- a/lis/metforcing/gswp1/read_gswp1.F90 +++ b/lis/metforcing/gswp1/read_gswp1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/readcrd_gswp1.F90 b/lis/metforcing/gswp1/readcrd_gswp1.F90 index 5722d0232..a4c44a093 100644 --- a/lis/metforcing/gswp1/readcrd_gswp1.F90 +++ b/lis/metforcing/gswp1/readcrd_gswp1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp1/timeinterp_gswp1.F90 b/lis/metforcing/gswp1/timeinterp_gswp1.F90 index 4ffef79f5..72840276b 100644 --- a/lis/metforcing/gswp1/timeinterp_gswp1.F90 +++ b/lis/metforcing/gswp1/timeinterp_gswp1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/0Intro_gswp.txt b/lis/metforcing/gswp2/0Intro_gswp.txt index 82a9c606a..4d58c6d18 100644 --- a/lis/metforcing/gswp2/0Intro_gswp.txt +++ b/lis/metforcing/gswp2/0Intro_gswp.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/fillgaps_gswp2.F90 b/lis/metforcing/gswp2/fillgaps_gswp2.F90 index acc18a90a..dc7594c98 100644 --- a/lis/metforcing/gswp2/fillgaps_gswp2.F90 +++ b/lis/metforcing/gswp2/fillgaps_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/finalize_gswp2.F90 b/lis/metforcing/gswp2/finalize_gswp2.F90 index bd255280a..82e2d162f 100644 --- a/lis/metforcing/gswp2/finalize_gswp2.F90 +++ b/lis/metforcing/gswp2/finalize_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/finterp_gswp2.F90 b/lis/metforcing/gswp2/finterp_gswp2.F90 index 4bec50579..f921420dc 100644 --- a/lis/metforcing/gswp2/finterp_gswp2.F90 +++ b/lis/metforcing/gswp2/finterp_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/get_gswp2.F90 b/lis/metforcing/gswp2/get_gswp2.F90 index 3bc586f2b..554c2e3ac 100644 --- a/lis/metforcing/gswp2/get_gswp2.F90 +++ b/lis/metforcing/gswp2/get_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/gswp2_forcingMod.F90 b/lis/metforcing/gswp2/gswp2_forcingMod.F90 index d4c5e9ed4..ff98d5e10 100644 --- a/lis/metforcing/gswp2/gswp2_forcingMod.F90 +++ b/lis/metforcing/gswp2/gswp2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/read_gswp2.F90 b/lis/metforcing/gswp2/read_gswp2.F90 index 00cc274ce..2d407e9f9 100644 --- a/lis/metforcing/gswp2/read_gswp2.F90 +++ b/lis/metforcing/gswp2/read_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/readcrd_gswp2.F90 b/lis/metforcing/gswp2/readcrd_gswp2.F90 index 55d5ced77..28109a399 100644 --- a/lis/metforcing/gswp2/readcrd_gswp2.F90 +++ b/lis/metforcing/gswp2/readcrd_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/gswp2/timeinterp_gswp2.F90 b/lis/metforcing/gswp2/timeinterp_gswp2.F90 index b64eb7f0a..b48582c05 100644 --- a/lis/metforcing/gswp2/timeinterp_gswp2.F90 +++ b/lis/metforcing/gswp2/timeinterp_gswp2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/finalize_imerg.F90 b/lis/metforcing/imerg/finalize_imerg.F90 index bfe6672e9..783054265 100644 --- a/lis/metforcing/imerg/finalize_imerg.F90 +++ b/lis/metforcing/imerg/finalize_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/get_imerg.F90 b/lis/metforcing/imerg/get_imerg.F90 index 941d3930d..3c5d22d45 100644 --- a/lis/metforcing/imerg/get_imerg.F90 +++ b/lis/metforcing/imerg/get_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/imerg_forcingMod.F90 b/lis/metforcing/imerg/imerg_forcingMod.F90 index 3c2f3ad03..cc162db11 100644 --- a/lis/metforcing/imerg/imerg_forcingMod.F90 +++ b/lis/metforcing/imerg/imerg_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/interp_imerg.F90 b/lis/metforcing/imerg/interp_imerg.F90 index e2b09e368..1363516c9 100644 --- a/lis/metforcing/imerg/interp_imerg.F90 +++ b/lis/metforcing/imerg/interp_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/read_imerg.F90 b/lis/metforcing/imerg/read_imerg.F90 index 039d4c185..61e1dd0d4 100644 --- a/lis/metforcing/imerg/read_imerg.F90 +++ b/lis/metforcing/imerg/read_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/readcrd_imerg.F90 b/lis/metforcing/imerg/readcrd_imerg.F90 index 4ff8d7097..2c3334cc7 100644 --- a/lis/metforcing/imerg/readcrd_imerg.F90 +++ b/lis/metforcing/imerg/readcrd_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/reset_imerg.F90 b/lis/metforcing/imerg/reset_imerg.F90 index caeab52c0..1a424d827 100644 --- a/lis/metforcing/imerg/reset_imerg.F90 +++ b/lis/metforcing/imerg/reset_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/imerg/timeinterp_imerg.F90 b/lis/metforcing/imerg/timeinterp_imerg.F90 index 2567d607d..4cbc87fa9 100644 --- a/lis/metforcing/imerg/timeinterp_imerg.F90 +++ b/lis/metforcing/imerg/timeinterp_imerg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/0Intro_merra2.txt b/lis/metforcing/merra2/0Intro_merra2.txt index f60e94ccb..228b10984 100644 --- a/lis/metforcing/merra2/0Intro_merra2.txt +++ b/lis/metforcing/merra2/0Intro_merra2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/finalize_merra2.F90 b/lis/metforcing/merra2/finalize_merra2.F90 index 7d56a1d0c..69c07c937 100644 --- a/lis/metforcing/merra2/finalize_merra2.F90 +++ b/lis/metforcing/merra2/finalize_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/get_merra2.F90 b/lis/metforcing/merra2/get_merra2.F90 index 6b3f25c4a..8742a3e0d 100644 --- a/lis/metforcing/merra2/get_merra2.F90 +++ b/lis/metforcing/merra2/get_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/merra2_forcingMod.F90 b/lis/metforcing/merra2/merra2_forcingMod.F90 index 62b62998e..b84efd5f3 100644 --- a/lis/metforcing/merra2/merra2_forcingMod.F90 +++ b/lis/metforcing/merra2/merra2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/read_merra2.F90 b/lis/metforcing/merra2/read_merra2.F90 index 3a7174d51..01c774170 100644 --- a/lis/metforcing/merra2/read_merra2.F90 +++ b/lis/metforcing/merra2/read_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/read_merra2_elev.F90 b/lis/metforcing/merra2/read_merra2_elev.F90 index a195818c9..35f8cdbac 100644 --- a/lis/metforcing/merra2/read_merra2_elev.F90 +++ b/lis/metforcing/merra2/read_merra2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/readcrd_merra2.F90 b/lis/metforcing/merra2/readcrd_merra2.F90 index 5db862543..c493b6064 100644 --- a/lis/metforcing/merra2/readcrd_merra2.F90 +++ b/lis/metforcing/merra2/readcrd_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/reset_merra2.F90 b/lis/metforcing/merra2/reset_merra2.F90 index 9807796cb..a342343dd 100644 --- a/lis/metforcing/merra2/reset_merra2.F90 +++ b/lis/metforcing/merra2/reset_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/merra2/timeinterp_merra2.F90 b/lis/metforcing/merra2/timeinterp_merra2.F90 index e7550a45a..a341c8fb2 100644 --- a/lis/metforcing/merra2/timeinterp_merra2.F90 +++ b/lis/metforcing/merra2/timeinterp_merra2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/finalize_mrms_grib.F90 b/lis/metforcing/mrms/finalize_mrms_grib.F90 index a00dfdd64..d2585c082 100755 --- a/lis/metforcing/mrms/finalize_mrms_grib.F90 +++ b/lis/metforcing/mrms/finalize_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/get_mrms_grib.F90 b/lis/metforcing/mrms/get_mrms_grib.F90 index 04d209e89..a58e3a9d4 100755 --- a/lis/metforcing/mrms/get_mrms_grib.F90 +++ b/lis/metforcing/mrms/get_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/interp_mrms_grib.F90 b/lis/metforcing/mrms/interp_mrms_grib.F90 index 1f7a0696e..66fb2207d 100755 --- a/lis/metforcing/mrms/interp_mrms_grib.F90 +++ b/lis/metforcing/mrms/interp_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/mrms_grib_forcingMod.F90 b/lis/metforcing/mrms/mrms_grib_forcingMod.F90 index 0906ee66e..4ed00012f 100755 --- a/lis/metforcing/mrms/mrms_grib_forcingMod.F90 +++ b/lis/metforcing/mrms/mrms_grib_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/mrms_gribfile.F90 b/lis/metforcing/mrms/mrms_gribfile.F90 index f6b475a54..250453d2e 100755 --- a/lis/metforcing/mrms/mrms_gribfile.F90 +++ b/lis/metforcing/mrms/mrms_gribfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/read_mrms_grib.F90 b/lis/metforcing/mrms/read_mrms_grib.F90 index e9403d836..030f2a7b8 100755 --- a/lis/metforcing/mrms/read_mrms_grib.F90 +++ b/lis/metforcing/mrms/read_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/readcrd_mrms_grib.F90 b/lis/metforcing/mrms/readcrd_mrms_grib.F90 index b850c4c8b..bbd53ec6a 100755 --- a/lis/metforcing/mrms/readcrd_mrms_grib.F90 +++ b/lis/metforcing/mrms/readcrd_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/reset_mrms_grib.F90 b/lis/metforcing/mrms/reset_mrms_grib.F90 index a1989f2ab..1cf8f2026 100755 --- a/lis/metforcing/mrms/reset_mrms_grib.F90 +++ b/lis/metforcing/mrms/reset_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/mrms/timeinterp_mrms_grib.F90 b/lis/metforcing/mrms/timeinterp_mrms_grib.F90 index ea7c3f756..ae67eceef 100644 --- a/lis/metforcing/mrms/timeinterp_mrms_grib.F90 +++ b/lis/metforcing/mrms/timeinterp_mrms_grib.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/0Intro_nam242.txt b/lis/metforcing/nam242/0Intro_nam242.txt index 8ac6c1bc5..9607294c2 100644 --- a/lis/metforcing/nam242/0Intro_nam242.txt +++ b/lis/metforcing/nam242/0Intro_nam242.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/create_nam242f9_filename.F90 b/lis/metforcing/nam242/create_nam242f9_filename.F90 index f389cf102..21d89979c 100644 --- a/lis/metforcing/nam242/create_nam242f9_filename.F90 +++ b/lis/metforcing/nam242/create_nam242f9_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/create_nam242filename.F90 b/lis/metforcing/nam242/create_nam242filename.F90 index 8b90f3cf1..9582cfe9c 100644 --- a/lis/metforcing/nam242/create_nam242filename.F90 +++ b/lis/metforcing/nam242/create_nam242filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/finalize_nam242.F90 b/lis/metforcing/nam242/finalize_nam242.F90 index b96cde90b..97756b3ec 100644 --- a/lis/metforcing/nam242/finalize_nam242.F90 +++ b/lis/metforcing/nam242/finalize_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/get_nam242.F90 b/lis/metforcing/nam242/get_nam242.F90 index 116a788a2..51bcfac25 100644 --- a/lis/metforcing/nam242/get_nam242.F90 +++ b/lis/metforcing/nam242/get_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/nam242_forcingMod.F90 b/lis/metforcing/nam242/nam242_forcingMod.F90 index f28ade1fe..b86b8fe90 100644 --- a/lis/metforcing/nam242/nam242_forcingMod.F90 +++ b/lis/metforcing/nam242/nam242_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/read_nam242.F90 b/lis/metforcing/nam242/read_nam242.F90 index 2940958ed..68629adf5 100644 --- a/lis/metforcing/nam242/read_nam242.F90 +++ b/lis/metforcing/nam242/read_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/read_nam242_elev.F90 b/lis/metforcing/nam242/read_nam242_elev.F90 index 3ea481dc1..550a5d7b0 100644 --- a/lis/metforcing/nam242/read_nam242_elev.F90 +++ b/lis/metforcing/nam242/read_nam242_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/readcrd_nam242.F90 b/lis/metforcing/nam242/readcrd_nam242.F90 index dc4bdee56..1cb8b822b 100644 --- a/lis/metforcing/nam242/readcrd_nam242.F90 +++ b/lis/metforcing/nam242/readcrd_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/reset_nam242.F90 b/lis/metforcing/nam242/reset_nam242.F90 index 2eec6ccc7..333dc130f 100644 --- a/lis/metforcing/nam242/reset_nam242.F90 +++ b/lis/metforcing/nam242/reset_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nam242/timeinterp_nam242.F90 b/lis/metforcing/nam242/timeinterp_nam242.F90 index 9c60f3fb8..6cabfe65c 100644 --- a/lis/metforcing/nam242/timeinterp_nam242.F90 +++ b/lis/metforcing/nam242/timeinterp_nam242.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/0Intro_narr.txt b/lis/metforcing/narr/0Intro_narr.txt index 1f1e57dba..696fd75fb 100644 --- a/lis/metforcing/narr/0Intro_narr.txt +++ b/lis/metforcing/narr/0Intro_narr.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/finalize_narr.F90 b/lis/metforcing/narr/finalize_narr.F90 index d81cb330b..c4d785bcb 100644 --- a/lis/metforcing/narr/finalize_narr.F90 +++ b/lis/metforcing/narr/finalize_narr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/get_narr.F90 b/lis/metforcing/narr/get_narr.F90 index 8798e4692..5dacf825b 100644 --- a/lis/metforcing/narr/get_narr.F90 +++ b/lis/metforcing/narr/get_narr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/interp_narrfield.F90 b/lis/metforcing/narr/interp_narrfield.F90 index f4a1a7d34..8df784a97 100644 --- a/lis/metforcing/narr/interp_narrfield.F90 +++ b/lis/metforcing/narr/interp_narrfield.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/narr_forcingMod.F90 b/lis/metforcing/narr/narr_forcingMod.F90 index 3bbb00a95..e0fef5024 100644 --- a/lis/metforcing/narr/narr_forcingMod.F90 +++ b/lis/metforcing/narr/narr_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/read_narr.F90 b/lis/metforcing/narr/read_narr.F90 index 2fbb5a549..281c46593 100644 --- a/lis/metforcing/narr/read_narr.F90 +++ b/lis/metforcing/narr/read_narr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/readcrd_narr.F90 b/lis/metforcing/narr/readcrd_narr.F90 index a8cc6a947..f1decbc0d 100644 --- a/lis/metforcing/narr/readcrd_narr.F90 +++ b/lis/metforcing/narr/readcrd_narr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/narr/timeinterp_narr.F90 b/lis/metforcing/narr/timeinterp_narr.F90 index ccb8e824e..a8e219398 100644 --- a/lis/metforcing/narr/timeinterp_narr.F90 +++ b/lis/metforcing/narr/timeinterp_narr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/0Intro_nldas2.txt b/lis/metforcing/nldas2/0Intro_nldas2.txt index 66ad696c3..40eee0772 100644 --- a/lis/metforcing/nldas2/0Intro_nldas2.txt +++ b/lis/metforcing/nldas2/0Intro_nldas2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/finalize_nldas2.F90 b/lis/metforcing/nldas2/finalize_nldas2.F90 index 0e8e953e5..85e8af6a2 100644 --- a/lis/metforcing/nldas2/finalize_nldas2.F90 +++ b/lis/metforcing/nldas2/finalize_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/get_gesdisc_filenames.F90 b/lis/metforcing/nldas2/get_gesdisc_filenames.F90 index a7541f2a6..db3ae8dc2 100755 --- a/lis/metforcing/nldas2/get_gesdisc_filenames.F90 +++ b/lis/metforcing/nldas2/get_gesdisc_filenames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/get_ncep_filenames.F90 b/lis/metforcing/nldas2/get_ncep_filenames.F90 index dcf80afe5..8aa0db898 100755 --- a/lis/metforcing/nldas2/get_ncep_filenames.F90 +++ b/lis/metforcing/nldas2/get_ncep_filenames.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/get_nldas2.F90 b/lis/metforcing/nldas2/get_nldas2.F90 index 18ff87bee..e6b0516d8 100644 --- a/lis/metforcing/nldas2/get_nldas2.F90 +++ b/lis/metforcing/nldas2/get_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/nldas2_ec_removal.F90 b/lis/metforcing/nldas2/nldas2_ec_removal.F90 index 7c2883091..e4de89681 100644 --- a/lis/metforcing/nldas2/nldas2_ec_removal.F90 +++ b/lis/metforcing/nldas2/nldas2_ec_removal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/nldas2_forcingMod.F90 b/lis/metforcing/nldas2/nldas2_forcingMod.F90 index 8019e598d..e3c65b227 100644 --- a/lis/metforcing/nldas2/nldas2_forcingMod.F90 +++ b/lis/metforcing/nldas2/nldas2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/read_nldas2_elev.F90 b/lis/metforcing/nldas2/read_nldas2_elev.F90 index 88a827cd9..dafe7647c 100644 --- a/lis/metforcing/nldas2/read_nldas2_elev.F90 +++ b/lis/metforcing/nldas2/read_nldas2_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/read_nldas2a.F90 b/lis/metforcing/nldas2/read_nldas2a.F90 index c8e759b8a..5f20a59ae 100644 --- a/lis/metforcing/nldas2/read_nldas2a.F90 +++ b/lis/metforcing/nldas2/read_nldas2a.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/read_nldas2b.F90 b/lis/metforcing/nldas2/read_nldas2b.F90 index fe4718c55..206f4512c 100644 --- a/lis/metforcing/nldas2/read_nldas2b.F90 +++ b/lis/metforcing/nldas2/read_nldas2b.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/read_orig_nldas2_elevdiff.F90 b/lis/metforcing/nldas2/read_orig_nldas2_elevdiff.F90 index e1b4ba82a..c433f426d 100644 --- a/lis/metforcing/nldas2/read_orig_nldas2_elevdiff.F90 +++ b/lis/metforcing/nldas2/read_orig_nldas2_elevdiff.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/readcrd_nldas2.F90 b/lis/metforcing/nldas2/readcrd_nldas2.F90 index 906d77161..32a0ac18a 100644 --- a/lis/metforcing/nldas2/readcrd_nldas2.F90 +++ b/lis/metforcing/nldas2/readcrd_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/reset_nldas2.F90 b/lis/metforcing/nldas2/reset_nldas2.F90 index 03707f70c..353ae2bf6 100644 --- a/lis/metforcing/nldas2/reset_nldas2.F90 +++ b/lis/metforcing/nldas2/reset_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/nldas2/timeinterp_nldas2.F90 b/lis/metforcing/nldas2/timeinterp_nldas2.F90 index a43bfa5a1..3ae8d97bb 100644 --- a/lis/metforcing/nldas2/timeinterp_nldas2.F90 +++ b/lis/metforcing/nldas2/timeinterp_nldas2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/0Intro_petusgs.txt b/lis/metforcing/pet_usgs/0Intro_petusgs.txt index 62edb398d..fed150ed2 100644 --- a/lis/metforcing/pet_usgs/0Intro_petusgs.txt +++ b/lis/metforcing/pet_usgs/0Intro_petusgs.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/finalize_petusgs.F90 b/lis/metforcing/pet_usgs/finalize_petusgs.F90 index 9e7c66c62..82ed94346 100644 --- a/lis/metforcing/pet_usgs/finalize_petusgs.F90 +++ b/lis/metforcing/pet_usgs/finalize_petusgs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/get_petusgs.F90 b/lis/metforcing/pet_usgs/get_petusgs.F90 index 0164c83ce..65484d77c 100644 --- a/lis/metforcing/pet_usgs/get_petusgs.F90 +++ b/lis/metforcing/pet_usgs/get_petusgs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/interp_petusgs.F90 b/lis/metforcing/pet_usgs/interp_petusgs.F90 index 8cdeae2f8..a5800413a 100644 --- a/lis/metforcing/pet_usgs/interp_petusgs.F90 +++ b/lis/metforcing/pet_usgs/interp_petusgs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/petusgs_forcingMod.F90 b/lis/metforcing/pet_usgs/petusgs_forcingMod.F90 index e85bcc8a7..c5ceb6495 100644 --- a/lis/metforcing/pet_usgs/petusgs_forcingMod.F90 +++ b/lis/metforcing/pet_usgs/petusgs_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/read_petusgs.F90 b/lis/metforcing/pet_usgs/read_petusgs.F90 index e87ba0212..72c4fa217 100644 --- a/lis/metforcing/pet_usgs/read_petusgs.F90 +++ b/lis/metforcing/pet_usgs/read_petusgs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/readpetusgscrd.F90 b/lis/metforcing/pet_usgs/readpetusgscrd.F90 index e0a04c4a1..d064f2511 100644 --- a/lis/metforcing/pet_usgs/readpetusgscrd.F90 +++ b/lis/metforcing/pet_usgs/readpetusgscrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pet_usgs/timeinterp_petusgs.F90 b/lis/metforcing/pet_usgs/timeinterp_petusgs.F90 index d43d34bec..0679f61f7 100644 --- a/lis/metforcing/pet_usgs/timeinterp_petusgs.F90 +++ b/lis/metforcing/pet_usgs/timeinterp_petusgs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/finalize_plumber2.F90 b/lis/metforcing/plumber2/finalize_plumber2.F90 index d904812d5..07b0df54d 100644 --- a/lis/metforcing/plumber2/finalize_plumber2.F90 +++ b/lis/metforcing/plumber2/finalize_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/get_plumber2.F90 b/lis/metforcing/plumber2/get_plumber2.F90 index 3c0ce22e9..c099054d8 100644 --- a/lis/metforcing/plumber2/get_plumber2.F90 +++ b/lis/metforcing/plumber2/get_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/plumber2_forcingMod.F90 b/lis/metforcing/plumber2/plumber2_forcingMod.F90 index 711149c7b..9df3c7189 100644 --- a/lis/metforcing/plumber2/plumber2_forcingMod.F90 +++ b/lis/metforcing/plumber2/plumber2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/read_plumber2.F90 b/lis/metforcing/plumber2/read_plumber2.F90 index 5d0e8d3c0..28e471111 100755 --- a/lis/metforcing/plumber2/read_plumber2.F90 +++ b/lis/metforcing/plumber2/read_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/readcrd_plumber2.F90 b/lis/metforcing/plumber2/readcrd_plumber2.F90 index ca183d62d..5081c9365 100644 --- a/lis/metforcing/plumber2/readcrd_plumber2.F90 +++ b/lis/metforcing/plumber2/readcrd_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/reset_plumber2.F90 b/lis/metforcing/plumber2/reset_plumber2.F90 index 015f40915..4bee639a0 100755 --- a/lis/metforcing/plumber2/reset_plumber2.F90 +++ b/lis/metforcing/plumber2/reset_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/plumber2/timeinterp_plumber2.F90 b/lis/metforcing/plumber2/timeinterp_plumber2.F90 index 6203283e4..1e35b9733 100644 --- a/lis/metforcing/plumber2/timeinterp_plumber2.F90 +++ b/lis/metforcing/plumber2/timeinterp_plumber2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/0Intro_genEnsFcst.txt b/lis/metforcing/pptEnsFcst/0Intro_genEnsFcst.txt index 487210e68..0134efa2e 100644 --- a/lis/metforcing/pptEnsFcst/0Intro_genEnsFcst.txt +++ b/lis/metforcing/pptEnsFcst/0Intro_genEnsFcst.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/finalize_pptEnsFcst.F90 b/lis/metforcing/pptEnsFcst/finalize_pptEnsFcst.F90 index 279f6528f..47bdf16dc 100644 --- a/lis/metforcing/pptEnsFcst/finalize_pptEnsFcst.F90 +++ b/lis/metforcing/pptEnsFcst/finalize_pptEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/get_pptEnsFcst.F90 b/lis/metforcing/pptEnsFcst/get_pptEnsFcst.F90 index 0eaee2eb5..34af840da 100644 --- a/lis/metforcing/pptEnsFcst/get_pptEnsFcst.F90 +++ b/lis/metforcing/pptEnsFcst/get_pptEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/get_pptEnsFcst_filename.F90 b/lis/metforcing/pptEnsFcst/get_pptEnsFcst_filename.F90 index df62c11bd..9abe2ae86 100755 --- a/lis/metforcing/pptEnsFcst/get_pptEnsFcst_filename.F90 +++ b/lis/metforcing/pptEnsFcst/get_pptEnsFcst_filename.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/pptEnsFcst_SpatialInterpMod.F90 b/lis/metforcing/pptEnsFcst/pptEnsFcst_SpatialInterpMod.F90 index 12ebdd566..d0a79ec7c 100644 --- a/lis/metforcing/pptEnsFcst/pptEnsFcst_SpatialInterpMod.F90 +++ b/lis/metforcing/pptEnsFcst/pptEnsFcst_SpatialInterpMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/pptEnsFcst_VariablesMod.F90 b/lis/metforcing/pptEnsFcst/pptEnsFcst_VariablesMod.F90 index bb2415970..146a3c3ef 100644 --- a/lis/metforcing/pptEnsFcst/pptEnsFcst_VariablesMod.F90 +++ b/lis/metforcing/pptEnsFcst/pptEnsFcst_VariablesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/pptEnsFcst_forcingMod.F90 b/lis/metforcing/pptEnsFcst/pptEnsFcst_forcingMod.F90 index 8261b9204..b0e7cb51a 100644 --- a/lis/metforcing/pptEnsFcst/pptEnsFcst_forcingMod.F90 +++ b/lis/metforcing/pptEnsFcst/pptEnsFcst_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/readcrd_pptEnsFcst.F90 b/lis/metforcing/pptEnsFcst/readcrd_pptEnsFcst.F90 index 899f604e4..5cc6d95bf 100644 --- a/lis/metforcing/pptEnsFcst/readcrd_pptEnsFcst.F90 +++ b/lis/metforcing/pptEnsFcst/readcrd_pptEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/reset_pptEnsFcst.F90 b/lis/metforcing/pptEnsFcst/reset_pptEnsFcst.F90 index 3018902cc..0b49827bc 100644 --- a/lis/metforcing/pptEnsFcst/reset_pptEnsFcst.F90 +++ b/lis/metforcing/pptEnsFcst/reset_pptEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/pptEnsFcst/timeinterp_pptEnsFcst.F90 b/lis/metforcing/pptEnsFcst/timeinterp_pptEnsFcst.F90 index 2518cbb1b..867619dc5 100644 --- a/lis/metforcing/pptEnsFcst/timeinterp_pptEnsFcst.F90 +++ b/lis/metforcing/pptEnsFcst/timeinterp_pptEnsFcst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/0Intro_princeton.txt b/lis/metforcing/princeton/0Intro_princeton.txt index 7afe9c2a3..ce237c903 100644 --- a/lis/metforcing/princeton/0Intro_princeton.txt +++ b/lis/metforcing/princeton/0Intro_princeton.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/finalize_princeton.F90 b/lis/metforcing/princeton/finalize_princeton.F90 index 061e0b3ed..5f71c82f3 100644 --- a/lis/metforcing/princeton/finalize_princeton.F90 +++ b/lis/metforcing/princeton/finalize_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/get_princeton.F90 b/lis/metforcing/princeton/get_princeton.F90 index 059d9d22e..ad804496c 100644 --- a/lis/metforcing/princeton/get_princeton.F90 +++ b/lis/metforcing/princeton/get_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/princeton_forcingMod.F90 b/lis/metforcing/princeton/princeton_forcingMod.F90 index 168542eab..817b61d48 100644 --- a/lis/metforcing/princeton/princeton_forcingMod.F90 +++ b/lis/metforcing/princeton/princeton_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/read_princeton.F90 b/lis/metforcing/princeton/read_princeton.F90 index 13b443c15..14703fa1a 100644 --- a/lis/metforcing/princeton/read_princeton.F90 +++ b/lis/metforcing/princeton/read_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/read_princeton_elev.F90 b/lis/metforcing/princeton/read_princeton_elev.F90 index e86c9ff4d..991aa83c2 100644 --- a/lis/metforcing/princeton/read_princeton_elev.F90 +++ b/lis/metforcing/princeton/read_princeton_elev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/readcrd_princeton.F90 b/lis/metforcing/princeton/readcrd_princeton.F90 index a47772d7b..7ac1c59cc 100644 --- a/lis/metforcing/princeton/readcrd_princeton.F90 +++ b/lis/metforcing/princeton/readcrd_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/reset_princeton.F90 b/lis/metforcing/princeton/reset_princeton.F90 index a21130db0..f34e7f6f9 100644 --- a/lis/metforcing/princeton/reset_princeton.F90 +++ b/lis/metforcing/princeton/reset_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/princeton/timeinterp_princeton.F90 b/lis/metforcing/princeton/timeinterp_princeton.F90 index 13dc7dc4f..9030efdb4 100644 --- a/lis/metforcing/princeton/timeinterp_princeton.F90 +++ b/lis/metforcing/princeton/timeinterp_princeton.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/0Intro_scan.txt b/lis/metforcing/scan/0Intro_scan.txt index e88c47085..2027553d8 100644 --- a/lis/metforcing/scan/0Intro_scan.txt +++ b/lis/metforcing/scan/0Intro_scan.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/finalize_scan.F90 b/lis/metforcing/scan/finalize_scan.F90 index db4417746..9c536d08a 100644 --- a/lis/metforcing/scan/finalize_scan.F90 +++ b/lis/metforcing/scan/finalize_scan.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/get_scan.F90 b/lis/metforcing/scan/get_scan.F90 index ecc525b1c..b23fc1522 100644 --- a/lis/metforcing/scan/get_scan.F90 +++ b/lis/metforcing/scan/get_scan.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/read_scan.F90 b/lis/metforcing/scan/read_scan.F90 index 300a2cec4..2925bf8a7 100644 --- a/lis/metforcing/scan/read_scan.F90 +++ b/lis/metforcing/scan/read_scan.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/readcrd_scan.F90 b/lis/metforcing/scan/readcrd_scan.F90 index 424ec9c82..6a6db544b 100644 --- a/lis/metforcing/scan/readcrd_scan.F90 +++ b/lis/metforcing/scan/readcrd_scan.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/scan_forcingMod.F90 b/lis/metforcing/scan/scan_forcingMod.F90 index bea5a23f7..f2cd04fc4 100644 --- a/lis/metforcing/scan/scan_forcingMod.F90 +++ b/lis/metforcing/scan/scan_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/scan/timeinterp_scan.F90 b/lis/metforcing/scan/timeinterp_scan.F90 index d4236500e..281b44010 100644 --- a/lis/metforcing/scan/timeinterp_scan.F90 +++ b/lis/metforcing/scan/timeinterp_scan.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/finalize_snotel.F90 b/lis/metforcing/snotel/finalize_snotel.F90 index cb5006547..903e9165d 100644 --- a/lis/metforcing/snotel/finalize_snotel.F90 +++ b/lis/metforcing/snotel/finalize_snotel.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/get_snotel.F90 b/lis/metforcing/snotel/get_snotel.F90 index fe61e90ca..43cd8e90e 100644 --- a/lis/metforcing/snotel/get_snotel.F90 +++ b/lis/metforcing/snotel/get_snotel.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/read_snotel.F90 b/lis/metforcing/snotel/read_snotel.F90 index 7f2772365..15b804aaa 100644 --- a/lis/metforcing/snotel/read_snotel.F90 +++ b/lis/metforcing/snotel/read_snotel.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/readcrd_snotel.F90 b/lis/metforcing/snotel/readcrd_snotel.F90 index a23c4428d..38c99a379 100644 --- a/lis/metforcing/snotel/readcrd_snotel.F90 +++ b/lis/metforcing/snotel/readcrd_snotel.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/snotel_forcingMod.F90 b/lis/metforcing/snotel/snotel_forcingMod.F90 index 6fff4e8b3..63c6881fa 100644 --- a/lis/metforcing/snotel/snotel_forcingMod.F90 +++ b/lis/metforcing/snotel/snotel_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/snotel/timeinterp_snotel.F90 b/lis/metforcing/snotel/timeinterp_snotel.F90 index 17575a6f3..3916d5d80 100644 --- a/lis/metforcing/snotel/timeinterp_snotel.F90 +++ b/lis/metforcing/snotel/timeinterp_snotel.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/0Intro_stage2.txt b/lis/metforcing/stg2/0Intro_stage2.txt index abfd10c4b..f86aab7a3 100644 --- a/lis/metforcing/stg2/0Intro_stage2.txt +++ b/lis/metforcing/stg2/0Intro_stage2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/finalize_stg2.F90 b/lis/metforcing/stg2/finalize_stg2.F90 index 812a440e0..e8396365a 100644 --- a/lis/metforcing/stg2/finalize_stg2.F90 +++ b/lis/metforcing/stg2/finalize_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/get_stg2.F90 b/lis/metforcing/stg2/get_stg2.F90 index 8f1a4b8a9..08787a44a 100644 --- a/lis/metforcing/stg2/get_stg2.F90 +++ b/lis/metforcing/stg2/get_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/interp_stg2.F90 b/lis/metforcing/stg2/interp_stg2.F90 index c6b393278..71cde5d42 100644 --- a/lis/metforcing/stg2/interp_stg2.F90 +++ b/lis/metforcing/stg2/interp_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/read_stg2.F90 b/lis/metforcing/stg2/read_stg2.F90 index 7e09d0361..33b44a266 100644 --- a/lis/metforcing/stg2/read_stg2.F90 +++ b/lis/metforcing/stg2/read_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/readcrd_stg2.F90 b/lis/metforcing/stg2/readcrd_stg2.F90 index 9b283e79e..3f6369927 100644 --- a/lis/metforcing/stg2/readcrd_stg2.F90 +++ b/lis/metforcing/stg2/readcrd_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/stg2_forcingMod.F90 b/lis/metforcing/stg2/stg2_forcingMod.F90 index 7624ec55f..e278277cf 100644 --- a/lis/metforcing/stg2/stg2_forcingMod.F90 +++ b/lis/metforcing/stg2/stg2_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/stg2file.F90 b/lis/metforcing/stg2/stg2file.F90 index 5ca362282..8435efd17 100644 --- a/lis/metforcing/stg2/stg2file.F90 +++ b/lis/metforcing/stg2/stg2file.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg2/timeinterp_stg2.F90 b/lis/metforcing/stg2/timeinterp_stg2.F90 index dcf6c3dc6..a23bfc066 100644 --- a/lis/metforcing/stg2/timeinterp_stg2.F90 +++ b/lis/metforcing/stg2/timeinterp_stg2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/0Intro_stage4.txt b/lis/metforcing/stg4/0Intro_stage4.txt index cef7edb0b..5a15e1ffc 100644 --- a/lis/metforcing/stg4/0Intro_stage4.txt +++ b/lis/metforcing/stg4/0Intro_stage4.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/finalize_stg4.F90 b/lis/metforcing/stg4/finalize_stg4.F90 index af27c7c3d..fb5e22cd7 100644 --- a/lis/metforcing/stg4/finalize_stg4.F90 +++ b/lis/metforcing/stg4/finalize_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/get_stg4.F90 b/lis/metforcing/stg4/get_stg4.F90 index 6d8a0f7ca..a0babf676 100644 --- a/lis/metforcing/stg4/get_stg4.F90 +++ b/lis/metforcing/stg4/get_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/interp_stg4.F90 b/lis/metforcing/stg4/interp_stg4.F90 index 8e6c71ebf..fab3f11f9 100644 --- a/lis/metforcing/stg4/interp_stg4.F90 +++ b/lis/metforcing/stg4/interp_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/read_stg4.F90 b/lis/metforcing/stg4/read_stg4.F90 index c46200ec5..61c971b9c 100644 --- a/lis/metforcing/stg4/read_stg4.F90 +++ b/lis/metforcing/stg4/read_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/readcrd_stg4.F90 b/lis/metforcing/stg4/readcrd_stg4.F90 index c27aea4bc..b724982ff 100644 --- a/lis/metforcing/stg4/readcrd_stg4.F90 +++ b/lis/metforcing/stg4/readcrd_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/reset_stg4.F90 b/lis/metforcing/stg4/reset_stg4.F90 index d9f414d49..179abd471 100644 --- a/lis/metforcing/stg4/reset_stg4.F90 +++ b/lis/metforcing/stg4/reset_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/stg4_forcingMod.F90 b/lis/metforcing/stg4/stg4_forcingMod.F90 index 7389d9926..a16b73de7 100644 --- a/lis/metforcing/stg4/stg4_forcingMod.F90 +++ b/lis/metforcing/stg4/stg4_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/stg4file.F90 b/lis/metforcing/stg4/stg4file.F90 index d6e3a944a..710716fa4 100644 --- a/lis/metforcing/stg4/stg4file.F90 +++ b/lis/metforcing/stg4/stg4file.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/stg4/timeinterp_stg4.F90 b/lis/metforcing/stg4/timeinterp_stg4.F90 index 69864ccd8..a970ea0ab 100644 --- a/lis/metforcing/stg4/timeinterp_stg4.F90 +++ b/lis/metforcing/stg4/timeinterp_stg4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/0Intro_template.txt b/lis/metforcing/templateMetForc/0Intro_template.txt index 6d649c93d..efabc8cea 100644 --- a/lis/metforcing/templateMetForc/0Intro_template.txt +++ b/lis/metforcing/templateMetForc/0Intro_template.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/finalize_metForcTemplate.F90 b/lis/metforcing/templateMetForc/finalize_metForcTemplate.F90 index 1ac9f53c9..3b51c21df 100644 --- a/lis/metforcing/templateMetForc/finalize_metForcTemplate.F90 +++ b/lis/metforcing/templateMetForc/finalize_metForcTemplate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/get_metForcTemplate.F90 b/lis/metforcing/templateMetForc/get_metForcTemplate.F90 index e2010439e..870fad05e 100644 --- a/lis/metforcing/templateMetForc/get_metForcTemplate.F90 +++ b/lis/metforcing/templateMetForc/get_metForcTemplate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/metForcTemplate_forcingMod.F90 b/lis/metforcing/templateMetForc/metForcTemplate_forcingMod.F90 index 0b80f78ac..fcaea46a3 100644 --- a/lis/metforcing/templateMetForc/metForcTemplate_forcingMod.F90 +++ b/lis/metforcing/templateMetForc/metForcTemplate_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/reset_metForcTemplate.F90 b/lis/metforcing/templateMetForc/reset_metForcTemplate.F90 index 36d9ef262..fde525325 100644 --- a/lis/metforcing/templateMetForc/reset_metForcTemplate.F90 +++ b/lis/metforcing/templateMetForc/reset_metForcTemplate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/templateMetForc/timeinterp_metForctemplate.F90 b/lis/metforcing/templateMetForc/timeinterp_metForctemplate.F90 index 250fd918a..46ae4733b 100644 --- a/lis/metforcing/templateMetForc/timeinterp_metForctemplate.F90 +++ b/lis/metforcing/templateMetForc/timeinterp_metForctemplate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_bakfac.F90 b/lis/metforcing/usaf/AGRMET_bakfac.F90 index 1fce3a8b1..be4ff0d53 100644 --- a/lis/metforcing/usaf/AGRMET_bakfac.F90 +++ b/lis/metforcing/usaf/AGRMET_bakfac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_bndslc.F90 b/lis/metforcing/usaf/AGRMET_bndslc.F90 index 5670a8e92..68688168c 100644 --- a/lis/metforcing/usaf/AGRMET_bndslc.F90 +++ b/lis/metforcing/usaf/AGRMET_bndslc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_calc_albedo.F90 b/lis/metforcing/usaf/AGRMET_calc_albedo.F90 index c3e5be678..728a153f6 100644 --- a/lis/metforcing/usaf/AGRMET_calc_albedo.F90 +++ b/lis/metforcing/usaf/AGRMET_calc_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_calcrh.F90 b/lis/metforcing/usaf/AGRMET_calcrh.F90 index 43812c479..dd83a3289 100644 --- a/lis/metforcing/usaf/AGRMET_calcrh.F90 +++ b/lis/metforcing/usaf/AGRMET_calcrh.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_calcrh_dpt.F90 b/lis/metforcing/usaf/AGRMET_calcrh_dpt.F90 index de3138bb6..bac183591 100644 --- a/lis/metforcing/usaf/AGRMET_calcrh_dpt.F90 +++ b/lis/metforcing/usaf/AGRMET_calcrh_dpt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_calest.F90 b/lis/metforcing/usaf/AGRMET_calest.F90 index 7a48fa3d9..0b6ac3ce3 100644 --- a/lis/metforcing/usaf/AGRMET_calest.F90 +++ b/lis/metforcing/usaf/AGRMET_calest.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 b/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 index 83634ba09..d8f82d477 100644 --- a/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 +++ b/lis/metforcing/usaf/AGRMET_cdfs2_est.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_cliest.F90 b/lis/metforcing/usaf/AGRMET_cliest.F90 index e81e0d643..34da6c57d 100644 --- a/lis/metforcing/usaf/AGRMET_cliest.F90 +++ b/lis/metforcing/usaf/AGRMET_cliest.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_cmorph.F90 b/lis/metforcing/usaf/AGRMET_cmorph.F90 index 6e0039b3a..1c0b5c9eb 100644 --- a/lis/metforcing/usaf/AGRMET_cmorph.F90 +++ b/lis/metforcing/usaf/AGRMET_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_coszen.F90 b/lis/metforcing/usaf/AGRMET_coszen.F90 index 37ef2921f..35510d91b 100644 --- a/lis/metforcing/usaf/AGRMET_coszen.F90 +++ b/lis/metforcing/usaf/AGRMET_coszen.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fgfill.F90 b/lis/metforcing/usaf/AGRMET_fgfill.F90 index 4abc7f553..ef41bc506 100644 --- a/lis/metforcing/usaf/AGRMET_fgfill.F90 +++ b/lis/metforcing/usaf/AGRMET_fgfill.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fillgaps.F90 b/lis/metforcing/usaf/AGRMET_fillgaps.F90 index 4c5f47f32..445149612 100644 --- a/lis/metforcing/usaf/AGRMET_fillgaps.F90 +++ b/lis/metforcing/usaf/AGRMET_fillgaps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fldbld.F90 b/lis/metforcing/usaf/AGRMET_fldbld.F90 index 618ea99ac..9829e97cb 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 b/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 index 41f51ac97..a25bb6b41 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 b/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 index eb7704c16..87d5c665b 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 b/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 index c641846ac..308a343d8 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_precip_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 b/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 index 9953b8622..4653d43b6 100644 --- a/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 +++ b/lis/metforcing/usaf/AGRMET_fldbld_precip_gfs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_forcingMod.F90 b/lis/metforcing/usaf/AGRMET_forcingMod.F90 index 3f242e639..2c7f074f8 100644 --- a/lis/metforcing/usaf/AGRMET_forcingMod.F90 +++ b/lis/metforcing/usaf/AGRMET_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_geoest.F90 b/lis/metforcing/usaf/AGRMET_geoest.F90 index 051726fc0..0f30988f1 100644 --- a/lis/metforcing/usaf/AGRMET_geoest.F90 +++ b/lis/metforcing/usaf/AGRMET_geoest.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_getcli.F90 b/lis/metforcing/usaf/AGRMET_getcli.F90 index a9eb8d0a8..69db2e4d0 100644 --- a/lis/metforcing/usaf/AGRMET_getcli.F90 +++ b/lis/metforcing/usaf/AGRMET_getcli.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_getcmorph.F90 b/lis/metforcing/usaf/AGRMET_getcmorph.F90 index b8948518c..6d113e9f3 100644 --- a/lis/metforcing/usaf/AGRMET_getcmorph.F90 +++ b/lis/metforcing/usaf/AGRMET_getcmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_getpcpobs.F90 b/lis/metforcing/usaf/AGRMET_getpcpobs.F90 index bd60dd8d6..e629d87fa 100644 --- a/lis/metforcing/usaf/AGRMET_getpcpobs.F90 +++ b/lis/metforcing/usaf/AGRMET_getpcpobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_getpwe.F90 b/lis/metforcing/usaf/AGRMET_getpwe.F90 index f3c44caf3..f07af4eb9 100644 --- a/lis/metforcing/usaf/AGRMET_getpwe.F90 +++ b/lis/metforcing/usaf/AGRMET_getpwe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_getsfc.F90 b/lis/metforcing/usaf/AGRMET_getsfc.F90 index 8a6eb9560..e0ed4bccf 100644 --- a/lis/metforcing/usaf/AGRMET_getsfc.F90 +++ b/lis/metforcing/usaf/AGRMET_getsfc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_interp_cmorph.F90 b/lis/metforcing/usaf/AGRMET_interp_cmorph.F90 index 467bf555c..8bc88cdbb 100644 --- a/lis/metforcing/usaf/AGRMET_interp_cmorph.F90 +++ b/lis/metforcing/usaf/AGRMET_interp_cmorph.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_julhr_date10.F90 b/lis/metforcing/usaf/AGRMET_julhr_date10.F90 index f4df45553..036e8729e 100644 --- a/lis/metforcing/usaf/AGRMET_julhr_date10.F90 +++ b/lis/metforcing/usaf/AGRMET_julhr_date10.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_loadcloud.F90 b/lis/metforcing/usaf/AGRMET_loadcloud.F90 index a72511ffc..7ddb7d727 100644 --- a/lis/metforcing/usaf/AGRMET_loadcloud.F90 +++ b/lis/metforcing/usaf/AGRMET_loadcloud.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_longwv.F90 b/lis/metforcing/usaf/AGRMET_longwv.F90 index 167ac43b1..6bc4c5a54 100644 --- a/lis/metforcing/usaf/AGRMET_longwv.F90 +++ b/lis/metforcing/usaf/AGRMET_longwv.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_make03.F90 b/lis/metforcing/usaf/AGRMET_make03.F90 index 021ea8cf9..2edcae54c 100644 --- a/lis/metforcing/usaf/AGRMET_make03.F90 +++ b/lis/metforcing/usaf/AGRMET_make03.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_makest.F90 b/lis/metforcing/usaf/AGRMET_makest.F90 index 5225dccd3..e1608c827 100644 --- a/lis/metforcing/usaf/AGRMET_makest.F90 +++ b/lis/metforcing/usaf/AGRMET_makest.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_makpwe.F90 b/lis/metforcing/usaf/AGRMET_makpwe.F90 index ea2a1392a..033f0dec3 100644 --- a/lis/metforcing/usaf/AGRMET_makpwe.F90 +++ b/lis/metforcing/usaf/AGRMET_makpwe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_parse12.F90 b/lis/metforcing/usaf/AGRMET_parse12.F90 index 00c872c0e..8a2f2d284 100644 --- a/lis/metforcing/usaf/AGRMET_parse12.F90 +++ b/lis/metforcing/usaf/AGRMET_parse12.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_parse6.F90 b/lis/metforcing/usaf/AGRMET_parse6.F90 index 552e239ce..d820422b8 100644 --- a/lis/metforcing/usaf/AGRMET_parse6.F90 +++ b/lis/metforcing/usaf/AGRMET_parse6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_pcp_barnes.F90 b/lis/metforcing/usaf/AGRMET_pcp_barnes.F90 index fecba7b3e..26226dca8 100644 --- a/lis/metforcing/usaf/AGRMET_pcp_barnes.F90 +++ b/lis/metforcing/usaf/AGRMET_pcp_barnes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_pcpobs_search.F90 b/lis/metforcing/usaf/AGRMET_pcpobs_search.F90 index eda75a10e..96b79678f 100644 --- a/lis/metforcing/usaf/AGRMET_pcpobs_search.F90 +++ b/lis/metforcing/usaf/AGRMET_pcpobs_search.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_phsrel12.F90 b/lis/metforcing/usaf/AGRMET_phsrel12.F90 index 5b8f3af49..c7eff096f 100644 --- a/lis/metforcing/usaf/AGRMET_phsrel12.F90 +++ b/lis/metforcing/usaf/AGRMET_phsrel12.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_phsrel6.F90 b/lis/metforcing/usaf/AGRMET_phsrel6.F90 index 16ea2eb8b..9901d7d24 100644 --- a/lis/metforcing/usaf/AGRMET_phsrel6.F90 +++ b/lis/metforcing/usaf/AGRMET_phsrel6.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_processobs.F90 b/lis/metforcing/usaf/AGRMET_processobs.F90 index eba6bf5e5..72103944a 100644 --- a/lis/metforcing/usaf/AGRMET_processobs.F90 +++ b/lis/metforcing/usaf/AGRMET_processobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_read_pcpclimodata.F90 b/lis/metforcing/usaf/AGRMET_read_pcpclimodata.F90 index dc857a881..c9cb1107d 100644 --- a/lis/metforcing/usaf/AGRMET_read_pcpclimodata.F90 +++ b/lis/metforcing/usaf/AGRMET_read_pcpclimodata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 b/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 index b8700de71..b82c004e2 100644 --- a/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 +++ b/lis/metforcing/usaf/AGRMET_read_sfcalccntm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_readmask.F90 b/lis/metforcing/usaf/AGRMET_readmask.F90 index 63e3b18b7..86e528550 100644 --- a/lis/metforcing/usaf/AGRMET_readmask.F90 +++ b/lis/metforcing/usaf/AGRMET_readmask.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 b/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 index 0ac8572e9..4806bc956 100644 --- a/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 +++ b/lis/metforcing/usaf/AGRMET_readpcpcntm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_readterrain.F90 b/lis/metforcing/usaf/AGRMET_readterrain.F90 index 358acc6d7..3c682caad 100644 --- a/lis/metforcing/usaf/AGRMET_readterrain.F90 +++ b/lis/metforcing/usaf/AGRMET_readterrain.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_sfcalc.F90 b/lis/metforcing/usaf/AGRMET_sfcalc.F90 index b79426223..d68826d26 100644 --- a/lis/metforcing/usaf/AGRMET_sfcalc.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcalc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_sfcalc_barnes.F90 b/lis/metforcing/usaf/AGRMET_sfcalc_barnes.F90 index d7442c21d..541512c83 100644 --- a/lis/metforcing/usaf/AGRMET_sfcalc_barnes.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcalc_barnes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_sfcval.F90 b/lis/metforcing/usaf/AGRMET_sfcval.F90 index 49222b922..49218ce99 100644 --- a/lis/metforcing/usaf/AGRMET_sfcval.F90 +++ b/lis/metforcing/usaf/AGRMET_sfcval.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_smiest.F90 b/lis/metforcing/usaf/AGRMET_smiest.F90 index 1879e3987..819ee15e0 100644 --- a/lis/metforcing/usaf/AGRMET_smiest.F90 +++ b/lis/metforcing/usaf/AGRMET_smiest.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_solar.F90 b/lis/metforcing/usaf/AGRMET_solar.F90 index 8ee0cd5cd..1312fbb47 100644 --- a/lis/metforcing/usaf/AGRMET_solar.F90 +++ b/lis/metforcing/usaf/AGRMET_solar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_storeobs.F90 b/lis/metforcing/usaf/AGRMET_storeobs.F90 index b10e751c5..16c708a44 100644 --- a/lis/metforcing/usaf/AGRMET_storeobs.F90 +++ b/lis/metforcing/usaf/AGRMET_storeobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_storeobs_offhour.F90 b/lis/metforcing/usaf/AGRMET_storeobs_offhour.F90 index ad95cd589..4d1733cac 100644 --- a/lis/metforcing/usaf/AGRMET_storeobs_offhour.F90 +++ b/lis/metforcing/usaf/AGRMET_storeobs_offhour.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_svp.F90 b/lis/metforcing/usaf/AGRMET_svp.F90 index 3d95f36ea..c93a0c2cf 100644 --- a/lis/metforcing/usaf/AGRMET_svp.F90 +++ b/lis/metforcing/usaf/AGRMET_svp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_tr_coeffs.F90 b/lis/metforcing/usaf/AGRMET_tr_coeffs.F90 index 0a06d0b60..179ff89cd 100644 --- a/lis/metforcing/usaf/AGRMET_tr_coeffs.F90 +++ b/lis/metforcing/usaf/AGRMET_tr_coeffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_trcalc.F90 b/lis/metforcing/usaf/AGRMET_trcalc.F90 index faf43a1f7..ff1988809 100644 --- a/lis/metforcing/usaf/AGRMET_trcalc.F90 +++ b/lis/metforcing/usaf/AGRMET_trcalc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_trnref.F90 b/lis/metforcing/usaf/AGRMET_trnref.F90 index c3f35db28..2c4c2bda3 100644 --- a/lis/metforcing/usaf/AGRMET_trnref.F90 +++ b/lis/metforcing/usaf/AGRMET_trnref.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_trpoly.F90 b/lis/metforcing/usaf/AGRMET_trpoly.F90 index 6c2d2aa61..4bf83d935 100644 --- a/lis/metforcing/usaf/AGRMET_trpoly.F90 +++ b/lis/metforcing/usaf/AGRMET_trpoly.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_typcnv.F90 b/lis/metforcing/usaf/AGRMET_typcnv.F90 index 6ff90c1f0..6f164912a 100644 --- a/lis/metforcing/usaf/AGRMET_typcnv.F90 +++ b/lis/metforcing/usaf/AGRMET_typcnv.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_valid.F90 b/lis/metforcing/usaf/AGRMET_valid.F90 index 4314d49de..aa562ae1b 100644 --- a/lis/metforcing/usaf/AGRMET_valid.F90 +++ b/lis/metforcing/usaf/AGRMET_valid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/AGRMET_w.F90 b/lis/metforcing/usaf/AGRMET_w.F90 index a016baa5b..880e7c1f3 100644 --- a/lis/metforcing/usaf/AGRMET_w.F90 +++ b/lis/metforcing/usaf/AGRMET_w.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/EMK_precipMod.F90.qc_attempt b/lis/metforcing/usaf/EMK_precipMod.F90.qc_attempt index debcd5a13..00d77e314 100644 --- a/lis/metforcing/usaf/EMK_precipMod.F90.qc_attempt +++ b/lis/metforcing/usaf/EMK_precipMod.F90.qc_attempt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/USAF_ImergHHMod.F90 b/lis/metforcing/usaf/USAF_ImergHHMod.F90 index 7aa7d9c52..10ae967a4 100644 --- a/lis/metforcing/usaf/USAF_ImergHHMod.F90 +++ b/lis/metforcing/usaf/USAF_ImergHHMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/USAF_OBAMod.F90 b/lis/metforcing/usaf/USAF_OBAMod.F90 index a3788ef57..80aab7045 100644 --- a/lis/metforcing/usaf/USAF_OBAMod.F90 +++ b/lis/metforcing/usaf/USAF_OBAMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/USAF_WWMCA_grib1Mod.F90 b/lis/metforcing/usaf/USAF_WWMCA_grib1Mod.F90 index 4d8b82dfd..87c6fdcb2 100644 --- a/lis/metforcing/usaf/USAF_WWMCA_grib1Mod.F90 +++ b/lis/metforcing/usaf/USAF_WWMCA_grib1Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 46421128a..c30d45715 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/USAF_sfcval.F90 b/lis/metforcing/usaf/USAF_sfcval.F90 index 989f6ff45..047d21e03 100644 --- a/lis/metforcing/usaf/USAF_sfcval.F90 +++ b/lis/metforcing/usaf/USAF_sfcval.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/compute_cod_based_clouds.F90 b/lis/metforcing/usaf/compute_cod_based_clouds.F90 index 6da9cbf2f..fd8158db5 100644 --- a/lis/metforcing/usaf/compute_cod_based_clouds.F90 +++ b/lis/metforcing/usaf/compute_cod_based_clouds.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/compute_type_based_clouds.F90 b/lis/metforcing/usaf/compute_type_based_clouds.F90 index 67c974bbb..f3805a862 100644 --- a/lis/metforcing/usaf/compute_type_based_clouds.F90 +++ b/lis/metforcing/usaf/compute_type_based_clouds.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/finalize_agrmet.F90 b/lis/metforcing/usaf/finalize_agrmet.F90 index 0a97ff567..9959ef967 100644 --- a/lis/metforcing/usaf/finalize_agrmet.F90 +++ b/lis/metforcing/usaf/finalize_agrmet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/get_agrmet.F90 b/lis/metforcing/usaf/get_agrmet.F90 index 422e7434a..00a2d2d72 100644 --- a/lis/metforcing/usaf/get_agrmet.F90 +++ b/lis/metforcing/usaf/get_agrmet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/interp_agrmetvar.F90 b/lis/metforcing/usaf/interp_agrmetvar.F90 index 1175b943e..00fd0ae8b 100644 --- a/lis/metforcing/usaf/interp_agrmetvar.F90 +++ b/lis/metforcing/usaf/interp_agrmetvar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/process_cloud_layers.F90 b/lis/metforcing/usaf/process_cloud_layers.F90 index d1f569d73..08d22f0c7 100644 --- a/lis/metforcing/usaf/process_cloud_layers.F90 +++ b/lis/metforcing/usaf/process_cloud_layers.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/read_cod.F90 b/lis/metforcing/usaf/read_cod.F90 index 5e82b3b9c..3e2d982d1 100644 --- a/lis/metforcing/usaf/read_cod.F90 +++ b/lis/metforcing/usaf/read_cod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/readagrmetforcing.F90 b/lis/metforcing/usaf/readagrmetforcing.F90 index 9cbb80d7a..2025fd88c 100644 --- a/lis/metforcing/usaf/readagrmetforcing.F90 +++ b/lis/metforcing/usaf/readagrmetforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/readagrmetforcinganalysis.F90 b/lis/metforcing/usaf/readagrmetforcinganalysis.F90 index 343930b41..36a69a52e 100644 --- a/lis/metforcing/usaf/readagrmetforcinganalysis.F90 +++ b/lis/metforcing/usaf/readagrmetforcinganalysis.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/readagrmetpcpforcing.F90 b/lis/metforcing/usaf/readagrmetpcpforcing.F90 index c47c1f020..f9c812901 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcing.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 b/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 index 1b7c050c8..cbaa27a81 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcinganalysis.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/readcrd_agrmet.F90 b/lis/metforcing/usaf/readcrd_agrmet.F90 index 4b307f4b2..ebac8311a 100644 --- a/lis/metforcing/usaf/readcrd_agrmet.F90 +++ b/lis/metforcing/usaf/readcrd_agrmet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/reset_agrmet.F90 b/lis/metforcing/usaf/reset_agrmet.F90 index e6e8e0fea..89be4d0b5 100644 --- a/lis/metforcing/usaf/reset_agrmet.F90 +++ b/lis/metforcing/usaf/reset_agrmet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/retrieve_agrmetvar.F90 b/lis/metforcing/usaf/retrieve_agrmetvar.F90 index 1bbda0e68..9bcf34ba7 100644 --- a/lis/metforcing/usaf/retrieve_agrmetvar.F90 +++ b/lis/metforcing/usaf/retrieve_agrmetvar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/usaf/timeinterp_agrmet.F90 b/lis/metforcing/usaf/timeinterp_agrmet.F90 index a016c3b48..f4ecf2303 100644 --- a/lis/metforcing/usaf/timeinterp_agrmet.F90 +++ b/lis/metforcing/usaf/timeinterp_agrmet.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/0Intro_vicforcing.txt b/lis/metforcing/vicforcing.4.1.2/0Intro_vicforcing.txt index 4ba3bad3d..bb4bc9a41 100755 --- a/lis/metforcing/vicforcing.4.1.2/0Intro_vicforcing.txt +++ b/lis/metforcing/vicforcing.4.1.2/0Intro_vicforcing.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90 b/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90 index c7f595997..cf8830ae3 100755 --- a/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90 +++ b/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90.tinterp b/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90.tinterp index ff9affe7e..60914374d 100755 --- a/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90.tinterp +++ b/lis/metforcing/vicforcing.4.1.2/getvicforcing.F90.tinterp @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/readviccrd.F90 b/lis/metforcing/vicforcing.4.1.2/readviccrd.F90 index d04a17184..6a8fe89f1 100755 --- a/lis/metforcing/vicforcing.4.1.2/readviccrd.F90 +++ b/lis/metforcing/vicforcing.4.1.2/readviccrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90 b/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90 index 5ff0dad56..dabc6047c 100755 --- a/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90 +++ b/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90.tinterp b/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90.tinterp index 611cd412d..a5daf029b 100755 --- a/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90.tinterp +++ b/lis/metforcing/vicforcing.4.1.2/time_interp_vicforcing.F90.tinterp @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/vic412_read_gridded_forcing_data.F90 b/lis/metforcing/vicforcing.4.1.2/vic412_read_gridded_forcing_data.F90 index b5016d5cc..bb0874ed6 100755 --- a/lis/metforcing/vicforcing.4.1.2/vic412_read_gridded_forcing_data.F90 +++ b/lis/metforcing/vicforcing.4.1.2/vic412_read_gridded_forcing_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/vic_forcingMod.F90 b/lis/metforcing/vicforcing.4.1.2/vic_forcingMod.F90 index e63c2ab46..76b8fb8ea 100755 --- a/lis/metforcing/vicforcing.4.1.2/vic_forcingMod.F90 +++ b/lis/metforcing/vicforcing.4.1.2/vic_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/vicforcing_finalize.F90 b/lis/metforcing/vicforcing.4.1.2/vicforcing_finalize.F90 index a45dd51a4..d59acce38 100755 --- a/lis/metforcing/vicforcing.4.1.2/vicforcing_finalize.F90 +++ b/lis/metforcing/vicforcing.4.1.2/vicforcing_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing.4.1.2/vicforcing_reset.F90 b/lis/metforcing/vicforcing.4.1.2/vicforcing_reset.F90 index 32a39613a..fb7fd54db 100755 --- a/lis/metforcing/vicforcing.4.1.2/vicforcing_reset.F90 +++ b/lis/metforcing/vicforcing.4.1.2/vicforcing_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/0Intro_vicforcing.txt b/lis/metforcing/vicforcing/0Intro_vicforcing.txt index 4ba3bad3d..bb4bc9a41 100644 --- a/lis/metforcing/vicforcing/0Intro_vicforcing.txt +++ b/lis/metforcing/vicforcing/0Intro_vicforcing.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/getvicforcing.F90 b/lis/metforcing/vicforcing/getvicforcing.F90 index e79484933..c33325558 100644 --- a/lis/metforcing/vicforcing/getvicforcing.F90 +++ b/lis/metforcing/vicforcing/getvicforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/getvicforcing.F90.tinterp b/lis/metforcing/vicforcing/getvicforcing.F90.tinterp index ff9affe7e..60914374d 100644 --- a/lis/metforcing/vicforcing/getvicforcing.F90.tinterp +++ b/lis/metforcing/vicforcing/getvicforcing.F90.tinterp @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/readviccrd.F90 b/lis/metforcing/vicforcing/readviccrd.F90 index d1268aaef..a0ac8da88 100644 --- a/lis/metforcing/vicforcing/readviccrd.F90 +++ b/lis/metforcing/vicforcing/readviccrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/time_interp_vicforcing.F90 b/lis/metforcing/vicforcing/time_interp_vicforcing.F90 index 46f34a2c8..49abef3d2 100644 --- a/lis/metforcing/vicforcing/time_interp_vicforcing.F90 +++ b/lis/metforcing/vicforcing/time_interp_vicforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/time_interp_vicforcing.F90.tinterp b/lis/metforcing/vicforcing/time_interp_vicforcing.F90.tinterp index 611cd412d..a5daf029b 100644 --- a/lis/metforcing/vicforcing/time_interp_vicforcing.F90.tinterp +++ b/lis/metforcing/vicforcing/time_interp_vicforcing.F90.tinterp @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/vic411_read_gridded_forcing_data.F90 b/lis/metforcing/vicforcing/vic411_read_gridded_forcing_data.F90 index ac06a0938..b95e4074b 100644 --- a/lis/metforcing/vicforcing/vic411_read_gridded_forcing_data.F90 +++ b/lis/metforcing/vicforcing/vic411_read_gridded_forcing_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/vic_forcingMod.F90 b/lis/metforcing/vicforcing/vic_forcingMod.F90 index b3f678711..2647babde 100644 --- a/lis/metforcing/vicforcing/vic_forcingMod.F90 +++ b/lis/metforcing/vicforcing/vic_forcingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/vicforcing_finalize.F90 b/lis/metforcing/vicforcing/vicforcing_finalize.F90 index f69bd76ed..f8b463884 100644 --- a/lis/metforcing/vicforcing/vicforcing_finalize.F90 +++ b/lis/metforcing/vicforcing/vicforcing_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/metforcing/vicforcing/vicforcing_reset.F90 b/lis/metforcing/vicforcing/vicforcing_reset.F90 index 3fdbcb895..54dd34bc3 100644 --- a/lis/metforcing/vicforcing/vicforcing_reset.F90 +++ b/lis/metforcing/vicforcing/vicforcing_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/offline/lisdrv.F90 b/lis/offline/lisdrv.F90 index 428241531..dee7ccfbe 100644 --- a/lis/offline/lisdrv.F90 +++ b/lis/offline/lisdrv.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/0Intro_paramest.txt b/lis/optUE/0Intro_paramest.txt index bcee4c2b8..0880f0275 100644 --- a/lis/optUE/0Intro_paramest.txt +++ b/lis/optUE/0Intro_paramest.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/DEMC/DEMCAlgorithm.F90 b/lis/optUE/algorithm/DEMC/DEMCAlgorithm.F90 index 34c2e300d..6048ac7db 100644 --- a/lis/optUE/algorithm/DEMC/DEMCAlgorithm.F90 +++ b/lis/optUE/algorithm/DEMC/DEMCAlgorithm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/DEMC/DEMC_varctl.F90 b/lis/optUE/algorithm/DEMC/DEMC_varctl.F90 index 0cf7353ba..74939421d 100644 --- a/lis/optUE/algorithm/DEMC/DEMC_varctl.F90 +++ b/lis/optUE/algorithm/DEMC/DEMC_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/DEMCz/0Intro_demc.txt b/lis/optUE/algorithm/DEMCz/0Intro_demc.txt index 30352420a..c91202c7a 100644 --- a/lis/optUE/algorithm/DEMCz/0Intro_demc.txt +++ b/lis/optUE/algorithm/DEMCz/0Intro_demc.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/DEMCz/DEMCzAlgorithm.F90 b/lis/optUE/algorithm/DEMCz/DEMCzAlgorithm.F90 index 56fed4aab..be6a6b4b9 100644 --- a/lis/optUE/algorithm/DEMCz/DEMCzAlgorithm.F90 +++ b/lis/optUE/algorithm/DEMCz/DEMCzAlgorithm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/DEMCz/DEMCz_varctl.F90 b/lis/optUE/algorithm/DEMCz/DEMCz_varctl.F90 index 191bc1164..4115fbc6c 100644 --- a/lis/optUE/algorithm/DEMCz/DEMCz_varctl.F90 +++ b/lis/optUE/algorithm/DEMCz/DEMCz_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/ES/ES_varctl.F90 b/lis/optUE/algorithm/ES/ES_varctl.F90 index fc89ac9db..6fc782045 100644 --- a/lis/optUE/algorithm/ES/ES_varctl.F90 +++ b/lis/optUE/algorithm/ES/ES_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/ES/EnumeratedSearch.F90 b/lis/optUE/algorithm/ES/EnumeratedSearch.F90 index a62213870..bc8ea29ac 100644 --- a/lis/optUE/algorithm/ES/EnumeratedSearch.F90 +++ b/lis/optUE/algorithm/ES/EnumeratedSearch.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/GA/0Intro_ga.txt b/lis/optUE/algorithm/GA/0Intro_ga.txt index 151b2a41a..c67afc669 100644 --- a/lis/optUE/algorithm/GA/0Intro_ga.txt +++ b/lis/optUE/algorithm/GA/0Intro_ga.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/GA/GA_varctl.F90 b/lis/optUE/algorithm/GA/GA_varctl.F90 index 7b8ec7849..b366503b7 100644 --- a/lis/optUE/algorithm/GA/GA_varctl.F90 +++ b/lis/optUE/algorithm/GA/GA_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/GA/GeneticAlgorithm.F90 b/lis/optUE/algorithm/GA/GeneticAlgorithm.F90 index 8a26d3f07..e09c1451d 100644 --- a/lis/optUE/algorithm/GA/GeneticAlgorithm.F90 +++ b/lis/optUE/algorithm/GA/GeneticAlgorithm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/LM/LM_varctl.F90 b/lis/optUE/algorithm/LM/LM_varctl.F90 index 7427f9247..729a0a299 100755 --- a/lis/optUE/algorithm/LM/LM_varctl.F90 +++ b/lis/optUE/algorithm/LM/LM_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/LM/LevenbergMarquardt.F90 b/lis/optUE/algorithm/LM/LevenbergMarquardt.F90 index f07985ea8..11a4fe809 100755 --- a/lis/optUE/algorithm/LM/LevenbergMarquardt.F90 +++ b/lis/optUE/algorithm/LM/LevenbergMarquardt.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/MCSIM/MCSIMAlgorithm.F90 b/lis/optUE/algorithm/MCSIM/MCSIMAlgorithm.F90 index 97b75c5af..c78bb804e 100644 --- a/lis/optUE/algorithm/MCSIM/MCSIMAlgorithm.F90 +++ b/lis/optUE/algorithm/MCSIM/MCSIMAlgorithm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/MCSIM/MCSIM_varctl.F90 b/lis/optUE/algorithm/MCSIM/MCSIM_varctl.F90 index 5f2a738da..353718e8a 100644 --- a/lis/optUE/algorithm/MCSIM/MCSIM_varctl.F90 +++ b/lis/optUE/algorithm/MCSIM/MCSIM_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/RWMCMC/RWMCMCAlgorithm.F90 b/lis/optUE/algorithm/RWMCMC/RWMCMCAlgorithm.F90 index 1e36321d4..2356e9082 100644 --- a/lis/optUE/algorithm/RWMCMC/RWMCMCAlgorithm.F90 +++ b/lis/optUE/algorithm/RWMCMC/RWMCMCAlgorithm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/RWMCMC/RWMCMC_varctl.F90 b/lis/optUE/algorithm/RWMCMC/RWMCMC_varctl.F90 index c1433ca25..10e34af06 100644 --- a/lis/optUE/algorithm/RWMCMC/RWMCMC_varctl.F90 +++ b/lis/optUE/algorithm/RWMCMC/RWMCMC_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/SCEUA/SCEUA_varctl.F90 b/lis/optUE/algorithm/SCEUA/SCEUA_varctl.F90 index 15de943ab..56b5f2e35 100755 --- a/lis/optUE/algorithm/SCEUA/SCEUA_varctl.F90 +++ b/lis/optUE/algorithm/SCEUA/SCEUA_varctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/algorithm/SCEUA/ShuffledComplexEvolution.F90 b/lis/optUE/algorithm/SCEUA/ShuffledComplexEvolution.F90 index 0361e156f..c2cfc9356 100755 --- a/lis/optUE/algorithm/SCEUA/ShuffledComplexEvolution.F90 +++ b/lis/optUE/algorithm/SCEUA/ShuffledComplexEvolution.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LL/LLobjFunc_Mod.F90 b/lis/optUE/type/paramestim/objfunc/LL/LLobjFunc_Mod.F90 index 0a8ea6802..022eff4a4 100755 --- a/lis/optUE/type/paramestim/objfunc/LL/LLobjFunc_Mod.F90 +++ b/lis/optUE/type/paramestim/objfunc/LL/LLobjFunc_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LL/computeLLestimate.F90 b/lis/optUE/type/paramestim/objfunc/LL/computeLLestimate.F90 index 196a0da3f..3198114df 100755 --- a/lis/optUE/type/paramestim/objfunc/LL/computeLLestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LL/computeLLestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LL/resetLLestimate.F90 b/lis/optUE/type/paramestim/objfunc/LL/resetLLestimate.F90 index 9b98b9040..2eda5add4 100755 --- a/lis/optUE/type/paramestim/objfunc/LL/resetLLestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LL/resetLLestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LL/updateLLestimate.F90 b/lis/optUE/type/paramestim/objfunc/LL/updateLLestimate.F90 index 820d907a2..a2056031b 100755 --- a/lis/optUE/type/paramestim/objfunc/LL/updateLLestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LL/updateLLestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LM/LMobjFunc_Mod.F90 b/lis/optUE/type/paramestim/objfunc/LM/LMobjFunc_Mod.F90 index 0c5092189..1816bf415 100755 --- a/lis/optUE/type/paramestim/objfunc/LM/LMobjFunc_Mod.F90 +++ b/lis/optUE/type/paramestim/objfunc/LM/LMobjFunc_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LM/computeLMestimate.F90 b/lis/optUE/type/paramestim/objfunc/LM/computeLMestimate.F90 index e214a0e1b..27a79b777 100755 --- a/lis/optUE/type/paramestim/objfunc/LM/computeLMestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LM/computeLMestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LM/resetLMestimate.F90 b/lis/optUE/type/paramestim/objfunc/LM/resetLMestimate.F90 index d8111f8ca..28aaddec1 100755 --- a/lis/optUE/type/paramestim/objfunc/LM/resetLMestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LM/resetLMestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LM/updateLMestimate.F90 b/lis/optUE/type/paramestim/objfunc/LM/updateLMestimate.F90 index 85c37460d..91263735e 100755 --- a/lis/optUE/type/paramestim/objfunc/LM/updateLMestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LM/updateLMestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LS/LSobjFunc_Mod.F90 b/lis/optUE/type/paramestim/objfunc/LS/LSobjFunc_Mod.F90 index a47db5a39..aa30f1300 100644 --- a/lis/optUE/type/paramestim/objfunc/LS/LSobjFunc_Mod.F90 +++ b/lis/optUE/type/paramestim/objfunc/LS/LSobjFunc_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LS/computeLSestimate.F90 b/lis/optUE/type/paramestim/objfunc/LS/computeLSestimate.F90 index f8bd9a06a..85065c41a 100644 --- a/lis/optUE/type/paramestim/objfunc/LS/computeLSestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LS/computeLSestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LS/resetLSestimate.F90 b/lis/optUE/type/paramestim/objfunc/LS/resetLSestimate.F90 index 3439d2a40..18e672883 100644 --- a/lis/optUE/type/paramestim/objfunc/LS/resetLSestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LS/resetLSestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/LS/updateLSestimate.F90 b/lis/optUE/type/paramestim/objfunc/LS/updateLSestimate.F90 index 2b9af73b7..26137bb9c 100644 --- a/lis/optUE/type/paramestim/objfunc/LS/updateLSestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/LS/updateLSestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/P/PobjFunc_Mod.F90 b/lis/optUE/type/paramestim/objfunc/P/PobjFunc_Mod.F90 index 7b3cf9bdd..a3895deef 100755 --- a/lis/optUE/type/paramestim/objfunc/P/PobjFunc_Mod.F90 +++ b/lis/optUE/type/paramestim/objfunc/P/PobjFunc_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/P/computePestimate.F90 b/lis/optUE/type/paramestim/objfunc/P/computePestimate.F90 index a522352ed..724793c6f 100755 --- a/lis/optUE/type/paramestim/objfunc/P/computePestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/P/computePestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/P/resetPestimate.F90 b/lis/optUE/type/paramestim/objfunc/P/resetPestimate.F90 index 89fe05bda..73a4516b5 100755 --- a/lis/optUE/type/paramestim/objfunc/P/resetPestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/P/resetPestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/objfunc/P/updatePestimate.F90 b/lis/optUE/type/paramestim/objfunc/P/updatePestimate.F90 index ddfa7b29f..bf1b1a007 100755 --- a/lis/optUE/type/paramestim/objfunc/P/updatePestimate.F90 +++ b/lis/optUE/type/paramestim/objfunc/P/updatePestimate.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/AMSRE_SR/AMSRE_SR_em_obsMod.F90 b/lis/optUE/type/paramestim/obs/AMSRE_SR/AMSRE_SR_em_obsMod.F90 index 53afd32bd..dce5b0e13 100755 --- a/lis/optUE/type/paramestim/obs/AMSRE_SR/AMSRE_SR_em_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/AMSRE_SR/AMSRE_SR_em_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/AMSRE_SR/read_AMSRE_SRdata.F90 b/lis/optUE/type/paramestim/obs/AMSRE_SR/read_AMSRE_SRdata.F90 index 1841e9eae..54cd69130 100755 --- a/lis/optUE/type/paramestim/obs/AMSRE_SR/read_AMSRE_SRdata.F90 +++ b/lis/optUE/type/paramestim/obs/AMSRE_SR/read_AMSRE_SRdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/AMSRE_SR/reset_AMSRE_SRObsdata.F90 b/lis/optUE/type/paramestim/obs/AMSRE_SR/reset_AMSRE_SRObsdata.F90 index 097dbf187..36b76b615 100644 --- a/lis/optUE/type/paramestim/obs/AMSRE_SR/reset_AMSRE_SRObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/AMSRE_SR/reset_AMSRE_SRObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/AMSRE_SR/write_AMSRE_SR_em_obs_data.F90 b/lis/optUE/type/paramestim/obs/AMSRE_SR/write_AMSRE_SR_em_obs_data.F90 index aadd26cb2..b8cb9f400 100755 --- a/lis/optUE/type/paramestim/obs/AMSRE_SR/write_AMSRE_SR_em_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/AMSRE_SR/write_AMSRE_SR_em_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARM/ARMdata_module.F90 b/lis/optUE/type/paramestim/obs/ARM/ARMdata_module.F90 index 9690b519b..1cca1beb5 100644 --- a/lis/optUE/type/paramestim/obs/ARM/ARMdata_module.F90 +++ b/lis/optUE/type/paramestim/obs/ARM/ARMdata_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARM/read_ARMdata.F90 b/lis/optUE/type/paramestim/obs/ARM/read_ARMdata.F90 index 76fdaffd0..8f83812d7 100644 --- a/lis/optUE/type/paramestim/obs/ARM/read_ARMdata.F90 +++ b/lis/optUE/type/paramestim/obs/ARM/read_ARMdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARM/reset_ARMdata.F90 b/lis/optUE/type/paramestim/obs/ARM/reset_ARMdata.F90 index bd61fc9ef..14afb84a0 100644 --- a/lis/optUE/type/paramestim/obs/ARM/reset_ARMdata.F90 +++ b/lis/optUE/type/paramestim/obs/ARM/reset_ARMdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARM/write_ARMdata.F90 b/lis/optUE/type/paramestim/obs/ARM/write_ARMdata.F90 index 3be00ed5b..656c572a1 100644 --- a/lis/optUE/type/paramestim/obs/ARM/write_ARMdata.F90 +++ b/lis/optUE/type/paramestim/obs/ARM/write_ARMdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARSsm/ARSsm_obsMod.F90 b/lis/optUE/type/paramestim/obs/ARSsm/ARSsm_obsMod.F90 index 2ebb220de..770aeba03 100755 --- a/lis/optUE/type/paramestim/obs/ARSsm/ARSsm_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/ARSsm/ARSsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARSsm/read_ARSsmobs.F90 b/lis/optUE/type/paramestim/obs/ARSsm/read_ARSsmobs.F90 index 1e9d95509..9e5a234e9 100755 --- a/lis/optUE/type/paramestim/obs/ARSsm/read_ARSsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ARSsm/read_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARSsm/reset_ARSsmobs.F90 b/lis/optUE/type/paramestim/obs/ARSsm/reset_ARSsmobs.F90 index e895b7c2c..bcdda69b6 100755 --- a/lis/optUE/type/paramestim/obs/ARSsm/reset_ARSsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ARSsm/reset_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ARSsm/write_ARSsmobs.F90 b/lis/optUE/type/paramestim/obs/ARSsm/write_ARSsmobs.F90 index e48fb1dcb..c4d1ff460 100755 --- a/lis/optUE/type/paramestim/obs/ARSsm/write_ARSsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ARSsm/write_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Ameriflux/AmerifluxobsMod.F90 b/lis/optUE/type/paramestim/obs/Ameriflux/AmerifluxobsMod.F90 index 0b866b242..1263cf7cb 100755 --- a/lis/optUE/type/paramestim/obs/Ameriflux/AmerifluxobsMod.F90 +++ b/lis/optUE/type/paramestim/obs/Ameriflux/AmerifluxobsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Ameriflux/read_AmerifluxObs.F90 b/lis/optUE/type/paramestim/obs/Ameriflux/read_AmerifluxObs.F90 index 314ab501e..d86a4ad69 100755 --- a/lis/optUE/type/paramestim/obs/Ameriflux/read_AmerifluxObs.F90 +++ b/lis/optUE/type/paramestim/obs/Ameriflux/read_AmerifluxObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Ameriflux/read_ameriflux_station.F90 b/lis/optUE/type/paramestim/obs/Ameriflux/read_ameriflux_station.F90 index 9a0e57ac0..560d762cb 100644 --- a/lis/optUE/type/paramestim/obs/Ameriflux/read_ameriflux_station.F90 +++ b/lis/optUE/type/paramestim/obs/Ameriflux/read_ameriflux_station.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Ameriflux/write_AmerifluxObs.F90 b/lis/optUE/type/paramestim/obs/Ameriflux/write_AmerifluxObs.F90 index af503846d..f78bac400 100755 --- a/lis/optUE/type/paramestim/obs/Ameriflux/write_AmerifluxObs.F90 +++ b/lis/optUE/type/paramestim/obs/Ameriflux/write_AmerifluxObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/CNRS/CNRS_em_obsMod.F90 b/lis/optUE/type/paramestim/obs/CNRS/CNRS_em_obsMod.F90 index 04bcfd94c..406c02d52 100755 --- a/lis/optUE/type/paramestim/obs/CNRS/CNRS_em_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/CNRS/CNRS_em_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata.F90 b/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata.F90 index 9f43f0bb1..f1706a302 100755 --- a/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata.F90 +++ b/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata_MPDI.F90 b/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata_MPDI.F90 index 37679bba9..3e6903ae6 100644 --- a/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata_MPDI.F90 +++ b/lis/optUE/type/paramestim/obs/CNRS/read_CNRSdata_MPDI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/CNRS/reset_CNRS_em_obs_data.F90 b/lis/optUE/type/paramestim/obs/CNRS/reset_CNRS_em_obs_data.F90 index 8f71e75a8..7df7ad4aa 100644 --- a/lis/optUE/type/paramestim/obs/CNRS/reset_CNRS_em_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/CNRS/reset_CNRS_em_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/CNRS/write_CNRS_em_obs_data.F90 b/lis/optUE/type/paramestim/obs/CNRS/write_CNRS_em_obs_data.F90 index 423adf005..a26814005 100755 --- a/lis/optUE/type/paramestim/obs/CNRS/write_CNRS_em_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/CNRS/write_CNRS_em_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/EmptyObs/Empty_obsMod.F90 b/lis/optUE/type/paramestim/obs/EmptyObs/Empty_obsMod.F90 index 2b42e4b87..79f8f3e4b 100644 --- a/lis/optUE/type/paramestim/obs/EmptyObs/Empty_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/EmptyObs/Empty_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/FLUXNET/FLUXNETdata_module.F90 b/lis/optUE/type/paramestim/obs/FLUXNET/FLUXNETdata_module.F90 index 0776712c9..4d85da472 100644 --- a/lis/optUE/type/paramestim/obs/FLUXNET/FLUXNETdata_module.F90 +++ b/lis/optUE/type/paramestim/obs/FLUXNET/FLUXNETdata_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/FLUXNET/read_FLUXNETdata.F90 b/lis/optUE/type/paramestim/obs/FLUXNET/read_FLUXNETdata.F90 index 6fcf2e089..f42c64c7c 100644 --- a/lis/optUE/type/paramestim/obs/FLUXNET/read_FLUXNETdata.F90 +++ b/lis/optUE/type/paramestim/obs/FLUXNET/read_FLUXNETdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/FLUXNET/reset_FLUXNETdata.F90 b/lis/optUE/type/paramestim/obs/FLUXNET/reset_FLUXNETdata.F90 index e37ac80d9..939139b32 100644 --- a/lis/optUE/type/paramestim/obs/FLUXNET/reset_FLUXNETdata.F90 +++ b/lis/optUE/type/paramestim/obs/FLUXNET/reset_FLUXNETdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/FLUXNET/write_FLUXNETdata.F90 b/lis/optUE/type/paramestim/obs/FLUXNET/write_FLUXNETdata.F90 index db8606b32..d6a3f49ee 100644 --- a/lis/optUE/type/paramestim/obs/FLUXNET/write_FLUXNETdata.F90 +++ b/lis/optUE/type/paramestim/obs/FLUXNET/write_FLUXNETdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Global_LS_data/GlobalLSDataMod.F90 b/lis/optUE/type/paramestim/obs/Global_LS_data/GlobalLSDataMod.F90 index 85fb18c96..ced19d1f5 100644 --- a/lis/optUE/type/paramestim/obs/Global_LS_data/GlobalLSDataMod.F90 +++ b/lis/optUE/type/paramestim/obs/Global_LS_data/GlobalLSDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Global_LS_data/read_GlobalLSObsdata.F90 b/lis/optUE/type/paramestim/obs/Global_LS_data/read_GlobalLSObsdata.F90 index 0a6aaa5f8..137c125a7 100755 --- a/lis/optUE/type/paramestim/obs/Global_LS_data/read_GlobalLSObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/Global_LS_data/read_GlobalLSObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Global_LS_data/reset_GlobalLSObsData.F90 b/lis/optUE/type/paramestim/obs/Global_LS_data/reset_GlobalLSObsData.F90 index c59038837..5b82c3d40 100644 --- a/lis/optUE/type/paramestim/obs/Global_LS_data/reset_GlobalLSObsData.F90 +++ b/lis/optUE/type/paramestim/obs/Global_LS_data/reset_GlobalLSObsData.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Global_LS_data/write_GlobalLSObsdata.F90 b/lis/optUE/type/paramestim/obs/Global_LS_data/write_GlobalLSObsdata.F90 index 3bfb10059..f4a2dea33 100755 --- a/lis/optUE/type/paramestim/obs/Global_LS_data/write_GlobalLSObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/Global_LS_data/write_GlobalLSObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISCCP_Tskin/ISCCP_Tskinobs_module.F90 b/lis/optUE/type/paramestim/obs/ISCCP_Tskin/ISCCP_Tskinobs_module.F90 index 95f112ae0..67fd2a6aa 100755 --- a/lis/optUE/type/paramestim/obs/ISCCP_Tskin/ISCCP_Tskinobs_module.F90 +++ b/lis/optUE/type/paramestim/obs/ISCCP_Tskin/ISCCP_Tskinobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISCCP_Tskin/read_ISCCP_Tskindata.F90 b/lis/optUE/type/paramestim/obs/ISCCP_Tskin/read_ISCCP_Tskindata.F90 index c6e7c5360..e8be73c71 100755 --- a/lis/optUE/type/paramestim/obs/ISCCP_Tskin/read_ISCCP_Tskindata.F90 +++ b/lis/optUE/type/paramestim/obs/ISCCP_Tskin/read_ISCCP_Tskindata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISMNsm/ISMNsm_obsMod.F90 b/lis/optUE/type/paramestim/obs/ISMNsm/ISMNsm_obsMod.F90 index dab7b9173..e712ebea4 100755 --- a/lis/optUE/type/paramestim/obs/ISMNsm/ISMNsm_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/ISMNsm/ISMNsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISMNsm/read_ISMNsmobs.F90 b/lis/optUE/type/paramestim/obs/ISMNsm/read_ISMNsmobs.F90 index 0502e4df7..e3488ee53 100755 --- a/lis/optUE/type/paramestim/obs/ISMNsm/read_ISMNsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ISMNsm/read_ISMNsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISMNsm/reset_ISMNsmobs.F90 b/lis/optUE/type/paramestim/obs/ISMNsm/reset_ISMNsmobs.F90 index d3507e63c..33993a5cd 100755 --- a/lis/optUE/type/paramestim/obs/ISMNsm/reset_ISMNsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ISMNsm/reset_ISMNsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/ISMNsm/write_ISMNsmobs.F90 b/lis/optUE/type/paramestim/obs/ISMNsm/write_ISMNsmobs.F90 index cf59df0ae..d8c0e366f 100755 --- a/lis/optUE/type/paramestim/obs/ISMNsm/write_ISMNsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/ISMNsm/write_ISMNsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 index bd9865c29..c55c50e33 100755 --- a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/LPRM_AMSREsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/read_LPRM_AMSREsmdata.F90 b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/read_LPRM_AMSREsmdata.F90 index 012109114..590290211 100755 --- a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/read_LPRM_AMSREsmdata.F90 +++ b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/read_LPRM_AMSREsmdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/reset_LPRM_AMSREsmObsdata.F90 b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/reset_LPRM_AMSREsmObsdata.F90 index cfdccb07e..5907f9abc 100644 --- a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/reset_LPRM_AMSREsmObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/reset_LPRM_AMSREsmObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/write_LPRM_AMSREsm_obs_data.F90 b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/write_LPRM_AMSREsm_obs_data.F90 index a41a728eb..67bbe96a9 100755 --- a/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/write_LPRM_AMSREsm_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/LPRM_AMSREsm/write_LPRM_AMSREsm_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Macon_LS_data/MaconLSDataMod.F90 b/lis/optUE/type/paramestim/obs/Macon_LS_data/MaconLSDataMod.F90 index 35e40c9c7..cc67480e9 100644 --- a/lis/optUE/type/paramestim/obs/Macon_LS_data/MaconLSDataMod.F90 +++ b/lis/optUE/type/paramestim/obs/Macon_LS_data/MaconLSDataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Macon_LS_data/read_MaconLSObsdata.F90 b/lis/optUE/type/paramestim/obs/Macon_LS_data/read_MaconLSObsdata.F90 index 08ffea4fe..3e61e53b5 100755 --- a/lis/optUE/type/paramestim/obs/Macon_LS_data/read_MaconLSObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/Macon_LS_data/read_MaconLSObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/Macon_LS_data/write_MaconLSObsdata.F90 b/lis/optUE/type/paramestim/obs/Macon_LS_data/write_MaconLSObsdata.F90 index 28beed2f4..5f54d3c0b 100755 --- a/lis/optUE/type/paramestim/obs/Macon_LS_data/write_MaconLSObsdata.F90 +++ b/lis/optUE/type/paramestim/obs/Macon_LS_data/write_MaconLSObsdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/SMAPsm/SMAPsm_obsMod.F90 b/lis/optUE/type/paramestim/obs/SMAPsm/SMAPsm_obsMod.F90 index 98689f4d7..774c4947e 100644 --- a/lis/optUE/type/paramestim/obs/SMAPsm/SMAPsm_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/SMAPsm/SMAPsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/SMAPsm/read_SMAPsmobs.F90 b/lis/optUE/type/paramestim/obs/SMAPsm/read_SMAPsmobs.F90 index d9e8c1e1c..4986f0323 100644 --- a/lis/optUE/type/paramestim/obs/SMAPsm/read_SMAPsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/SMAPsm/read_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/SMAPsm/reset_SMAPsmobs.F90 b/lis/optUE/type/paramestim/obs/SMAPsm/reset_SMAPsmobs.F90 index 17a5f26f1..107d13fe5 100644 --- a/lis/optUE/type/paramestim/obs/SMAPsm/reset_SMAPsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/SMAPsm/reset_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/SMAPsm/write_SMAPsmobs.F90 b/lis/optUE/type/paramestim/obs/SMAPsm/write_SMAPsmobs.F90 index ad87a302f..fa5a777d8 100644 --- a/lis/optUE/type/paramestim/obs/SMAPsm/write_SMAPsmobs.F90 +++ b/lis/optUE/type/paramestim/obs/SMAPsm/write_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/UAsnow/UAsnow_obsMod.F90 b/lis/optUE/type/paramestim/obs/UAsnow/UAsnow_obsMod.F90 index c4d5e775d..f8b1284bc 100644 --- a/lis/optUE/type/paramestim/obs/UAsnow/UAsnow_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/UAsnow/UAsnow_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/UAsnow/read_UAsnowobs.F90 b/lis/optUE/type/paramestim/obs/UAsnow/read_UAsnowobs.F90 index 42f25b7df..b367c97c0 100644 --- a/lis/optUE/type/paramestim/obs/UAsnow/read_UAsnowobs.F90 +++ b/lis/optUE/type/paramestim/obs/UAsnow/read_UAsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/UAsnow/reset_UAsnowobs.F90 b/lis/optUE/type/paramestim/obs/UAsnow/reset_UAsnowobs.F90 index 77d92805b..e626edf02 100644 --- a/lis/optUE/type/paramestim/obs/UAsnow/reset_UAsnowobs.F90 +++ b/lis/optUE/type/paramestim/obs/UAsnow/reset_UAsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/UAsnow/write_UAsnowobs.F90 b/lis/optUE/type/paramestim/obs/UAsnow/write_UAsnowobs.F90 index 749f815ff..27a9c40e0 100644 --- a/lis/optUE/type/paramestim/obs/UAsnow/write_UAsnowobs.F90 +++ b/lis/optUE/type/paramestim/obs/UAsnow/write_UAsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/USDA_ARSsm/USDA_ARSsm_obsMod.F90 b/lis/optUE/type/paramestim/obs/USDA_ARSsm/USDA_ARSsm_obsMod.F90 index 26411a205..d0eee6c89 100755 --- a/lis/optUE/type/paramestim/obs/USDA_ARSsm/USDA_ARSsm_obsMod.F90 +++ b/lis/optUE/type/paramestim/obs/USDA_ARSsm/USDA_ARSsm_obsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/USDA_ARSsm/read_USDA_ARSsmdata.F90 b/lis/optUE/type/paramestim/obs/USDA_ARSsm/read_USDA_ARSsmdata.F90 index b16beb13f..fd5c09a0c 100755 --- a/lis/optUE/type/paramestim/obs/USDA_ARSsm/read_USDA_ARSsmdata.F90 +++ b/lis/optUE/type/paramestim/obs/USDA_ARSsm/read_USDA_ARSsmdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/USDA_ARSsm/reset_USDA_ARSsm_obs_data.F90 b/lis/optUE/type/paramestim/obs/USDA_ARSsm/reset_USDA_ARSsm_obs_data.F90 index cb0fe8860..20aad58b9 100644 --- a/lis/optUE/type/paramestim/obs/USDA_ARSsm/reset_USDA_ARSsm_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/USDA_ARSsm/reset_USDA_ARSsm_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/USDA_ARSsm/write_USDA_ARSsm_obs_data.F90 b/lis/optUE/type/paramestim/obs/USDA_ARSsm/write_USDA_ARSsm_obs_data.F90 index 5b515e6e4..c0421de04 100755 --- a/lis/optUE/type/paramestim/obs/USDA_ARSsm/write_USDA_ARSsm_obs_data.F90 +++ b/lis/optUE/type/paramestim/obs/USDA_ARSsm/write_USDA_ARSsm_obs_data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/pesynsm1/pesynsm1data_module.F90 b/lis/optUE/type/paramestim/obs/pesynsm1/pesynsm1data_module.F90 index a6331ea12..f746f64d4 100755 --- a/lis/optUE/type/paramestim/obs/pesynsm1/pesynsm1data_module.F90 +++ b/lis/optUE/type/paramestim/obs/pesynsm1/pesynsm1data_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/pesynsm1/read_pesynsm1data.F90 b/lis/optUE/type/paramestim/obs/pesynsm1/read_pesynsm1data.F90 index e2e8e63c9..62c173675 100755 --- a/lis/optUE/type/paramestim/obs/pesynsm1/read_pesynsm1data.F90 +++ b/lis/optUE/type/paramestim/obs/pesynsm1/read_pesynsm1data.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/template/read_templateObs.F90 b/lis/optUE/type/paramestim/obs/template/read_templateObs.F90 index 7ba0fc8a7..84dfee52a 100644 --- a/lis/optUE/type/paramestim/obs/template/read_templateObs.F90 +++ b/lis/optUE/type/paramestim/obs/template/read_templateObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/template/reset_templateObs.F90 b/lis/optUE/type/paramestim/obs/template/reset_templateObs.F90 index 568afc974..bc1c2a580 100644 --- a/lis/optUE/type/paramestim/obs/template/reset_templateObs.F90 +++ b/lis/optUE/type/paramestim/obs/template/reset_templateObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/template/templateObs_module.F90 b/lis/optUE/type/paramestim/obs/template/templateObs_module.F90 index 983a48417..abe580407 100644 --- a/lis/optUE/type/paramestim/obs/template/templateObs_module.F90 +++ b/lis/optUE/type/paramestim/obs/template/templateObs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/template/write_templateObs.F90 b/lis/optUE/type/paramestim/obs/template/write_templateObs.F90 index 65d9672ce..e48c1d2fa 100644 --- a/lis/optUE/type/paramestim/obs/template/write_templateObs.F90 +++ b/lis/optUE/type/paramestim/obs/template/write_templateObs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/wgPBMRsm/read_wgPBMRsmdata.F90 b/lis/optUE/type/paramestim/obs/wgPBMRsm/read_wgPBMRsmdata.F90 index d256d6333..3e7a109bc 100755 --- a/lis/optUE/type/paramestim/obs/wgPBMRsm/read_wgPBMRsmdata.F90 +++ b/lis/optUE/type/paramestim/obs/wgPBMRsm/read_wgPBMRsmdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/wgPBMRsm/reset_wgPBMRsmdata.F90 b/lis/optUE/type/paramestim/obs/wgPBMRsm/reset_wgPBMRsmdata.F90 index f8345bc1b..39e7a4451 100644 --- a/lis/optUE/type/paramestim/obs/wgPBMRsm/reset_wgPBMRsmdata.F90 +++ b/lis/optUE/type/paramestim/obs/wgPBMRsm/reset_wgPBMRsmdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/wgPBMRsm/wgPBMRsmobs_module.F90 b/lis/optUE/type/paramestim/obs/wgPBMRsm/wgPBMRsmobs_module.F90 index ffb6f8b26..277941c2f 100755 --- a/lis/optUE/type/paramestim/obs/wgPBMRsm/wgPBMRsmobs_module.F90 +++ b/lis/optUE/type/paramestim/obs/wgPBMRsm/wgPBMRsmobs_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/optUE/type/paramestim/obs/wgPBMRsm/write_wgPBMRsmdata.F90 b/lis/optUE/type/paramestim/obs/wgPBMRsm/write_wgPBMRsmdata.F90 index 4fc6fdb15..a1312a53a 100755 --- a/lis/optUE/type/paramestim/obs/wgPBMRsm/write_wgPBMRsmdata.F90 +++ b/lis/optUE/type/paramestim/obs/wgPBMRsm/write_wgPBMRsmdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/0Intro_params.txt b/lis/params/0Intro_params.txt index 86de4595d..26b317b32 100644 --- a/lis/params/0Intro_params.txt +++ b/lis/params/0Intro_params.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/albedo/ALMIPII/read_ALMIPIIalbedo.F90 b/lis/params/albedo/ALMIPII/read_ALMIPIIalbedo.F90 index 5b2ae03bf..f3e94e9d5 100644 --- a/lis/params/albedo/ALMIPII/read_ALMIPIIalbedo.F90 +++ b/lis/params/albedo/ALMIPII/read_ALMIPIIalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/albedo/ALMIPII/setup_ALMIPIIalbedo.F90 b/lis/params/albedo/ALMIPII/setup_ALMIPIIalbedo.F90 index dd50bb3f8..887c4ee37 100644 --- a/lis/params/albedo/ALMIPII/setup_ALMIPIIalbedo.F90 +++ b/lis/params/albedo/ALMIPII/setup_ALMIPIIalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/emissivity/ALMIPII/read_ALMIPIIemiss.F90 b/lis/params/emissivity/ALMIPII/read_ALMIPIIemiss.F90 index 47329584c..88561f7e1 100644 --- a/lis/params/emissivity/ALMIPII/read_ALMIPIIemiss.F90 +++ b/lis/params/emissivity/ALMIPII/read_ALMIPIIemiss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/emissivity/ALMIPII/setup_ALMIPIIemiss.F90 b/lis/params/emissivity/ALMIPII/setup_ALMIPIIemiss.F90 index ee0d3bc9a..9110ded6a 100644 --- a/lis/params/emissivity/ALMIPII/setup_ALMIPIIemiss.F90 +++ b/lis/params/emissivity/ALMIPII/setup_ALMIPIIemiss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/0Intro_greenness.txt b/lis/params/gfrac/0Intro_greenness.txt index 1d6d57742..a78f9d644 100644 --- a/lis/params/gfrac/0Intro_greenness.txt +++ b/lis/params/gfrac/0Intro_greenness.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/ALMIPII/read_ALMIPIIgfrac.F90 b/lis/params/gfrac/ALMIPII/read_ALMIPIIgfrac.F90 index 5bb5c11c4..ccc2c6f07 100644 --- a/lis/params/gfrac/ALMIPII/read_ALMIPIIgfrac.F90 +++ b/lis/params/gfrac/ALMIPII/read_ALMIPIIgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/ALMIPII/setup_ALMIPIIgfrac.F90 b/lis/params/gfrac/ALMIPII/setup_ALMIPIIgfrac.F90 index c31b825e5..38fc005c5 100644 --- a/lis/params/gfrac/ALMIPII/setup_ALMIPIIgfrac.F90 +++ b/lis/params/gfrac/ALMIPII/setup_ALMIPIIgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/NESDISWeekly/read_NESDISgfrac.F90 b/lis/params/gfrac/NESDISWeekly/read_NESDISgfrac.F90 index 0ef54e64d..2e73bec06 100644 --- a/lis/params/gfrac/NESDISWeekly/read_NESDISgfrac.F90 +++ b/lis/params/gfrac/NESDISWeekly/read_NESDISgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/NESDISWeekly/setup_NESDISgfrac.F90 b/lis/params/gfrac/NESDISWeekly/setup_NESDISgfrac.F90 index 6a9b17929..ed97d4293 100644 --- a/lis/params/gfrac/NESDISWeekly/setup_NESDISgfrac.F90 +++ b/lis/params/gfrac/NESDISWeekly/setup_NESDISgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/SPORTgfracMod.F90 b/lis/params/gfrac/SPORTDaily/SPORTgfracMod.F90 index 0bbfef462..9f00d8cc5 100644 --- a/lis/params/gfrac/SPORTDaily/SPORTgfracMod.F90 +++ b/lis/params/gfrac/SPORTDaily/SPORTgfracMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/cppfunmodis.h b/lis/params/gfrac/SPORTDaily/cppfunmodis.h index fb6ab6cb2..e66333cc3 100644 --- a/lis/params/gfrac/SPORTDaily/cppfunmodis.h +++ b/lis/params/gfrac/SPORTDaily/cppfunmodis.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/gvf_binary_reader_modis.h b/lis/params/gfrac/SPORTDaily/gvf_binary_reader_modis.h index 82f4bb151..0b8dc044f 100644 --- a/lis/params/gfrac/SPORTDaily/gvf_binary_reader_modis.h +++ b/lis/params/gfrac/SPORTDaily/gvf_binary_reader_modis.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/read_SPORTgfrac.F90 b/lis/params/gfrac/SPORTDaily/read_SPORTgfrac.F90 index 86412de0b..d0a065559 100644 --- a/lis/params/gfrac/SPORTDaily/read_SPORTgfrac.F90 +++ b/lis/params/gfrac/SPORTDaily/read_SPORTgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/read_gvf_binary_modis.cc b/lis/params/gfrac/SPORTDaily/read_gvf_binary_modis.cc index 30a0f559e..c898681ce 100644 --- a/lis/params/gfrac/SPORTDaily/read_gvf_binary_modis.cc +++ b/lis/params/gfrac/SPORTDaily/read_gvf_binary_modis.cc @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/SPORTDaily/setup_SPORTgfrac.F90 b/lis/params/gfrac/SPORTDaily/setup_SPORTgfrac.F90 index ce3f5ba7e..db9e72a53 100644 --- a/lis/params/gfrac/SPORTDaily/setup_SPORTgfrac.F90 +++ b/lis/params/gfrac/SPORTDaily/setup_SPORTgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/VIIRSgfracMod.F90 b/lis/params/gfrac/VIIRSDaily/VIIRSgfracMod.F90 index 0294b1798..30f6be38b 100644 --- a/lis/params/gfrac/VIIRSDaily/VIIRSgfracMod.F90 +++ b/lis/params/gfrac/VIIRSDaily/VIIRSgfracMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/cppfunviirs.h b/lis/params/gfrac/VIIRSDaily/cppfunviirs.h index 52fd850e0..f90a4be3e 100644 --- a/lis/params/gfrac/VIIRSDaily/cppfunviirs.h +++ b/lis/params/gfrac/VIIRSDaily/cppfunviirs.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/gvf_binary_reader_viirs.h b/lis/params/gfrac/VIIRSDaily/gvf_binary_reader_viirs.h index c5f56d12d..b0f932f95 100644 --- a/lis/params/gfrac/VIIRSDaily/gvf_binary_reader_viirs.h +++ b/lis/params/gfrac/VIIRSDaily/gvf_binary_reader_viirs.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/read_VIIRSgfrac.F90 b/lis/params/gfrac/VIIRSDaily/read_VIIRSgfrac.F90 index 52328004e..0d85342ea 100644 --- a/lis/params/gfrac/VIIRSDaily/read_VIIRSgfrac.F90 +++ b/lis/params/gfrac/VIIRSDaily/read_VIIRSgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/read_gvf_binary_viirs.cc b/lis/params/gfrac/VIIRSDaily/read_gvf_binary_viirs.cc index 779371c06..cc7762f08 100644 --- a/lis/params/gfrac/VIIRSDaily/read_gvf_binary_viirs.cc +++ b/lis/params/gfrac/VIIRSDaily/read_gvf_binary_viirs.cc @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/gfrac/VIIRSDaily/setup_VIIRSgfrac.F90 b/lis/params/gfrac/VIIRSDaily/setup_VIIRSgfrac.F90 index 29b0c9420..f58c9950c 100644 --- a/lis/params/gfrac/VIIRSDaily/setup_VIIRSgfrac.F90 +++ b/lis/params/gfrac/VIIRSDaily/setup_VIIRSgfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/0Intro_lai.txt b/lis/params/lai/0Intro_lai.txt index 6c57641d2..e4acd1190 100644 --- a/lis/params/lai/0Intro_lai.txt +++ b/lis/params/lai/0Intro_lai.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/ALMIPII/read_ALMIPIIlai.F90 b/lis/params/lai/ALMIPII/read_ALMIPIIlai.F90 index 324477888..e049f28d3 100644 --- a/lis/params/lai/ALMIPII/read_ALMIPIIlai.F90 +++ b/lis/params/lai/ALMIPII/read_ALMIPIIlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/ALMIPII/setup_ALMIPIIlai.F90 b/lis/params/lai/ALMIPII/setup_ALMIPIIlai.F90 index a7110710f..88b94079a 100644 --- a/lis/params/lai/ALMIPII/setup_ALMIPIIlai.F90 +++ b/lis/params/lai/ALMIPII/setup_ALMIPIIlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS/read_MODISlai.F90 b/lis/params/lai/MODIS/read_MODISlai.F90 index 1c4c7a25b..e8b60a2d8 100644 --- a/lis/params/lai/MODIS/read_MODISlai.F90 +++ b/lis/params/lai/MODIS/read_MODISlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS/read_MODISsai.F90 b/lis/params/lai/MODIS/read_MODISsai.F90 index 3247d73f9..c8b3db4b9 100644 --- a/lis/params/lai/MODIS/read_MODISsai.F90 +++ b/lis/params/lai/MODIS/read_MODISsai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS/setup_MODISlai.F90 b/lis/params/lai/MODIS/setup_MODISlai.F90 index 0fcecbb42..41f6d28c7 100644 --- a/lis/params/lai/MODIS/setup_MODISlai.F90 +++ b/lis/params/lai/MODIS/setup_MODISlai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS_RT/read_MODIS_RT_lai.F90 b/lis/params/lai/MODIS_RT/read_MODIS_RT_lai.F90 index b6fb92d96..494995fbd 100644 --- a/lis/params/lai/MODIS_RT/read_MODIS_RT_lai.F90 +++ b/lis/params/lai/MODIS_RT/read_MODIS_RT_lai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS_RT/read_MODIS_RT_sai.F90 b/lis/params/lai/MODIS_RT/read_MODIS_RT_sai.F90 index 43006f8e4..e681e6895 100644 --- a/lis/params/lai/MODIS_RT/read_MODIS_RT_sai.F90 +++ b/lis/params/lai/MODIS_RT/read_MODIS_RT_sai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/lai/MODIS_RT/setup_MODIS_RT_lai.F90 b/lis/params/lai/MODIS_RT/setup_MODIS_RT_lai.F90 index 9e5b76669..22c1f42c8 100644 --- a/lis/params/lai/MODIS_RT/setup_MODIS_RT_lai.F90 +++ b/lis/params/lai/MODIS_RT/setup_MODIS_RT_lai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/roughness/ALMIPII/read_ALMIPIIroughness.F90 b/lis/params/roughness/ALMIPII/read_ALMIPIIroughness.F90 index eeefa2796..bc545a174 100644 --- a/lis/params/roughness/ALMIPII/read_ALMIPIIroughness.F90 +++ b/lis/params/roughness/ALMIPII/read_ALMIPIIroughness.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/params/roughness/ALMIPII/setup_ALMIPIIroughness.F90 b/lis/params/roughness/ALMIPII/setup_ALMIPIIroughness.F90 index ddd6669ac..b81a87bbb 100644 --- a/lis/params/roughness/ALMIPII/setup_ALMIPIIroughness.F90 +++ b/lis/params/roughness/ALMIPII/setup_ALMIPIIroughness.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/0Intro_plugins.txt b/lis/plugins/0Intro_plugins.txt index 4446d3a26..2214ad1b6 100644 --- a/lis/plugins/0Intro_plugins.txt +++ b/lis/plugins/0Intro_plugins.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_DAobs_pluginMod.F90 b/lis/plugins/LIS_DAobs_pluginMod.F90 index 680b12dc3..b369b69fb 100644 --- a/lis/plugins/LIS_DAobs_pluginMod.F90 +++ b/lis/plugins/LIS_DAobs_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_ObjFunc_pluginMod.F90 b/lis/plugins/LIS_ObjFunc_pluginMod.F90 index 65100d504..3248eea61 100644 --- a/lis/plugins/LIS_ObjFunc_pluginMod.F90 +++ b/lis/plugins/LIS_ObjFunc_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_PEobs_pluginMod.F90 b/lis/plugins/LIS_PEobs_pluginMod.F90 index 4e92b2096..ce38d46e0 100644 --- a/lis/plugins/LIS_PEobs_pluginMod.F90 +++ b/lis/plugins/LIS_PEobs_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_RTM_pluginMod.F90 b/lis/plugins/LIS_RTM_pluginMod.F90 index d7fcff1d7..b5ffd3d57 100644 --- a/lis/plugins/LIS_RTM_pluginMod.F90 +++ b/lis/plugins/LIS_RTM_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_RTMoptue_pluginMod.F90 b/lis/plugins/LIS_RTMoptue_pluginMod.F90 index a8fc3b1f8..f8997a12d 100644 --- a/lis/plugins/LIS_RTMoptue_pluginMod.F90 +++ b/lis/plugins/LIS_RTMoptue_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_biasEstimation_pluginMod.F90 b/lis/plugins/LIS_biasEstimation_pluginMod.F90 index 471e0b03f..e5fed519f 100644 --- a/lis/plugins/LIS_biasEstimation_pluginMod.F90 +++ b/lis/plugins/LIS_biasEstimation_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_dataassim_pluginMod.F90 b/lis/plugins/LIS_dataassim_pluginMod.F90 index ae5ab3d6e..c1c73423e 100644 --- a/lis/plugins/LIS_dataassim_pluginMod.F90 +++ b/lis/plugins/LIS_dataassim_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_forecastAlg_pluginMod.F90 b/lis/plugins/LIS_forecastAlg_pluginMod.F90 index a8a09cc03..cbe0a3a7c 100644 --- a/lis/plugins/LIS_forecastAlg_pluginMod.F90 +++ b/lis/plugins/LIS_forecastAlg_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_glaciermodel_pluginMod.F90 b/lis/plugins/LIS_glaciermodel_pluginMod.F90 index a82d645d4..e239a4b8c 100644 --- a/lis/plugins/LIS_glaciermodel_pluginMod.F90 +++ b/lis/plugins/LIS_glaciermodel_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_glacierrouting_pluginMod.F90 b/lis/plugins/LIS_glacierrouting_pluginMod.F90 index 9ae380533..f90d20699 100644 --- a/lis/plugins/LIS_glacierrouting_pluginMod.F90 +++ b/lis/plugins/LIS_glacierrouting_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_irrigationmodel_pluginMod.F90 b/lis/plugins/LIS_irrigationmodel_pluginMod.F90 index ea4206662..0adcf510a 100644 --- a/lis/plugins/LIS_irrigationmodel_pluginMod.F90 +++ b/lis/plugins/LIS_irrigationmodel_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lakemodel_pluginMod.F90 b/lis/plugins/LIS_lakemodel_pluginMod.F90 index b9c00728b..5a50b525f 100644 --- a/lis/plugins/LIS_lakemodel_pluginMod.F90 +++ b/lis/plugins/LIS_lakemodel_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_landslidemodel_pluginMod.F90 b/lis/plugins/LIS_landslidemodel_pluginMod.F90 index 102d3df13..12ceac307 100644 --- a/lis/plugins/LIS_landslidemodel_pluginMod.F90 +++ b/lis/plugins/LIS_landslidemodel_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsm_pluginMod.F90 b/lis/plugins/LIS_lsm_pluginMod.F90 index ef2bcea66..a5c2fdda5 100644 --- a/lis/plugins/LIS_lsm_pluginMod.F90 +++ b/lis/plugins/LIS_lsm_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmcpl_pluginMod.F90 b/lis/plugins/LIS_lsmcpl_pluginMod.F90 index b363ad517..124498659 100644 --- a/lis/plugins/LIS_lsmcpl_pluginMod.F90 +++ b/lis/plugins/LIS_lsmcpl_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmda_pluginMod.F90 b/lis/plugins/LIS_lsmda_pluginMod.F90 index 98e892393..b146699a1 100644 --- a/lis/plugins/LIS_lsmda_pluginMod.F90 +++ b/lis/plugins/LIS_lsmda_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmirrigation_pluginMod.F90 b/lis/plugins/LIS_lsmirrigation_pluginMod.F90 index 09f8e5900..df9422e95 100644 --- a/lis/plugins/LIS_lsmirrigation_pluginMod.F90 +++ b/lis/plugins/LIS_lsmirrigation_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmoptue_pluginMod.F90 b/lis/plugins/LIS_lsmoptue_pluginMod.F90 index 498248ca2..ecdb8b252 100644 --- a/lis/plugins/LIS_lsmoptue_pluginMod.F90 +++ b/lis/plugins/LIS_lsmoptue_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmrouting_pluginMod.F90 b/lis/plugins/LIS_lsmrouting_pluginMod.F90 index e6fa53b61..3055ab43b 100644 --- a/lis/plugins/LIS_lsmrouting_pluginMod.F90 +++ b/lis/plugins/LIS_lsmrouting_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_lsmrtm_pluginMod.F90 b/lis/plugins/LIS_lsmrtm_pluginMod.F90 index 421c62db6..cabe3d512 100644 --- a/lis/plugins/LIS_lsmrtm_pluginMod.F90 +++ b/lis/plugins/LIS_lsmrtm_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_metforcing_pluginMod.F90 b/lis/plugins/LIS_metforcing_pluginMod.F90 index a4f06a4cd..920bcc673 100644 --- a/lis/plugins/LIS_metforcing_pluginMod.F90 +++ b/lis/plugins/LIS_metforcing_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_openwatermodel_pluginMod.F90 b/lis/plugins/LIS_openwatermodel_pluginMod.F90 index b642dd3d0..0b69a954b 100644 --- a/lis/plugins/LIS_openwatermodel_pluginMod.F90 +++ b/lis/plugins/LIS_openwatermodel_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_optUEAlgorithm_pluginMod.F90 b/lis/plugins/LIS_optUEAlgorithm_pluginMod.F90 index d6cd0a5ca..30eef409b 100644 --- a/lis/plugins/LIS_optUEAlgorithm_pluginMod.F90 +++ b/lis/plugins/LIS_optUEAlgorithm_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_param_pluginMod.F90 b/lis/plugins/LIS_param_pluginMod.F90 index 520cf05b6..4833ab7aa 100644 --- a/lis/plugins/LIS_param_pluginMod.F90 +++ b/lis/plugins/LIS_param_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_perturb_pluginMod.F90 b/lis/plugins/LIS_perturb_pluginMod.F90 index 1771672ef..d7633324f 100644 --- a/lis/plugins/LIS_perturb_pluginMod.F90 +++ b/lis/plugins/LIS_perturb_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_pluginIndices.F90 b/lis/plugins/LIS_pluginIndices.F90 index 76536bbc3..9bf21bc37 100644 --- a/lis/plugins/LIS_pluginIndices.F90 +++ b/lis/plugins/LIS_pluginIndices.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_routing_pluginMod.F90 b/lis/plugins/LIS_routing_pluginMod.F90 index 54359ca5f..4f90ba619 100644 --- a/lis/plugins/LIS_routing_pluginMod.F90 +++ b/lis/plugins/LIS_routing_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_routingda_pluginMod.F90 b/lis/plugins/LIS_routingda_pluginMod.F90 index cbca913f3..ed48987a0 100644 --- a/lis/plugins/LIS_routingda_pluginMod.F90 +++ b/lis/plugins/LIS_routingda_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_runmode_pluginMod.F90 b/lis/plugins/LIS_runmode_pluginMod.F90 index 4b229f977..92abc766b 100644 --- a/lis/plugins/LIS_runmode_pluginMod.F90 +++ b/lis/plugins/LIS_runmode_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_runoffdata_pluginMod.F90 b/lis/plugins/LIS_runoffdata_pluginMod.F90 index 2edfe697b..d9577327a 100644 --- a/lis/plugins/LIS_runoffdata_pluginMod.F90 +++ b/lis/plugins/LIS_runoffdata_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/plugins/LIS_sublsm_pluginMod.F90 b/lis/plugins/LIS_sublsm_pluginMod.F90 index 3b3cbc2cc..2b866f83c 100644 --- a/lis/plugins/LIS_sublsm_pluginMod.F90 +++ b/lis/plugins/LIS_sublsm_pluginMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_evapMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_evapMod.F90 index 0d2b165e9..6a8bf4d0a 100755 --- a/lis/routing/HYMAP2_router/HYMAP2_evapMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_evapMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_initMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_initMod.F90 index 0591ccaa2..771c93005 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_initMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_initMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_model.F90 b/lis/routing/HYMAP2_router/HYMAP2_model.F90 index cacc64bec..b194ecad3 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_model.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_model.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_modelMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_modelMod.F90 index 38f55e2a5..c5d1ce205 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_modelMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_modelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 b/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 index 8f47eb4e6..3ae2700e3 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_model_core.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_resopMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_resopMod.F90 index 618240f7a..4148197e0 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_resopMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_resopMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routingMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_routingMod.F90 index f83fd24ac..c75b75b57 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_routingMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_output.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_output.F90 index 5a60fc0dd..89e41d046 100755 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_output.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_output.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_readrst.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_readrst.F90 index 32427dd20..855787704 100755 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_readrst.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_reset.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_reset.F90 index e94a18cdc..bed8246dd 100755 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_reset.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 index a091240c0..072bb8d59 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_routing_writerst.F90 b/lis/routing/HYMAP2_router/HYMAP2_routing_writerst.F90 index 70e1935e8..9896c940f 100644 --- a/lis/routing/HYMAP2_router/HYMAP2_routing_writerst.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_routing_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/HYMAP2_urbanMod.F90 b/lis/routing/HYMAP2_router/HYMAP2_urbanMod.F90 index a08bfa8e4..ac91cf4ee 100755 --- a/lis/routing/HYMAP2_router/HYMAP2_urbanMod.F90 +++ b/lis/routing/HYMAP2_router/HYMAP2_urbanMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_daWL_Mod.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_daWL_Mod.F90 index 365b61ae5..096959051 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_daWL_Mod.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_daWL_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_descale_WL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_descale_WL.F90 index e3d0e0972..75a572ffc 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_descale_WL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_descale_WL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getStateSpaceSize.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getStateSpaceSize.F90 index cf76cacab..762c7152c 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getStateSpaceSize.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getStateSpaceSize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWL.F90 index bb720e08e..8843a3f07 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWLpred.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWLpred.F90 index 527384d22..fb29e50de 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWLpred.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_getWLpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_qcWL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_qcWL.F90 index 80e0d393b..5f08b3f14 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_qcWL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_qcWL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_qc_WLobs.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_qc_WLobs.F90 index ba407b972..a9fca41cd 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_qc_WLobs.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_qc_WLobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_scale_WL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_scale_WL.F90 index aef5039df..077ae1d33 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_scale_WL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_scale_WL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_setPertStates.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_setPertStates.F90 index d361191e3..539f5bcf2 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_setPertStates.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_setPertStates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_setWL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_setWL.F90 index b391d3ce2..96a445d82 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_setWL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_setWL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_updateWL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_updateWL.F90 index 101aa12cc..59316b91f 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_updateWL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_updateWL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/da_WL/HYMAP2_write_WL.F90 b/lis/routing/HYMAP2_router/da_WL/HYMAP2_write_WL.F90 index 09716e2e6..b7dbe96c3 100644 --- a/lis/routing/HYMAP2_router/da_WL/HYMAP2_write_WL.F90 +++ b/lis/routing/HYMAP2_router/da_WL/HYMAP2_write_WL.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 index d34066b0b..134f34452 100755 --- a/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 index 7a481b39d..e7f214781 100755 --- a/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 index d6556ca2c..a9138d071 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 index c7c7d3048..0a8dad14c 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 index 44e74a1dc..ee5c4afeb 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 index 2a901f4f5..781c87517 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 index aadc11f54..a7741fbd6 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 index 05d106863..a298e2acd 100755 --- a/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/LISoutput/LISrunoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/LISoutput/LISrunoffdataMod.F90 index 0b31aea54..602cb0922 100755 --- a/lis/routing/HYMAP2_router/runoffdata/LISoutput/LISrunoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/LISoutput/LISrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/LISoutput/readLISrunoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/LISoutput/readLISrunoffdata.F90 index 6ecfadfa2..c31863dce 100755 --- a/lis/routing/HYMAP2_router/runoffdata/LISoutput/readLISrunoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/LISoutput/readLISrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 index c1ca594f9..9ea8a50a4 100755 --- a/lis/routing/HYMAP2_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 index df66824d6..d43d0d4f9 100755 --- a/lis/routing/HYMAP2_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 b/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 index 979e0b6ec..20785c75a 100755 --- a/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 b/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 index 61bc6e7ac..ceb72b61d 100755 --- a/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 +++ b/lis/routing/HYMAP2_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_initMod.F90 b/lis/routing/HYMAP_router/HYMAP_initMod.F90 index b7dfab840..76279603d 100755 --- a/lis/routing/HYMAP_router/HYMAP_initMod.F90 +++ b/lis/routing/HYMAP_router/HYMAP_initMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_modelMod.F90 b/lis/routing/HYMAP_router/HYMAP_modelMod.F90 index 99b18a52d..89ce63751 100755 --- a/lis/routing/HYMAP_router/HYMAP_modelMod.F90 +++ b/lis/routing/HYMAP_router/HYMAP_modelMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_routingMod.F90 b/lis/routing/HYMAP_router/HYMAP_routingMod.F90 index 955c485e6..92dfb4e45 100755 --- a/lis/routing/HYMAP_router/HYMAP_routingMod.F90 +++ b/lis/routing/HYMAP_router/HYMAP_routingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_routing_output.F90 b/lis/routing/HYMAP_router/HYMAP_routing_output.F90 index 6eca06ede..fde1fe2b4 100755 --- a/lis/routing/HYMAP_router/HYMAP_routing_output.F90 +++ b/lis/routing/HYMAP_router/HYMAP_routing_output.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_routing_readrst.F90 b/lis/routing/HYMAP_router/HYMAP_routing_readrst.F90 index 6fe27b8d9..a9a4cc75f 100755 --- a/lis/routing/HYMAP_router/HYMAP_routing_readrst.F90 +++ b/lis/routing/HYMAP_router/HYMAP_routing_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_routing_run.F90 b/lis/routing/HYMAP_router/HYMAP_routing_run.F90 index 2c713e9cf..ab2cf71f6 100755 --- a/lis/routing/HYMAP_router/HYMAP_routing_run.F90 +++ b/lis/routing/HYMAP_router/HYMAP_routing_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/HYMAP_routing_writerst.F90 b/lis/routing/HYMAP_router/HYMAP_routing_writerst.F90 index 22e10ffb1..05b9c351a 100755 --- a/lis/routing/HYMAP_router/HYMAP_routing_writerst.F90 +++ b/lis/routing/HYMAP_router/HYMAP_routing_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/model.F90 b/lis/routing/HYMAP_router/model.F90 index 35be276da..5cbeed5c3 100755 --- a/lis/routing/HYMAP_router/model.F90 +++ b/lis/routing/HYMAP_router/model.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 index d34066b0b..134f34452 100755 --- a/lis/routing/HYMAP_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/ERAILanddata/ERAILandrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 index 7a481b39d..e7f214781 100755 --- a/lis/routing/HYMAP_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/ERAILanddata/readERAILandrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 index d6556ca2c..a9138d071 100755 --- a/lis/routing/HYMAP_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GLDAS1data/GLDAS1runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 index f0888156e..f51b53336 100755 --- a/lis/routing/HYMAP_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GLDAS1data/readGLDAS1runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 index aca1cdd09..2473bd319 100755 --- a/lis/routing/HYMAP_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GLDAS2data/GLDAS2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 index a0fa31e94..eea5ed92f 100755 --- a/lis/routing/HYMAP_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GLDAS2data/readGLDAS2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 index df59062d7..986d8f034 100755 --- a/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/GWBMIPrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 index 2da7c2711..377dfa8fb 100755 --- a/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/GWBMIPdata/readGWBMIPrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/LISoutput/LISrunoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/LISoutput/LISrunoffdataMod.F90 index 9e62623df..5c9111d73 100755 --- a/lis/routing/HYMAP_router/runoffdata/LISoutput/LISrunoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/LISoutput/LISrunoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/LISoutput/readLISrunoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/LISoutput/readLISrunoffdata.F90 index 8a9ad6280..e47eff77d 100755 --- a/lis/routing/HYMAP_router/runoffdata/LISoutput/readLISrunoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/LISoutput/readLISrunoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 index c1ca594f9..9ea8a50a4 100755 --- a/lis/routing/HYMAP_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/MERRA2data/MERRA2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 index df66824d6..d43d0d4f9 100755 --- a/lis/routing/HYMAP_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/MERRA2data/readMERRA2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 b/lis/routing/HYMAP_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 index 979e0b6ec..20785c75a 100755 --- a/lis/routing/HYMAP_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 +++ b/lis/routing/HYMAP_router/runoffdata/NLDAS2data/NLDAS2runoffdataMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/HYMAP_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 b/lis/routing/HYMAP_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 index 4cb8a7155..948a3ef20 100755 --- a/lis/routing/HYMAP_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 +++ b/lis/routing/HYMAP_router/runoffdata/NLDAS2data/readNLDAS2runoffdata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/NLDAS_router/NLDAS_routingMod.F90 b/lis/routing/NLDAS_router/NLDAS_routingMod.F90 index 30028d796..11e4c24ea 100644 --- a/lis/routing/NLDAS_router/NLDAS_routingMod.F90 +++ b/lis/routing/NLDAS_router/NLDAS_routingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/NLDAS_router/NLDAS_routing_output.F90 b/lis/routing/NLDAS_router/NLDAS_routing_output.F90 index 7b39390a9..e11412fdf 100644 --- a/lis/routing/NLDAS_router/NLDAS_routing_output.F90 +++ b/lis/routing/NLDAS_router/NLDAS_routing_output.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/NLDAS_router/NLDAS_routing_readrst.F90 b/lis/routing/NLDAS_router/NLDAS_routing_readrst.F90 index 9ad44ad95..b78ba9b8d 100644 --- a/lis/routing/NLDAS_router/NLDAS_routing_readrst.F90 +++ b/lis/routing/NLDAS_router/NLDAS_routing_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/NLDAS_router/NLDAS_routing_run.F90 b/lis/routing/NLDAS_router/NLDAS_routing_run.F90 index dbfbdbcb0..6b75c1d5c 100644 --- a/lis/routing/NLDAS_router/NLDAS_routing_run.F90 +++ b/lis/routing/NLDAS_router/NLDAS_routing_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/NLDAS_router/NLDAS_routing_writerst.F90 b/lis/routing/NLDAS_router/NLDAS_routing_writerst.F90 index aeb95e285..92e80eb44 100644 --- a/lis/routing/NLDAS_router/NLDAS_routing_writerst.F90 +++ b/lis/routing/NLDAS_router/NLDAS_routing_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_check_domain_size.F90 b/lis/routing/RAPID_router/RAPID_check_domain_size.F90 index eebc19127..09863d6be 100644 --- a/lis/routing/RAPID_router/RAPID_check_domain_size.F90 +++ b/lis/routing/RAPID_router/RAPID_check_domain_size.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_model_main.F90 b/lis/routing/RAPID_router/RAPID_model_main.F90 index 2297aafba..d41262136 100644 --- a/lis/routing/RAPID_router/RAPID_model_main.F90 +++ b/lis/routing/RAPID_router/RAPID_model_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_routingMod.F90 b/lis/routing/RAPID_router/RAPID_routingMod.F90 index 4fc8ecb72..171e9d25b 100644 --- a/lis/routing/RAPID_router/RAPID_routingMod.F90 +++ b/lis/routing/RAPID_router/RAPID_routingMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_routing_output.F90 b/lis/routing/RAPID_router/RAPID_routing_output.F90 index 70d8ab01e..d97fdfb2a 100644 --- a/lis/routing/RAPID_router/RAPID_routing_output.F90 +++ b/lis/routing/RAPID_router/RAPID_routing_output.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_routing_readrst.F90 b/lis/routing/RAPID_router/RAPID_routing_readrst.F90 index 8fa30cb85..86253fa24 100644 --- a/lis/routing/RAPID_router/RAPID_routing_readrst.F90 +++ b/lis/routing/RAPID_router/RAPID_routing_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_routing_run.F90 b/lis/routing/RAPID_router/RAPID_routing_run.F90 index b1a57cead..65fc7686f 100644 --- a/lis/routing/RAPID_router/RAPID_routing_run.F90 +++ b/lis/routing/RAPID_router/RAPID_routing_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/routing/RAPID_router/RAPID_routing_writerst.F90 b/lis/routing/RAPID_router/RAPID_routing_writerst.F90 index e6cef6b76..925a3aced 100644 --- a/lis/routing/RAPID_router/RAPID_routing_writerst.F90 +++ b/lis/routing/RAPID_router/RAPID_routing_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM/CRTM_handlerMod.F90 b/lis/rtms/CRTM/CRTM_handlerMod.F90 index 2a88a9c6d..c9e84d89a 100644 --- a/lis/rtms/CRTM/CRTM_handlerMod.F90 +++ b/lis/rtms/CRTM/CRTM_handlerMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM/readCRTMcrd.F90 b/lis/rtms/CRTM/readCRTMcrd.F90 index 39e3ad35a..a346fccbd 100644 --- a/lis/rtms/CRTM/readCRTMcrd.F90 +++ b/lis/rtms/CRTM/readCRTMcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2/CRTM2_handlerMod.F90 b/lis/rtms/CRTM2/CRTM2_handlerMod.F90 index 0d15c46b4..330eb7459 100644 --- a/lis/rtms/CRTM2/CRTM2_handlerMod.F90 +++ b/lis/rtms/CRTM2/CRTM2_handlerMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2/readCRTM2crd.F90 b/lis/rtms/CRTM2/readCRTM2crd.F90 index 50effa8da..6a7e9ade5 100644 --- a/lis/rtms/CRTM2/readCRTM2crd.F90 +++ b/lis/rtms/CRTM2/readCRTM2crd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/CRTM2_EMMod.F90 b/lis/rtms/CRTM2EM/CRTM2_EMMod.F90 index 3c6be200c..d9749dec3 100644 --- a/lis/rtms/CRTM2EM/CRTM2_EMMod.F90 +++ b/lis/rtms/CRTM2EM/CRTM2_EMMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/CRTM2EM_peMod.F90 b/lis/rtms/CRTM2EM/pe/CRTM2EM_peMod.F90 index 01d49f011..c92750d2f 100644 --- a/lis/rtms/CRTM2EM/pe/CRTM2EM_peMod.F90 +++ b/lis/rtms/CRTM2EM/pe/CRTM2EM_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/CRTM2EM_set_pedecvars.F90 b/lis/rtms/CRTM2EM/pe/CRTM2EM_set_pedecvars.F90 index ea3323169..20ac2533a 100644 --- a/lis/rtms/CRTM2EM/pe/CRTM2EM_set_pedecvars.F90 +++ b/lis/rtms/CRTM2EM/pe/CRTM2EM_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_getpeobspred_AMSRE_SR.F90 b/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_getpeobspred_AMSRE_SR.F90 index 94ad1c395..d2da89946 100644 --- a/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_getpeobspred_AMSRE_SR.F90 +++ b/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_getpeobspred_AMSRE_SR.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_setupobspred_AMSRE_SR.F90 b/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_setupobspred_AMSRE_SR.F90 index 92346d77e..991562c5b 100755 --- a/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_setupobspred_AMSRE_SR.F90 +++ b/lis/rtms/CRTM2EM/pe/obspred/AMSRE_SR/CRTM2EM_setupobspred_AMSRE_SR.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS.F90 b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS.F90 index fb445ce1e..96202fd0f 100644 --- a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS.F90 +++ b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS_MPDI.F90 b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS_MPDI.F90 index f392e3d46..3a9662a2d 100644 --- a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS_MPDI.F90 +++ b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_getpeobspred_CNRS_MPDI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_setupobspred_CNRS.F90 b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_setupobspred_CNRS.F90 index 848f59e8b..b840063d5 100644 --- a/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_setupobspred_CNRS.F90 +++ b/lis/rtms/CRTM2EM/pe/obspred/CNRS/CRTM2EM_setupobspred_CNRS.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/CRTM2EM/readCRTM2EMcrd.F90 b/lis/rtms/CRTM2EM/readCRTM2EMcrd.F90 index 07244d868..152ae4b43 100644 --- a/lis/rtms/CRTM2EM/readCRTM2EMcrd.F90 +++ b/lis/rtms/CRTM2EM/readCRTM2EMcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/CMEM3_Mod.F90 b/lis/rtms/LIS-CMEM3/CMEM3_Mod.F90 index 91864eecc..1db477379 100644 --- a/lis/rtms/LIS-CMEM3/CMEM3_Mod.F90 +++ b/lis/rtms/LIS-CMEM3/CMEM3_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/pe/CMEM3_param_reset.F90 b/lis/rtms/LIS-CMEM3/pe/CMEM3_param_reset.F90 index 91800d175..cec21043d 100755 --- a/lis/rtms/LIS-CMEM3/pe/CMEM3_param_reset.F90 +++ b/lis/rtms/LIS-CMEM3/pe/CMEM3_param_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/pe/CMEM3_peMod.F90 b/lis/rtms/LIS-CMEM3/pe/CMEM3_peMod.F90 index 959f889c1..377bb1199 100644 --- a/lis/rtms/LIS-CMEM3/pe/CMEM3_peMod.F90 +++ b/lis/rtms/LIS-CMEM3/pe/CMEM3_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/pe/CMEM3_set_pedecvars.F90 b/lis/rtms/LIS-CMEM3/pe/CMEM3_set_pedecvars.F90 index b4feed9ef..cac9bf2ee 100644 --- a/lis/rtms/LIS-CMEM3/pe/CMEM3_set_pedecvars.F90 +++ b/lis/rtms/LIS-CMEM3/pe/CMEM3_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_getpeobspred_AMSRE_SR.F90 b/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_getpeobspred_AMSRE_SR.F90 index c069a8d56..060fa5aa3 100644 --- a/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_getpeobspred_AMSRE_SR.F90 +++ b/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_getpeobspred_AMSRE_SR.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_setupobspred_AMSRE_SR.F90 b/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_setupobspred_AMSRE_SR.F90 index f64af3361..222b85d04 100755 --- a/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_setupobspred_AMSRE_SR.F90 +++ b/lis/rtms/LIS-CMEM3/pe/obspred/AMSRE_SR/CMEM3_setupobspred_AMSRE_SR.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/LIS-CMEM3/readCMEM3crd.F90 b/lis/rtms/LIS-CMEM3/readCMEM3crd.F90 index ae800de26..5310fbeb8 100644 --- a/lis/rtms/LIS-CMEM3/readCMEM3crd.F90 +++ b/lis/rtms/LIS-CMEM3/readCMEM3crd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/rtms/TauOmegaRTM/TauOmegaRTM_Mod.F90 b/lis/rtms/TauOmegaRTM/TauOmegaRTM_Mod.F90 index ee7b217cc..f029d700e 100644 --- a/lis/rtms/TauOmegaRTM/TauOmegaRTM_Mod.F90 +++ b/lis/rtms/TauOmegaRTM/TauOmegaRTM_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/0Intro_runmodes.txt b/lis/runmodes/0Intro_runmodes.txt index a3546ef6a..1f5046bb5 100644 --- a/lis/runmodes/0Intro_runmodes.txt +++ b/lis/runmodes/0Intro_runmodes.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/RTMforward/RTMforward_runMod.F90 b/lis/runmodes/RTMforward/RTMforward_runMod.F90 index f2517c220..63268b10d 100644 --- a/lis/runmodes/RTMforward/RTMforward_runMod.F90 +++ b/lis/runmodes/RTMforward/RTMforward_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/agrmetmode/agrmet_runMod.F90 b/lis/runmodes/agrmetmode/agrmet_runMod.F90 index 02f6c77d4..47874598a 100644 --- a/lis/runmodes/agrmetmode/agrmet_runMod.F90 +++ b/lis/runmodes/agrmetmode/agrmet_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/forecast/forecast_runMod.F90 b/lis/runmodes/forecast/forecast_runMod.F90 index 10e0b3b35..ce9f579ee 100644 --- a/lis/runmodes/forecast/forecast_runMod.F90 +++ b/lis/runmodes/forecast/forecast_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/gce_cpl_mode/lis_gce_init.F90 b/lis/runmodes/gce_cpl_mode/lis_gce_init.F90 index 2b26cf435..2b444cd3b 100644 --- a/lis/runmodes/gce_cpl_mode/lis_gce_init.F90 +++ b/lis/runmodes/gce_cpl_mode/lis_gce_init.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/gce_cpl_mode/lis_gce_run.F90 b/lis/runmodes/gce_cpl_mode/lis_gce_run.F90 index 920faa9a1..75b5b6a92 100644 --- a/lis/runmodes/gce_cpl_mode/lis_gce_run.F90 +++ b/lis/runmodes/gce_cpl_mode/lis_gce_run.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/gce_cpl_mode/lisgceGridCompMod.F90 b/lis/runmodes/gce_cpl_mode/lisgceGridCompMod.F90 index 8c90e654b..30ceaa29b 100644 --- a/lis/runmodes/gce_cpl_mode/lisgceGridCompMod.F90 +++ b/lis/runmodes/gce_cpl_mode/lisgceGridCompMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/gce_cpl_mode/lisgceexport_module.F90 b/lis/runmodes/gce_cpl_mode/lisgceexport_module.F90 index e37819e83..f042cc6e1 100644 --- a/lis/runmodes/gce_cpl_mode/lisgceexport_module.F90 +++ b/lis/runmodes/gce_cpl_mode/lisgceexport_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/gce_cpl_mode/lisgceimport_module.F90 b/lis/runmodes/gce_cpl_mode/lisgceimport_module.F90 index 045f45977..38d8f207b 100644 --- a/lis/runmodes/gce_cpl_mode/lisgceimport_module.F90 +++ b/lis/runmodes/gce_cpl_mode/lisgceimport_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/landslide_optUE/landslideOptUE_runMod.F90 b/lis/runmodes/landslide_optUE/landslideOptUE_runMod.F90 index c470931d8..2de20cc7a 100644 --- a/lis/runmodes/landslide_optUE/landslideOptUE_runMod.F90 +++ b/lis/runmodes/landslide_optUE/landslideOptUE_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/nuopc_cpl_mode/LIS_ESMF_Extensions.F90 b/lis/runmodes/nuopc_cpl_mode/LIS_ESMF_Extensions.F90 index 417e636d2..1fe8d4f56 100644 --- a/lis/runmodes/nuopc_cpl_mode/LIS_ESMF_Extensions.F90 +++ b/lis/runmodes/nuopc_cpl_mode/LIS_ESMF_Extensions.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Cap.F90 b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Cap.F90 index d9f1e56e2..171ec96a9 100644 --- a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Cap.F90 +++ b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Cap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_DataCopy.F90 b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_DataCopy.F90 index 6392a3085..d0ba2546a 100644 --- a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_DataCopy.F90 +++ b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_DataCopy.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Gluecode.F90 b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Gluecode.F90 index 7c24c7959..09d969d93 100644 --- a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Gluecode.F90 +++ b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Gluecode.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Macros.h b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Macros.h index ffa262514..634680f57 100644 --- a/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Macros.h +++ b/lis/runmodes/nuopc_cpl_mode/LIS_NUOPC_Macros.h @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/paramEstimation/0Intro_optUE.txt b/lis/runmodes/paramEstimation/0Intro_optUE.txt index c108510f6..f48b66c75 100644 --- a/lis/runmodes/paramEstimation/0Intro_optUE.txt +++ b/lis/runmodes/paramEstimation/0Intro_optUE.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/paramEstimation/paramEstim_runMod.F90 b/lis/runmodes/paramEstimation/paramEstim_runMod.F90 index b004ea3bc..d0c06dcc0 100755 --- a/lis/runmodes/paramEstimation/paramEstim_runMod.F90 +++ b/lis/runmodes/paramEstimation/paramEstim_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/retrospective/0Intro_retrospective.txt b/lis/runmodes/retrospective/0Intro_retrospective.txt index 61abfb373..9f2d76f8d 100644 --- a/lis/runmodes/retrospective/0Intro_retrospective.txt +++ b/lis/runmodes/retrospective/0Intro_retrospective.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/retrospective/retrospective_runMod.F90 b/lis/runmodes/retrospective/retrospective_runMod.F90 index eb4a98061..3bfebf596 100644 --- a/lis/runmodes/retrospective/retrospective_runMod.F90 +++ b/lis/runmodes/retrospective/retrospective_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/smootherDA/smootherDA_runMod.F90 b/lis/runmodes/smootherDA/smootherDA_runMod.F90 index e686c476c..7db51d70b 100755 --- a/lis/runmodes/smootherDA/smootherDA_runMod.F90 +++ b/lis/runmodes/smootherDA/smootherDA_runMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/LISWRFGridCompMod.F90 b/lis/runmodes/wrf_cpl_mode/LISWRFGridCompMod.F90 index 967cf39c9..7c54659ea 100755 --- a/lis/runmodes/wrf_cpl_mode/LISWRFGridCompMod.F90 +++ b/lis/runmodes/wrf_cpl_mode/LISWRFGridCompMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/LISWRFexport_module.F90 b/lis/runmodes/wrf_cpl_mode/LISWRFexport_module.F90 index ba1ed24dc..a001de5e9 100755 --- a/lis/runmodes/wrf_cpl_mode/LISWRFexport_module.F90 +++ b/lis/runmodes/wrf_cpl_mode/LISWRFexport_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/LISWRFimport_module.F90 b/lis/runmodes/wrf_cpl_mode/LISWRFimport_module.F90 index cbfb14e87..fb67475ee 100755 --- a/lis/runmodes/wrf_cpl_mode/LISWRFimport_module.F90 +++ b/lis/runmodes/wrf_cpl_mode/LISWRFimport_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/liswrffinalize_coupled.F90 b/lis/runmodes/wrf_cpl_mode/liswrffinalize_coupled.F90 index 0cd905db7..dc2435f43 100755 --- a/lis/runmodes/wrf_cpl_mode/liswrffinalize_coupled.F90 +++ b/lis/runmodes/wrf_cpl_mode/liswrffinalize_coupled.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/liswrfinit_coupled.F90 b/lis/runmodes/wrf_cpl_mode/liswrfinit_coupled.F90 index cad2887f7..e8a1c1f0b 100755 --- a/lis/runmodes/wrf_cpl_mode/liswrfinit_coupled.F90 +++ b/lis/runmodes/wrf_cpl_mode/liswrfinit_coupled.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/runmodes/wrf_cpl_mode/liswrfrun_coupled.F90 b/lis/runmodes/wrf_cpl_mode/liswrfrun_coupled.F90 index e76fe31d2..e2b74ac9d 100755 --- a/lis/runmodes/wrf_cpl_mode/liswrfrun_coupled.F90 +++ b/lis/runmodes/wrf_cpl_mode/liswrfrun_coupled.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/kwm_date_utilities_noahgl3911.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/kwm_date_utilities_noahgl3911.F90 index c69611756..e69c9c73a 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/kwm_date_utilities_noahgl3911.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/kwm_date_utilities_noahgl3911.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_Mod.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_Mod.F90 index 4f33951d1..1d510dc13 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_Mod.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_coldstart.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_coldstart.F90 index c2a66c775..bedb45b85 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_coldstart.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_dynsetup.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_dynsetup.F90 index a1c652734..e9129b874 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_dynsetup.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_f2t.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_f2t.F90 index e1d1fa346..42bbe6c86 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_f2t.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_finalize.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_finalize.F90 index 378c1f7a5..400366b75 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_finalize.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_main.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_main.F90 index 8bf1bda5b..993c4f26b 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_main.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_module.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_module.F90 index 16e06e36f..1ad5afad8 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_module.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readcrd.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readcrd.F90 index 5543a0881..f195fc70f 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readcrd.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readrst.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readrst.F90 index 5b0187770..5226888f8 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readrst.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_setup.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_setup.F90 index a1013afe7..94a772891 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_setup.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_writerst.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_writerst.F90 index 6a93c11eb..97a0defa3 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_writerst.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/noahmpglacier3911_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_hymap2.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_hymap2.F90 index 361a2864c..45ef9c9c6 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_mm.F90 b/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_mm.F90 index de0710673..5d8afd75e 100644 --- a/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_mm.F90 +++ b/lis/surfacemodels/glacier/noahmp.3.9.1.1/routing/noahmpglacier3911_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_Mod.F90 b/lis/surfacemodels/glacier/template/templateGL_Mod.F90 index 469f22574..73d5fbb15 100644 --- a/lis/surfacemodels/glacier/template/templateGL_Mod.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_dynsetup.F90 b/lis/surfacemodels/glacier/template/templateGL_dynsetup.F90 index 427568b8d..afff1e414 100644 --- a/lis/surfacemodels/glacier/template/templateGL_dynsetup.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_f2t.F90 b/lis/surfacemodels/glacier/template/templateGL_f2t.F90 index fbe171015..1cf3f0f60 100644 --- a/lis/surfacemodels/glacier/template/templateGL_f2t.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_finalize.F90 b/lis/surfacemodels/glacier/template/templateGL_finalize.F90 index a4b2a4c7d..2357466fc 100644 --- a/lis/surfacemodels/glacier/template/templateGL_finalize.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_getrunoffs_mm.F90 b/lis/surfacemodels/glacier/template/templateGL_getrunoffs_mm.F90 index d659569bc..12f86314c 100644 --- a/lis/surfacemodels/glacier/template/templateGL_getrunoffs_mm.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_main.F90 b/lis/surfacemodels/glacier/template/templateGL_main.F90 index 4bf9ab754..cc4c191c6 100644 --- a/lis/surfacemodels/glacier/template/templateGL_main.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_readcrd.F90 b/lis/surfacemodels/glacier/template/templateGL_readcrd.F90 index b7e6895b1..71e56f2b1 100644 --- a/lis/surfacemodels/glacier/template/templateGL_readcrd.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_readrst.F90 b/lis/surfacemodels/glacier/template/templateGL_readrst.F90 index 3b9c55d64..66e07363d 100644 --- a/lis/surfacemodels/glacier/template/templateGL_readrst.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_setup.F90 b/lis/surfacemodels/glacier/template/templateGL_setup.F90 index dc83fe544..328c02de5 100644 --- a/lis/surfacemodels/glacier/template/templateGL_setup.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/glacier/template/templateGL_writerst.F90 b/lis/surfacemodels/glacier/template/templateGL_writerst.F90 index 0bf624716..f1492196a 100644 --- a/lis/surfacemodels/glacier/template/templateGL_writerst.F90 +++ b/lis/surfacemodels/glacier/template/templateGL_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_Mod.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_Mod.F90 index 146ce4c64..2669d67bc 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_Mod.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_coldstart.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_coldstart.F90 index a5f8060b2..8dcc336e4 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_coldstart.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_dynsetup.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_dynsetup.F90 index 8d44eedb5..d9291a60c 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_dynsetup.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_f2t.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_f2t.F90 index b8143b03f..5785fbff7 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_f2t.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_finalize.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_finalize.F90 index f15c66061..15df52701 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_finalize.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_main.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_main.F90 index 381a6a485..ec7b704e8 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_main.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_module.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_module.F90 index c238d6c6e..352850154 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_module.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_readcrd.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_readcrd.F90 index 8429df107..980f63c26 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_readcrd.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_readrst.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_readrst.F90 index 2db2aa3de..756a3b1ad 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_readrst.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_setup.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_setup.F90 index 42d3945a3..9a21587c3 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_setup.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/FLake1_writerst.F90 b/lis/surfacemodels/lake/FLake.1.0/FLake1_writerst.F90 index 996204d0c..192b3465b 100644 --- a/lis/surfacemodels/lake/FLake.1.0/FLake1_writerst.F90 +++ b/lis/surfacemodels/lake/FLake.1.0/FLake1_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/lake/FLake.1.0/lis7_flake_2013.f90 b/lis/surfacemodels/lake/FLake.1.0/lis7_flake_2013.f90 index 4b8c53def..09132d48c 100755 --- a/lis/surfacemodels/lake/FLake.1.0/lis7_flake_2013.f90 +++ b/lis/surfacemodels/lake/FLake.1.0/lis7_flake_2013.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/0Intro_lsms.txt b/lis/surfacemodels/land/0Intro_lsms.txt index 028b1919d..746b6ce03 100644 --- a/lis/surfacemodels/land/0Intro_lsms.txt +++ b/lis/surfacemodels/land/0Intro_lsms.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_coldstart.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_coldstart.F90 index 8df05d4eb..c2199aba1 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_coldstart.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_dynsetup.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_dynsetup.F90 index e848166f5..6175ba00a 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_dynsetup.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_f2t.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_f2t.F90 index 79ca38d9f..057c3d768 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_f2t.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_finalize.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_finalize.F90 index 16bd6902d..bd9b8e12e 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_finalize.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_lsmMod.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_lsmMod.F90 index 3d161b356..cb63f04d2 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_lsmMod.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_main.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_main.F90 index a5d020039..61cd2a3fb 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_main.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_module.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_module.F90 index 077bb0605..764db3531 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_module.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readcrd.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readcrd.F90 index b1afb08b0..d448b693f 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readcrd.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readrst.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readrst.F90 index 39bf93076..1535fd6ed 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readrst.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_setup.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_setup.F90 index 626d99762..cc65cc616 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_setup.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_writerst.F90 b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_writerst.F90 index d482c0cf5..d4c1d28a3 100644 --- a/lis/surfacemodels/land/awral.6.0.0/AWRAL600_writerst.F90 +++ b/lis/surfacemodels/land/awral.6.0.0/AWRAL600_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/0Intro_cable.txt b/lis/surfacemodels/land/cable/0Intro_cable.txt index 47d7359b4..e07ba278a 100644 --- a/lis/surfacemodels/land/cable/0Intro_cable.txt +++ b/lis/surfacemodels/land/cable/0Intro_cable.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_coldstart.F90 b/lis/surfacemodels/land/cable/cable_coldstart.F90 index 075a8fe16..fb1ea6a59 100644 --- a/lis/surfacemodels/land/cable/cable_coldstart.F90 +++ b/lis/surfacemodels/land/cable/cable_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_driver.F90 b/lis/surfacemodels/land/cable/cable_driver.F90 index 90ab81e76..86ed72950 100644 --- a/lis/surfacemodels/land/cable/cable_driver.F90 +++ b/lis/surfacemodels/land/cable/cable_driver.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_dynsetup.F90 b/lis/surfacemodels/land/cable/cable_dynsetup.F90 index fce99d2b4..db983a4ab 100644 --- a/lis/surfacemodels/land/cable/cable_dynsetup.F90 +++ b/lis/surfacemodels/land/cable/cable_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_f2t.F90 b/lis/surfacemodels/land/cable/cable_f2t.F90 index 17180fdaa..f61ec128d 100644 --- a/lis/surfacemodels/land/cable/cable_f2t.F90 +++ b/lis/surfacemodels/land/cable/cable_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_finalize.F90 b/lis/surfacemodels/land/cable/cable_finalize.F90 index e2d88d652..902e0ee0c 100644 --- a/lis/surfacemodels/land/cable/cable_finalize.F90 +++ b/lis/surfacemodels/land/cable/cable_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_listime.F90 b/lis/surfacemodels/land/cable/cable_listime.F90 index b7e6e8604..61512fe8b 100644 --- a/lis/surfacemodels/land/cable/cable_listime.F90 +++ b/lis/surfacemodels/land/cable/cable_listime.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_lsmMod.F90 b/lis/surfacemodels/land/cable/cable_lsmMod.F90 index 8903d1e74..0020219e3 100644 --- a/lis/surfacemodels/land/cable/cable_lsmMod.F90 +++ b/lis/surfacemodels/land/cable/cable_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_module.F90 b/lis/surfacemodels/land/cable/cable_module.F90 index 90fb52256..020f28142 100644 --- a/lis/surfacemodels/land/cable/cable_module.F90 +++ b/lis/surfacemodels/land/cable/cable_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_readcrd.F90 b/lis/surfacemodels/land/cable/cable_readcrd.F90 index 1d36afe9c..a9868020b 100644 --- a/lis/surfacemodels/land/cable/cable_readcrd.F90 +++ b/lis/surfacemodels/land/cable/cable_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_readrst.F90 b/lis/surfacemodels/land/cable/cable_readrst.F90 index ed05865be..4e9263c62 100644 --- a/lis/surfacemodels/land/cable/cable_readrst.F90 +++ b/lis/surfacemodels/land/cable/cable_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_setsoilparms.F90 b/lis/surfacemodels/land/cable/cable_setsoilparms.F90 index 1d1468e59..9d8bf048c 100644 --- a/lis/surfacemodels/land/cable/cable_setsoilparms.F90 +++ b/lis/surfacemodels/land/cable/cable_setsoilparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_setup.F90 b/lis/surfacemodels/land/cable/cable_setup.F90 index fc45e2e08..577d4b5d6 100644 --- a/lis/surfacemodels/land/cable/cable_setup.F90 +++ b/lis/surfacemodels/land/cable/cable_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_setvegparms.F90 b/lis/surfacemodels/land/cable/cable_setvegparms.F90 index 019f9521b..0ea4c6652 100644 --- a/lis/surfacemodels/land/cable/cable_setvegparms.F90 +++ b/lis/surfacemodels/land/cable/cable_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cable_writerst.F90 b/lis/surfacemodels/land/cable/cable_writerst.F90 index 5667c6bba..7f8756e71 100644 --- a/lis/surfacemodels/land/cable/cable_writerst.F90 +++ b/lis/surfacemodels/land/cable/cable_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_setwrfexport.F90 b/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_setwrfexport.F90 index 6b0c2f7b2..e9715222a 100644 --- a/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_setwrfexport.F90 +++ b/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_wrf_f2t.F90 b/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_wrf_f2t.F90 index 3f334c3f5..b0e6b7783 100644 --- a/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_wrf_f2t.F90 +++ b/lis/surfacemodels/land/cable/cpl_wrf_noesmf/cable_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/0Intro_clm2.txt b/lis/surfacemodels/land/clm2/0Intro_clm2.txt index 3c2175d30..58f5dc29c 100644 --- a/lis/surfacemodels/land/clm2/0Intro_clm2.txt +++ b/lis/surfacemodels/land/clm2/0Intro_clm2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeochem/Biogeochemistry.F90 b/lis/surfacemodels/land/clm2/biogeochem/Biogeochemistry.F90 index a90e1bd7a..9d2ad36c7 100644 --- a/lis/surfacemodels/land/clm2/biogeochem/Biogeochemistry.F90 +++ b/lis/surfacemodels/land/clm2/biogeochem/Biogeochemistry.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeochem/DustEmissionMod.F90 b/lis/surfacemodels/land/clm2/biogeochem/DustEmissionMod.F90 index c7580f517..4d735a34b 100644 --- a/lis/surfacemodels/land/clm2/biogeochem/DustEmissionMod.F90 +++ b/lis/surfacemodels/land/clm2/biogeochem/DustEmissionMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeochem/VOCEmission.F90 b/lis/surfacemodels/land/clm2/biogeochem/VOCEmission.F90 index f0b3ce2d8..4cb83d051 100644 --- a/lis/surfacemodels/land/clm2/biogeochem/VOCEmission.F90 +++ b/lis/surfacemodels/land/clm2/biogeochem/VOCEmission.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/BalanceCheck.F90 b/lis/surfacemodels/land/clm2/biogeophys/BalanceCheck.F90 index caa1b492e..ee18e672a 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/BalanceCheck.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/BalanceCheck.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/BareGroundFluxes.F90 b/lis/surfacemodels/land/clm2/biogeophys/BareGroundFluxes.F90 index a309762ae..6be991d9d 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/BareGroundFluxes.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/BareGroundFluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics1.F90 b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics1.F90 index a420ebd14..f631398e3 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics1.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics2.F90 b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics2.F90 index 35ccfc558..b08a841a7 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics2.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics_Lake.F90 b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics_Lake.F90 index 5ea39f25e..a7f96371d 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics_Lake.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Biogeophysics_Lake.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/CanopyFluxes.F90 b/lis/surfacemodels/land/clm2/biogeophys/CanopyFluxes.F90 index d0b571541..ad7a75d33 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/CanopyFluxes.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/CanopyFluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/CombineSnowLayers.F90 b/lis/surfacemodels/land/clm2/biogeophys/CombineSnowLayers.F90 index 6aca11d67..b48bf6400 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/CombineSnowLayers.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/CombineSnowLayers.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Combo.F90 b/lis/surfacemodels/land/clm2/biogeophys/Combo.F90 index 3327bcb69..4b2b3e84c 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Combo.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Combo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/DivideSnowLayers.F90 b/lis/surfacemodels/land/clm2/biogeophys/DivideSnowLayers.F90 index c80828045..fb8868d41 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/DivideSnowLayers.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/DivideSnowLayers.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Drainage.F90 b/lis/surfacemodels/land/clm2/biogeophys/Drainage.F90 index 18d6fd6e3..b59632aa6 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Drainage.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Drainage.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/FrictionVelocity.F90 b/lis/surfacemodels/land/clm2/biogeophys/FrictionVelocity.F90 index 6dd3f655f..b7f578a1c 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/FrictionVelocity.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/FrictionVelocity.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Hydrology1.F90 b/lis/surfacemodels/land/clm2/biogeophys/Hydrology1.F90 index de2781502..c992bb4c8 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Hydrology1.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Hydrology1.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Hydrology2.F90 b/lis/surfacemodels/land/clm2/biogeophys/Hydrology2.F90 index 9ebc6424a..37c859cb3 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Hydrology2.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Hydrology2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Hydrology_Lake.F90 b/lis/surfacemodels/land/clm2/biogeophys/Hydrology_Lake.F90 index c24e5d14c..aa8c2c402 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Hydrology_Lake.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Hydrology_Lake.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Infiltration.F90 b/lis/surfacemodels/land/clm2/biogeophys/Infiltration.F90 index 2a950591f..521140f75 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Infiltration.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Infiltration.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/LatentHCond.F90 b/lis/surfacemodels/land/clm2/biogeophys/LatentHCond.F90 index 16d3d9aaf..02b6910a5 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/LatentHCond.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/LatentHCond.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/MoninObukIni.F90 b/lis/surfacemodels/land/clm2/biogeophys/MoninObukIni.F90 index 83ca293b2..3ace9759d 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/MoninObukIni.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/MoninObukIni.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/PhaseChange.F90 b/lis/surfacemodels/land/clm2/biogeophys/PhaseChange.F90 index b1dacaf33..ef3058b4b 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/PhaseChange.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/PhaseChange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/QSatclm.F90 b/lis/surfacemodels/land/clm2/biogeophys/QSatclm.F90 index 27d1d9c16..658df5d1a 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/QSatclm.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/QSatclm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SensibleHCond.F90 b/lis/surfacemodels/land/clm2/biogeophys/SensibleHCond.F90 index e246636c4..6452e52dd 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SensibleHCond.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SensibleHCond.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SnowAge.F90 b/lis/surfacemodels/land/clm2/biogeophys/SnowAge.F90 index 21adffd79..531922f52 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SnowAge.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SnowAge.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SnowAlbedo.F90 b/lis/surfacemodels/land/clm2/biogeophys/SnowAlbedo.F90 index 9415477a8..33d52250d 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SnowAlbedo.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SnowAlbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SnowCompaction.F90 b/lis/surfacemodels/land/clm2/biogeophys/SnowCompaction.F90 index 2d7d70517..2829e938e 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SnowCompaction.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SnowCompaction.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SnowWater.F90 b/lis/surfacemodels/land/clm2/biogeophys/SnowWater.F90 index 6936d39a1..71238f873 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SnowWater.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SnowWater.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SoilAlbedo.F90 b/lis/surfacemodels/land/clm2/biogeophys/SoilAlbedo.F90 index 2743bddda..4a7694e3c 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SoilAlbedo.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SoilAlbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SoilTemperature.F90 b/lis/surfacemodels/land/clm2/biogeophys/SoilTemperature.F90 index 3e06fee3a..202505a31 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SoilTemperature.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SoilTemperature.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SoilThermProp.F90 b/lis/surfacemodels/land/clm2/biogeophys/SoilThermProp.F90 index 8dcb6f06a..b13f49656 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SoilThermProp.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SoilThermProp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SoilWater.F90 b/lis/surfacemodels/land/clm2/biogeophys/SoilWater.F90 index 353fff6c1..34e097860 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SoilWater.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SoilWater.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/StabilityFunc.F90 b/lis/surfacemodels/land/clm2/biogeophys/StabilityFunc.F90 index 2dbb31ce5..f4df3ae5a 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/StabilityFunc.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/StabilityFunc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Stomata.F90 b/lis/surfacemodels/land/clm2/biogeophys/Stomata.F90 index 77db5aa11..bcce19a0c 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Stomata.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Stomata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SurfaceAlbedo.F90 b/lis/surfacemodels/land/clm2/biogeophys/SurfaceAlbedo.F90 index 7a33e82f9..8a6a719d2 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SurfaceAlbedo.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SurfaceAlbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SurfaceRadiation.F90 b/lis/surfacemodels/land/clm2/biogeophys/SurfaceRadiation.F90 index dcde1e648..3763be0a6 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SurfaceRadiation.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SurfaceRadiation.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/SurfaceRunoff.F90 b/lis/surfacemodels/land/clm2/biogeophys/SurfaceRunoff.F90 index 525ffbd0a..7c6e867e6 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/SurfaceRunoff.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/SurfaceRunoff.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/Tridiagonal.F90 b/lis/surfacemodels/land/clm2/biogeophys/Tridiagonal.F90 index beb24a35e..5ca2d5d52 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/Tridiagonal.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/Tridiagonal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/TwoStream.F90 b/lis/surfacemodels/land/clm2/biogeophys/TwoStream.F90 index c62e1d9d7..1a4157212 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/TwoStream.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/TwoStream.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/biogeophys/WetIceHydrology.F90 b/lis/surfacemodels/land/clm2/biogeophys/WetIceHydrology.F90 index d42bce95b..5fe0c9e9c 100644 --- a/lis/surfacemodels/land/clm2/biogeophys/WetIceHydrology.F90 +++ b/lis/surfacemodels/land/clm2/biogeophys/WetIceHydrology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/calendr.F90 b/lis/surfacemodels/land/clm2/camclm_share/calendr.F90 index 2399105e4..562dd13ed 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/calendr.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/calendr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/datetime.F90 b/lis/surfacemodels/land/clm2/camclm_share/datetime.F90 index 8380e8dc8..db7d81bcf 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/datetime.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/datetime.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/fileutils.F90 b/lis/surfacemodels/land/clm2/camclm_share/fileutils.F90 index a693ef1af..de620862c 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/fileutils.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/fileutils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/gauaw_mod.F90 b/lis/surfacemodels/land/clm2/camclm_share/gauaw_mod.F90 index 9297cd177..4e2778237 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/gauaw_mod.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/gauaw_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/ioFileMod.F90 b/lis/surfacemodels/land/clm2/camclm_share/ioFileMod.F90 index 99a5b8c5d..3185d7bd1 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/ioFileMod.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/ioFileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/linebuf_stdout.c b/lis/surfacemodels/land/clm2/camclm_share/linebuf_stdout.c index 018b1ab71..4d06d2f07 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/linebuf_stdout.c +++ b/lis/surfacemodels/land/clm2/camclm_share/linebuf_stdout.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/camclm_share/wrap_nf.F90 b/lis/surfacemodels/land/clm2/camclm_share/wrap_nf.F90 index 7a2dd8f67..29a47bd36 100644 --- a/lis/surfacemodels/land/clm2/camclm_share/wrap_nf.F90 +++ b/lis/surfacemodels/land/clm2/camclm_share/wrap_nf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/canhtset.F90 b/lis/surfacemodels/land/clm2/canhtset.F90 index 5d37c9329..1fc3dd639 100644 --- a/lis/surfacemodels/land/clm2/canhtset.F90 +++ b/lis/surfacemodels/land/clm2/canhtset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_dynsetup.F90 b/lis/surfacemodels/land/clm2/clm2_dynsetup.F90 index c422f71e7..80c5d341d 100644 --- a/lis/surfacemodels/land/clm2/clm2_dynsetup.F90 +++ b/lis/surfacemodels/land/clm2/clm2_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_finalize.F90 b/lis/surfacemodels/land/clm2/clm2_finalize.F90 index 68a9c128e..8fdbe5194 100644 --- a/lis/surfacemodels/land/clm2/clm2_finalize.F90 +++ b/lis/surfacemodels/land/clm2/clm2_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_lairead.F90 b/lis/surfacemodels/land/clm2/clm2_lairead.F90 index dfd49a39b..a607b8fb2 100644 --- a/lis/surfacemodels/land/clm2/clm2_lairead.F90 +++ b/lis/surfacemodels/land/clm2/clm2_lairead.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_lsmMod.F90 b/lis/surfacemodels/land/clm2/clm2_lsmMod.F90 index beeb78f6b..c0de91551 100644 --- a/lis/surfacemodels/land/clm2/clm2_lsmMod.F90 +++ b/lis/surfacemodels/land/clm2/clm2_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_main.F90 b/lis/surfacemodels/land/clm2/clm2_main.F90 index d7649e1c3..b8cb9dad4 100644 --- a/lis/surfacemodels/land/clm2/clm2_main.F90 +++ b/lis/surfacemodels/land/clm2/clm2_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_readrestart.F90 b/lis/surfacemodels/land/clm2/clm2_readrestart.F90 index e0e467db0..531439ae6 100644 --- a/lis/surfacemodels/land/clm2/clm2_readrestart.F90 +++ b/lis/surfacemodels/land/clm2/clm2_readrestart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_setup.F90 b/lis/surfacemodels/land/clm2/clm2_setup.F90 index 3c893818c..a2d778a32 100644 --- a/lis/surfacemodels/land/clm2/clm2_setup.F90 +++ b/lis/surfacemodels/land/clm2/clm2_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2_writerestart.F90 b/lis/surfacemodels/land/clm2/clm2_writerestart.F90 index 649353976..f4bdbcf1a 100644 --- a/lis/surfacemodels/land/clm2/clm2_writerestart.F90 +++ b/lis/surfacemodels/land/clm2/clm2_writerestart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/clm2type.F90 b/lis/surfacemodels/land/clm2/clm2type.F90 index 8b920a73c..8b382135d 100644 --- a/lis/surfacemodels/land/clm2/clm2type.F90 +++ b/lis/surfacemodels/land/clm2/clm2type.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_setwrfesmfexport.F90 b/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_setwrfesmfexport.F90 index d844ef28a..353e78815 100755 --- a/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_setwrfesmfexport.F90 +++ b/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_setwrfesmfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_wrf_esmff2t.F90 b/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_wrf_esmff2t.F90 index 1fee61403..722acd086 100644 --- a/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_wrf_esmff2t.F90 +++ b/lis/surfacemodels/land/clm2/cpl_wrf_esmf/clm2_wrf_esmff2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_setwrfexport.F90 b/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_setwrfexport.F90 index 9884ac966..a01b3d340 100755 --- a/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_setwrfexport.F90 +++ b/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_wrf_f2t.F90 b/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_wrf_f2t.F90 index c9fdbbb0c..70fcebdd2 100755 --- a/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_wrf_f2t.F90 +++ b/lis/surfacemodels/land/clm2/cpl_wrf_noesmf/clm2_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_const_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_const_mod.F90 index 1b89b68c4..27461e6c5 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_const_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_const_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_file_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_file_mod.F90 index e4d557343..4e28eda73 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_file_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_file_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_kind_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_kind_mod.F90 index ba6fcc969..df6b6334c 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_kind_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_kind_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_msg_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_msg_mod.F90 index 0c31b94a0..7893b2d63 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_msg_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_msg_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_orb_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_orb_mod.F90 index 3e2fd0cda..e1e17f9e3 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_orb_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_orb_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_sys_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_sys_mod.F90 index 15f2ac9f9..f54930240 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_sys_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_sys_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_timer_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_timer_mod.F90 index 62ad80b16..b6168ff7a 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_timer_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_timer_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_fwrap.c b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_fwrap.c index 792ada0cd..afbd25187 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_fwrap.c +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_fwrap.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_mod.F90 b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_mod.F90 index 74ce257f7..ec24bebe6 100644 --- a/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_mod.F90 +++ b/lis/surfacemodels/land/clm2/csm_share/clm2_shr_vmath_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_descale_lst.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_descale_lst.F90 index f7ff26b4d..8666b01d7 100644 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_descale_lst.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_descale_lst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_getlst.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_getlst.F90 index be32ad1f5..ee6a3b5c4 100755 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_getlst.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_getlst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_getsynlstpred.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_getsynlstpred.F90 index d3a6c2b79..a46e7a8b6 100644 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_getsynlstpred.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_getsynlstpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_qclst.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_qclst.F90 index d7673f707..59694bbe3 100644 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_qclst.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_qclst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_scale_lst.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_scale_lst.F90 index 189a65df7..4e17404c8 100755 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_scale_lst.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_scale_lst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_lst/clm2_setlst.F90 b/lis/surfacemodels/land/clm2/da_lst/clm2_setlst.F90 index 89c140a0c..9fdc4076b 100644 --- a/lis/surfacemodels/land/clm2/da_lst/clm2_setlst.F90 +++ b/lis/surfacemodels/land/clm2/da_lst/clm2_setlst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_descale_snow.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_descale_snow.F90 index 3c2a43aef..52a34038e 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_descale_snow.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_getsnowvars.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_getsnowvars.F90 index 07350d3b2..8ddf34fc0 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_getsnowvars.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_getsnwdpred.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_getsnwdpred.F90 index c8950be63..fee19d6ca 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_getsnwdpred.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_getswepred.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_getswepred.F90 index 99662e404..3a9efb9fe 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_getswepred.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_map_sca.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_map_sca.F90 index fe9ee1644..c6516760d 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_map_sca.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_map_sca.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_qc_snowobs.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_qc_snowobs.F90 index e9902eb68..2dda77563 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_qc_snowobs.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_qcsnow.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_qcsnow.F90 index ed5af5962..fdfba4173 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_qcsnow.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_scale_snow.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_scale_snow.F90 index 19e5d1fbe..b1e44af0a 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_scale_snow.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_setsnowvars.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_setsnowvars.F90 index e832a8294..d6dec4964 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_setsnowvars.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_transform_obssca.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_transform_obssca.F90 index 4ed447804..2a60c2e12 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_transform_obssca.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_transform_obssca.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_snow/clm2_updatesnowvars.F90 b/lis/surfacemodels/land/clm2/da_snow/clm2_updatesnowvars.F90 index cf0333413..37b5f2f06 100644 --- a/lis/surfacemodels/land/clm2/da_snow/clm2_updatesnowvars.F90 +++ b/lis/surfacemodels/land/clm2/da_snow/clm2_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_descale_soilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_descale_soilm.F90 index c9742654a..cde460218 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_descale_soilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_getsoilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_getsoilm.F90 index aafccba4c..bc28a8cfe 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_getsoilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_getsynsmpred.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_getsynsmpred.F90 index 75a17584c..fb7e8a143 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_getsynsmpred.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_getsynsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_qcsoilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_qcsoilm.F90 index ab5e39c9a..a449eac34 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_qcsoilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_scale_soilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_scale_soilm.F90 index 5df70743d..8c42825cd 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_scale_soilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_setsoilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_setsoilm.F90 index 2733c6ccb..5c026037d 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_setsoilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_updatesoilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_updatesoilm.F90 index f49372658..735a34106 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_updatesoilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/da_soilm/clm2_write_soilm.F90 b/lis/surfacemodels/land/clm2/da_soilm/clm2_write_soilm.F90 index 9fd76b86b..287b53f2f 100644 --- a/lis/surfacemodels/land/clm2/da_soilm/clm2_write_soilm.F90 +++ b/lis/surfacemodels/land/clm2/da_soilm/clm2_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Allocation.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Allocation.F90 index 79b0e619c..6a1fedb2c 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Allocation.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Allocation.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/EcosystemDyn.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/EcosystemDyn.F90 index 347441567..d794c2e31 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/EcosystemDyn.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/EcosystemDyn.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Fire.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Fire.F90 index 863dd5866..2d8833b5e 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Fire.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Fire.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/FireSeason.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/FireSeason.F90 index aefee8fd1..bdf6ece78 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/FireSeason.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/FireSeason.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Kill.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Kill.F90 index cbfab266e..b7102dc4c 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Kill.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Kill.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/LitterSOM.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/LitterSOM.F90 index 3c7a20f73..26accc244 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/LitterSOM.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/LitterSOM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Mortality.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Mortality.F90 index 54fb0e8e9..e5420caa5 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Mortality.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Mortality.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Phenology.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Phenology.F90 index 3a3792c09..937ec6415 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Phenology.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Phenology.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Reproduction.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Reproduction.F90 index 21d0bc431..261b77e64 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Reproduction.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Reproduction.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/Turnover.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/Turnover.F90 index 1a05958e2..bddd1f7a3 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/Turnover.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/Turnover.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/ecosysdyn/accumDGVM.F90 b/lis/surfacemodels/land/clm2/ecosysdyn/accumDGVM.F90 index 0a8b3a763..3a727a1f9 100644 --- a/lis/surfacemodels/land/clm2/ecosysdyn/accumDGVM.F90 +++ b/lis/surfacemodels/land/clm2/ecosysdyn/accumDGVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/iniTimeConst.F90 b/lis/surfacemodels/land/clm2/iniTimeConst.F90 index 8411f234d..b593f35aa 100644 --- a/lis/surfacemodels/land/clm2/iniTimeConst.F90 +++ b/lis/surfacemodels/land/clm2/iniTimeConst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/iniTimeVar.F90 b/lis/surfacemodels/land/clm2/iniTimeVar.F90 index 014c66ca7..234d1db76 100644 --- a/lis/surfacemodels/land/clm2/iniTimeVar.F90 +++ b/lis/surfacemodels/land/clm2/iniTimeVar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/atm_lndMod.F90 b/lis/surfacemodels/land/clm2/main/atm_lndMod.F90 index 29960d6b7..c637e2898 100644 --- a/lis/surfacemodels/land/clm2/main/atm_lndMod.F90 +++ b/lis/surfacemodels/land/clm2/main/atm_lndMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_accumulMod.F90 b/lis/surfacemodels/land/clm2/main/clm2_accumulMod.F90 index 2257fb967..778d67d01 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_accumulMod.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_accumulMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_areaMod.F90 b/lis/surfacemodels/land/clm2/main/clm2_areaMod.F90 index c29f07f12..563977ca6 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_areaMod.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_areaMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_atmdrvMod.F90 b/lis/surfacemodels/land/clm2/main/clm2_atmdrvMod.F90 index 782a29f33..1e5ad58b8 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_atmdrvMod.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_atmdrvMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_varcon.F90 b/lis/surfacemodels/land/clm2/main/clm2_varcon.F90 index e6a51e0e2..7509619aa 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_varcon.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_varcon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_varpar.F90 b/lis/surfacemodels/land/clm2/main/clm2_varpar.F90 index 67f8b6a8e..a34d052e9 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_varpar.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_varpar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/clm2_varsur.F90 b/lis/surfacemodels/land/clm2/main/clm2_varsur.F90 index 8e762b5b5..23c2aa4f0 100644 --- a/lis/surfacemodels/land/clm2/main/clm2_varsur.F90 +++ b/lis/surfacemodels/land/clm2/main/clm2_varsur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/lnd_atmMod.F90 b/lis/surfacemodels/land/clm2/main/lnd_atmMod.F90 index 56c01cf09..116a2eb9b 100644 --- a/lis/surfacemodels/land/clm2/main/lnd_atmMod.F90 +++ b/lis/surfacemodels/land/clm2/main/lnd_atmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/pft_varcon.F90 b/lis/surfacemodels/land/clm2/main/pft_varcon.F90 index c878f6d66..1e7f7098d 100644 --- a/lis/surfacemodels/land/clm2/main/pft_varcon.F90 +++ b/lis/surfacemodels/land/clm2/main/pft_varcon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/snowdp2lev.F90 b/lis/surfacemodels/land/clm2/main/snowdp2lev.F90 index 4a0f013ca..a235823f1 100644 --- a/lis/surfacemodels/land/clm2/main/snowdp2lev.F90 +++ b/lis/surfacemodels/land/clm2/main/snowdp2lev.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/main/surfFileMod.F90 b/lis/surfacemodels/land/clm2/main/surfFileMod.F90 index 8c2408447..0898cc863 100644 --- a/lis/surfacemodels/land/clm2/main/surfFileMod.F90 +++ b/lis/surfacemodels/land/clm2/main/surfFileMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkglacier.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkglacier.F90 index fb588147a..5c3948514 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkglacier.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkglacier.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkgridMod.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkgridMod.F90 index ca6b5ff12..38d482353 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkgridMod.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkgridMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mklai.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mklai.F90 index eabb39e0e..08c045904 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mklai.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mklai.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mklanwat.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mklanwat.F90 index 67aff2814..afae2cd72 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mklanwat.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mklanwat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkmxovr.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkmxovr.F90 index 11f9db33a..bc997f381 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkmxovr.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkmxovr.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkpft.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkpft.F90 index 893f0de93..a96f44468 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkpft.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkpft.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkrank.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkrank.F90 index e8d30338d..5bd5647c8 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkrank.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkrank.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mksoicol.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mksoicol.F90 index 370391338..6778d1ac5 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mksoicol.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mksoicol.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mksoitex.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mksoitex.F90 index fd189172e..f1b602931 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mksoitex.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mksoitex.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mksrfdatMod.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mksrfdatMod.F90 index d5fd926c6..3fe91a25c 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mksrfdatMod.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mksrfdatMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/mksrfdata/mkurban.F90 b/lis/surfacemodels/land/clm2/mksrfdata/mkurban.F90 index 330184fd5..5f5222fe8 100644 --- a/lis/surfacemodels/land/clm2/mksrfdata/mkurban.F90 +++ b/lis/surfacemodels/land/clm2/mksrfdata/mkurban.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/readclm2crd.F90 b/lis/surfacemodels/land/clm2/readclm2crd.F90 index 340093055..ab624b028 100644 --- a/lis/surfacemodels/land/clm2/readclm2crd.F90 +++ b/lis/surfacemodels/land/clm2/readclm2crd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/riverroute/RtmMod.F90 b/lis/surfacemodels/land/clm2/riverroute/RtmMod.F90 index f29946243..ff8f6b1af 100644 --- a/lis/surfacemodels/land/clm2/riverroute/RtmMod.F90 +++ b/lis/surfacemodels/land/clm2/riverroute/RtmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack2d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack2d.F90 index 34fea3269..f3cdf3bbe 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack2d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack2d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack3d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack3d.F90 index 9cea18a75..138201545 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack3d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack3d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack4d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack4d.F90 index 3fcb6fc09..3d981e257 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack4d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferpack4d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack2d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack2d.F90 index c04bc756e..9e59d9bd0 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack2d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack2d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack3d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack3d.F90 index d080bb7be..71f45e561 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack3d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack3d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack4d.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack4d.F90 index 3cb4bf0fa..b3ad81389 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack4d.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/bufferunpack4d.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/debug.h b/lis/surfacemodels/land/clm2/utils/pilgrim/debug.h index b73746388..b8fc35c1d 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/debug.h +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/debug.h @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/debugutilitiesmodule.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/debugutilitiesmodule.F90 index 9064983a9..65eea11a7 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/debugutilitiesmodule.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/debugutilitiesmodule.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/decompmodule.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/decompmodule.F90 index 314f13fd5..351e61614 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/decompmodule.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/decompmodule.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/ghostmodule.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/ghostmodule.F90 index c102e3908..d85f4880e 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/ghostmodule.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/ghostmodule.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/parutilitiesmodule.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/parutilitiesmodule.F90 index 0b0d4c99f..ee155e74d 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/parutilitiesmodule.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/parutilitiesmodule.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/pilgrim.h b/lis/surfacemodels/land/clm2/utils/pilgrim/pilgrim.h index b3cfebc30..18d71804f 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/pilgrim.h +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/pilgrim.h @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/puminterfaces.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/puminterfaces.F90 index dd687f152..b35b26116 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/puminterfaces.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/puminterfaces.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/pilgrim/redistributemodule.F90 b/lis/surfacemodels/land/clm2/utils/pilgrim/redistributemodule.F90 index 99b12270e..7e1b84501 100644 --- a/lis/surfacemodels/land/clm2/utils/pilgrim/redistributemodule.F90 +++ b/lis/surfacemodels/land/clm2/utils/pilgrim/redistributemodule.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/f_wrappers.c b/lis/surfacemodels/land/clm2/utils/timing/f_wrappers.c index 29ae425e2..1b8f220dd 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/f_wrappers.c +++ b/lis/surfacemodels/land/clm2/utils/timing/f_wrappers.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/get_cpustamp.c b/lis/surfacemodels/land/clm2/utils/timing/get_cpustamp.c index 2a0415eed..cf3cf481c 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/get_cpustamp.c +++ b/lis/surfacemodels/land/clm2/utils/timing/get_cpustamp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/get_thread_num.c b/lis/surfacemodels/land/clm2/utils/timing/get_thread_num.c index 49e167d24..38f65e743 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/get_thread_num.c +++ b/lis/surfacemodels/land/clm2/utils/timing/get_thread_num.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/gpt.h b/lis/surfacemodels/land/clm2/utils/timing/gpt.h index 6ceb8b4df..9b544d34c 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/gpt.h +++ b/lis/surfacemodels/land/clm2/utils/timing/gpt.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_error.c b/lis/surfacemodels/land/clm2/utils/timing/t_error.c index 1af24ce73..b7010ceed 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_error.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_error.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_initialize.c b/lis/surfacemodels/land/clm2/utils/timing/t_initialize.c index 954b54662..fc86e8ad5 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_initialize.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_initialize.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_pclstr.c b/lis/surfacemodels/land/clm2/utils/timing/t_pclstr.c index e93a63966..80379a81c 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_pclstr.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_pclstr.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_pr.c b/lis/surfacemodels/land/clm2/utils/timing/t_pr.c index 004febd13..a3777f04d 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_pr.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_pr.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_reset.c b/lis/surfacemodels/land/clm2/utils/timing/t_reset.c index af8bd1ff3..317b30325 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_reset.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_reset.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_setoption.c b/lis/surfacemodels/land/clm2/utils/timing/t_setoption.c index 2f5fe0b86..816731ed9 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_setoption.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_setoption.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_stamp.c b/lis/surfacemodels/land/clm2/utils/timing/t_stamp.c index 669b660a2..cb47fb452 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_stamp.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_stamp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_start.c b/lis/surfacemodels/land/clm2/utils/timing/t_start.c index f59be06dd..fdc123ad0 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_start.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_start.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clm2/utils/timing/t_stop.c b/lis/surfacemodels/land/clm2/utils/timing/t_stop.c index 7140d159c..a26db42cf 100644 --- a/lis/surfacemodels/land/clm2/utils/timing/t_stop.c +++ b/lis/surfacemodels/land/clm2/utils/timing/t_stop.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/0Intro_clsmf25.txt b/lis/surfacemodels/land/clsm.f2.5/0Intro_clsmf25.txt index e4f22318a..27d44e47f 100755 --- a/lis/surfacemodels/land/clsm.f2.5/0Intro_clsmf25.txt +++ b/lis/surfacemodels/land/clsm.f2.5/0Intro_clsmf25.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_DragCoefficientsMod.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_DragCoefficientsMod.F90 index 01a6cd1c2..beccb9fd7 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_DragCoefficientsMod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_DragCoefficientsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_MAPL_constants.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_MAPL_constants.F90 index f77f7bd6d..63c6b14c1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_MAPL_constants.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_MAPL_constants.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_compute_land_parameters.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_compute_land_parameters.F90 index 1e6042ec7..3002a1ae3 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_compute_land_parameters.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_compute_land_parameters.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_constants.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_constants.F90 index 4c2680585..d74fbb5f7 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_constants.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_constants.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_diagn_routines.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_diagn_routines.F90 index abd6cff92..8e388f66b 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_diagn_routines.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_diagn_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_drv_types.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_drv_types.F90 index 40788954a..3512c7e28 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_drv_types.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_drv_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_dynsetup.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_dynsetup.F90 index dec072eeb..9cb001f88 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_dynsetup.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_esat_qsat.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_esat_qsat.F90 index 2242db3e0..46cd6c6d5 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_esat_qsat.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_esat_qsat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_f2t.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_f2t.F90 index 9d03579b5..0175ede1b 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_f2t.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_finalize.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_finalize.F90 index b13488395..f88370475 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_finalize.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_lsmMod.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_lsmMod.F90 index 9839e3153..20a83584b 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_lsmMod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_main.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_main.F90 index 15bd441dd..a407ff864 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_main.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_model.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_model.F90 index 86899e335..1dfcd60f6 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_model.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_model.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_modis_alb_types.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_modis_alb_types.F90 index 47018236a..1e8b8c82d 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_modis_alb_types.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_modis_alb_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_pmonth_stage4.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_pmonth_stage4.F90 index 304894890..49141f1a9 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_pmonth_stage4.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_pmonth_stage4.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_readcrd.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_readcrd.F90 index bfcf93abd..af491943d 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_readcrd.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_readrst.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_readrst.F90 index f6159bcc5..5d1564e89 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_readrst.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_relayer_snow.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_relayer_snow.F90 index 27860e87d..c80b4e4a8 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_relayer_snow.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_relayer_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_reset.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_reset.F90 index c947af55f..5f7281bd5 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_reset.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_setup.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_setup.F90 index a5ea37d03..392175821 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_setup.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_sibalb_coeff.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_sibalb_coeff.F90 index 339b9a084..c9ffeb091 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_sibalb_coeff.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_sibalb_coeff.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_surfacelayer.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_surfacelayer.F90 index d23d88712..c2e353445 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_surfacelayer.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_surfacelayer.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_turb.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_turb.F90 index 547bce854..f5da85cb1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_turb.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_turb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_types.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_types.F90 index a18bc3ef5..5c4877269 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_types.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_types.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/clsmf25_writerst.F90 b/lis/surfacemodels/land/clsm.f2.5/clsmf25_writerst.F90 index 902741e7b..4bea85288 100644 --- a/lis/surfacemodels/land/clsm.f2.5/clsmf25_writerst.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/clsmf25_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_dasnow_Mod.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_dasnow_Mod.F90 index 115cd343c..322345a55 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_descale_snow.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_descale_snow.F90 index 777f43f03..7a2867257 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_descale_snow.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnowvars.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnowvars.F90 index dae7fb7c1..6bc4b9758 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnowvars.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnwdpred.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnwdpred.F90 index ed265a35c..c12839e3d 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnwdpred.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qc_snowobs.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qc_snowobs.F90 index 51f7fcbdf..b194597ef 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qc_snowobs.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qcsnow.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qcsnow.F90 index 9e06c6030..fb9461408 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qcsnow.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_scale_snow.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_scale_snow.F90 index a17ea40c2..20a5b7841 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_scale_snow.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_setsnowvars.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_setsnowvars.F90 index 0493d6448..a703a4af1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_setsnowvars.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_snow_DAlog.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_snow_DAlog.F90 index 4f4f0a192..eec7e35a5 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_snow_DAlog.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_snow_DAlog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_updatesnowvars.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_updatesnowvars.F90 index 834cfc759..beb21a713 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_updatesnowvars.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_wrtswe.F90 b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_wrtswe.F90 index 1f8d85348..3fe0db646 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_wrtswe.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_snow/clsmf25_wrtswe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_dasoilm_Mod.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_dasoilm_Mod.F90 index abe5dfe7c..7ec0360a6 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_descale_soilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_descale_soilm.F90 index f6e4afa91..2499223d1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_descale_soilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsmpred.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsmpred.F90 index ef1772011..c1bd736a0 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsmpred.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsoilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsoilm.F90 index 939bd4626..aeb41ff82 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsoilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qc_soilmobs.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qc_soilmobs.F90 index 3da2450cb..4890a5e82 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qcsoilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qcsoilm.F90 index 07023e278..bb6939daf 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qcsoilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_scale_soilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_scale_soilm.F90 index 4a76b6d32..b52d72a42 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_scale_soilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_setsoilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_setsoilm.F90 index bb4935a50..aa5e6a816 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_setsoilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_soilm_DAlog.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_soilm_DAlog.F90 index d6ece4180..66a583ab1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_soilm_DAlog.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_soilm_DAlog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_updatesoilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_updatesoilm.F90 index f44c5e902..fe110b734 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_updatesoilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_write_soilm.F90 b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_write_soilm.F90 index 6e6aa71a2..892be4500 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_write_soilm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_soilm/clsmf25_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_datws_Mod.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_datws_Mod.F90 index 2430b05db..9dbc3cb09 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_datws_Mod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_datws_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_descale_tws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_descale_tws.F90 index f157a3757..006cedafa 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_descale_tws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_descale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettws.F90 index 82ff8de72..898c8185f 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettwspred.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettwspred.F90 index 696f6f809..57275f4be 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettwspred.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_gettwspred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qc_twsobs.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qc_twsobs.F90 index b5e373e22..b6e445d14 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qc_twsobs.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qc_twsobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qctws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qctws.F90 index eb3ea8847..d4c65e6e4 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qctws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_qctws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_scale_tws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_scale_tws.F90 index f5f8f669a..f5e084e7b 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_scale_tws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_scale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_settws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_settws.F90 index 1922e509b..dc60fa7de 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_settws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_settws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_tws_DAlogMod.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_tws_DAlogMod.F90 index dfba68d02..440536173 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_tws_DAlogMod.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_tws_DAlogMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_update_tws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_update_tws.F90 index 848a49b86..d4041135f 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_update_tws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_update_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_write_tws.F90 b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_write_tws.F90 index 24019d158..597df017a 100644 --- a/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_write_tws.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/da_tws/clsmf25_write_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/irrigation/clsmf25_getirrigationstates.F90 b/lis/surfacemodels/land/clsm.f2.5/irrigation/clsmf25_getirrigationstates.F90 index fc21a1a9a..6e84e9231 100644 --- a/lis/surfacemodels/land/clsm.f2.5/irrigation/clsmf25_getirrigationstates.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/irrigation/clsmf25_getirrigationstates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs.F90 b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs.F90 index 37613ab50..22a14829e 100644 --- a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_hymap2.F90 index 7469ae26c..03d758b05 100755 --- a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_mm.F90 b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_mm.F90 index f3dc38cdd..c880e12fd 100644 --- a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getsws_hymap2.F90 b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getsws_hymap2.F90 index 3144828b5..69ff79db1 100644 --- a/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/clsm.f2.5/routing/clsmf25_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/0Intro_geowrsi2.txt b/lis/surfacemodels/land/geowrsi.2/0Intro_geowrsi2.txt index b342e412d..b0090d258 100644 --- a/lis/surfacemodels/land/geowrsi.2/0Intro_geowrsi2.txt +++ b/lis/surfacemodels/land/geowrsi.2/0Intro_geowrsi2.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_arraymgmt_module.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_arraymgmt_module.F90 index 2215cd45a..b62362dd7 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_arraymgmt_module.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_arraymgmt_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_dynsetup.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_dynsetup.F90 index 6c0f51f74..f6a288238 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_dynsetup.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_f2t.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_f2t.F90 index 3d44268f4..e80ec9ed4 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_f2t.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_finalize.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_finalize.F90 index fb17f1c87..1bb163fc7 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_finalize.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_lsmMod.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_lsmMod.F90 index 35bfc2b1a..a83c0466b 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_lsmMod.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_main.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_main.F90 index f94bec23c..a738f2e3d 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_main.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_module.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_module.F90 index d9fe3fa4b..8815213ee 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_module.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_physics_module.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_physics_module.F90 index ec2d99928..3db87d035 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_physics_module.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_physics_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readInputSettings.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readInputSettings.F90 index 0016bc82f..92b7a126f 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readInputSettings.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readInputSettings.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readSOS_Bilfile.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readSOS_Bilfile.F90 index 8c11cc3c2..85b6e1900 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readSOS_Bilfile.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readSOS_Bilfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readcrd.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readcrd.F90 index 88ae53239..13552fe3f 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readcrd.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readrst.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readrst.F90 index cdbd1d497..05a63e28e 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_readrst.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_set_gcoords.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_set_gcoords.F90 index 3cc436eb8..6002cffd4 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_set_gcoords.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_set_gcoords.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_setup.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_setup.F90 index d2e6b99c5..32a35c2ec 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_setup.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_writeSOS_Bilfile.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_writeSOS_Bilfile.F90 index b32ef994a..194d00440 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_writeSOS_Bilfile.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_writeSOS_Bilfile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/geowrsi.2/geowrsi2_writerst.F90 b/lis/surfacemodels/land/geowrsi.2/geowrsi2_writerst.F90 index 75fcd5147..03202978e 100644 --- a/lis/surfacemodels/land/geowrsi.2/geowrsi2_writerst.F90 +++ b/lis/surfacemodels/land/geowrsi.2/geowrsi2_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/0Intro_hyssib.txt b/lis/surfacemodels/land/hyssib/0Intro_hyssib.txt index 4a7d1e27b..916c8eda2 100644 --- a/lis/surfacemodels/land/hyssib/0Intro_hyssib.txt +++ b/lis/surfacemodels/land/hyssib/0Intro_hyssib.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_coldstart.F90 b/lis/surfacemodels/land/hyssib/hyssib_coldstart.F90 index fc7431286..f0c37617e 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_coldstart.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_dynsetup.F90 b/lis/surfacemodels/land/hyssib/hyssib_dynsetup.F90 index c64813168..bc55ba3c0 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_dynsetup.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_f2t.F90 b/lis/surfacemodels/land/hyssib/hyssib_f2t.F90 index 432e143ff..8ffa4bca7 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_f2t.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_finalize.F90 b/lis/surfacemodels/land/hyssib/hyssib_finalize.F90 index c430395ee..781440fc9 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_finalize.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_gfrac.F90 b/lis/surfacemodels/land/hyssib/hyssib_gfrac.F90 index f8655ff49..70828debb 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_gfrac.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_gfrac.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_lsmMod.F90 b/lis/surfacemodels/land/hyssib/hyssib_lsmMod.F90 index 343b47073..2039acb63 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_lsmMod.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_main.F90 b/lis/surfacemodels/land/hyssib/hyssib_main.F90 index 9b36e11c8..1229efebc 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_main.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_mapvegc.F90 b/lis/surfacemodels/land/hyssib/hyssib_mapvegc.F90 index 3f42f52ec..99472fcb7 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_mapvegc.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_mapvegc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_module.F90 b/lis/surfacemodels/land/hyssib/hyssib_module.F90 index 0a186b61d..c6dada8be 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_module.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_readcrd.F90 b/lis/surfacemodels/land/hyssib/hyssib_readcrd.F90 index 4b164bb06..ff8a198af 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_readcrd.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_readrst.F90 b/lis/surfacemodels/land/hyssib/hyssib_readrst.F90 index 4b6514948..d5cb58743 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_readrst.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_settbot.F90 b/lis/surfacemodels/land/hyssib/hyssib_settbot.F90 index 88abe24d7..4a4fca12d 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_settbot.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_settopostd.F90 b/lis/surfacemodels/land/hyssib/hyssib_settopostd.F90 index 9ba1c3061..0c2a05acb 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_settopostd.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_settopostd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_setup.F90 b/lis/surfacemodels/land/hyssib/hyssib_setup.F90 index c95b56d50..03bf1ecf8 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_setup.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_setvegparms.F90 b/lis/surfacemodels/land/hyssib/hyssib_setvegparms.F90 index 4ef24bc0e..89b03edc3 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_setvegparms.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_totinit.F90 b/lis/surfacemodels/land/hyssib/hyssib_totinit.F90 index 1e6e12ade..f46b38bdb 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_totinit.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_totinit.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssib_writerst.F90 b/lis/surfacemodels/land/hyssib/hyssib_writerst.F90 index f68789f9f..49367f63d 100644 --- a/lis/surfacemodels/land/hyssib/hyssib_writerst.F90 +++ b/lis/surfacemodels/land/hyssib/hyssib_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssibalb_module.F90 b/lis/surfacemodels/land/hyssib/hyssibalb_module.F90 index fd0159830..24bc057b6 100755 --- a/lis/surfacemodels/land/hyssib/hyssibalb_module.F90 +++ b/lis/surfacemodels/land/hyssib/hyssibalb_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/hyssib/hyssibveg_module.F90 b/lis/surfacemodels/land/hyssib/hyssibveg_module.F90 index 266aef0e5..69d63403c 100755 --- a/lis/surfacemodels/land/hyssib/hyssibveg_module.F90 +++ b/lis/surfacemodels/land/hyssib/hyssibveg_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/ancil_to_tile.F90 index 7508d817a..dbb090e7f 100644 --- a/lis/surfacemodels/land/jules.5.0/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/bvoc_vars_to_tile.F90 index 41d495b3f..8706f6168 100644 --- a/lis/surfacemodels/land/jules.5.0/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.0/couple_jules_to_lis.sh index aff70c649..15ecc73c3 100755 --- a/lis/surfacemodels/land/jules.5.0/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.0/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_dasnodep_Mod.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_dasnodep_Mod.F90 index 50a8380e8..ee19606c2 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_dasnodep_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_dasnodep_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_descale_snodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_descale_snodep.F90 index 207c70d1f..39eb7ab11 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_descale_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodeppred.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodeppred.F90 index b373f57ff..d20f7bd92 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodeppred.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodepvars.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodepvars.F90 index d70436f05..a789d771b 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodepvars.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_map_snodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_map_snodep.F90 index 4b077626d..ac371e8a1 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_map_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qc_snodepobs.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qc_snodepobs.F90 index 24991415c..780b9c196 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qcsnodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qcsnodep.F90 index e09597529..a4de6f464 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qcsnodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_scale_snodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_scale_snodep.F90 index 348f92576..85e201188 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_scale_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_setsnodepvars.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_setsnodepvars.F90 index 9812b58b1..e7383135f 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_setsnodepvars.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_snodep_update.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_snodep_update.F90 index dedd1215d..431586325 100644 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_snodep_update.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_snodep_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_transform_snodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_transform_snodep.F90 index 31d512268..fb4c753b4 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_transform_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_updatesnodep.F90 b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_updatesnodep.F90 index ade4603ba..da93c79e1 100755 --- a/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_updatesnodep.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_snodep/jules50_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_dasoilm_Mod.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_dasoilm_Mod.F90 index 85254b15a..12be1645a 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_descale_soilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_descale_soilm.F90 index 82427effc..cc6071576 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_descale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getLbandTbPred.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getLbandTbPred.F90 index 8bf03b20a..8835b57ba 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsmpred.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsmpred.F90 index f5c0b0d33..9d9434dec 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsmpred.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsoilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsoilm.F90 index 002cb663a..e45d994fe 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qc_soilmobs.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qc_soilmobs.F90 index 205aa595f..b168e5328 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qcsoilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qcsoilm.F90 index 72dcc9a41..8c0f12284 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qcsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_scale_soilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_scale_soilm.F90 index ff963c9e8..4a6c5c918 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_scale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_setsoilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_setsoilm.F90 index dfbceb11a..47bd9b380 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_setsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_updatesoilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_updatesoilm.F90 index 2e9973187..c337ed4ac 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_updatesoilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_write_soilm.F90 b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_write_soilm.F90 index 8acb01c84..e95f246c8 100644 --- a/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_write_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_soilm/jules50_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_dausafsi_Mod.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_dausafsi_Mod.F90 index 5ed4d5ec6..b90fff919 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_dausafsi_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_dausafsi_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_descale_usafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_descale_usafsi.F90 index 84af53675..e1f8a440a 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_descale_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_descale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsipred.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsipred.F90 index 9217039ca..dc57ef496 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsipred.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsipred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsivars.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsivars.F90 index 7baacd32c..bf5cbc8f0 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsivars.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_getusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_map_usafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_map_usafsi.F90 index ba3bbce21..356a55c6e 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_map_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_map_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qc_usafsiobs.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qc_usafsiobs.F90 index 3f6855536..916e1a9c7 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qc_usafsiobs.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qc_usafsiobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qcusafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qcusafsi.F90 index b28c663c0..bd04c5908 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qcusafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_qcusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_scale_usafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_scale_usafsi.F90 index eed74230e..02b9782c0 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_scale_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_scale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_setusafsivars.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_setusafsivars.F90 index 4583da751..b0861e53a 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_setusafsivars.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_setusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_transform_usafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_transform_usafsi.F90 index 38ce2ec6b..06db58904 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_transform_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_transform_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_updateusafsi.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_updateusafsi.F90 index 9cea70352..ae3acd687 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_updateusafsi.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_updateusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_usafsi_update.F90 b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_usafsi_update.F90 index 443623afa..be86e4a3a 100644 --- a/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_usafsi_update.F90 +++ b/lis/surfacemodels/land/jules.5.0/da_usafsi/jules50_usafsi_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.0/debug_latlon.F90 index e36a1ec95..295150b63 100644 --- a/lis/surfacemodels/land/jules.5.0/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.0/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/fluxes_to_tile.F90 index 0d8684193..7d31b153d 100644 --- a/lis/surfacemodels/land/jules.5.0/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_coldstart.F90 b/lis/surfacemodels/land/jules.5.0/jules50_coldstart.F90 index adabea70d..68f3c2d81 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_dynsetup.F90 b/lis/surfacemodels/land/jules.5.0/jules50_dynsetup.F90 index 8834196ee..4337fdb9e 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_f2t.F90 b/lis/surfacemodels/land/jules.5.0/jules50_f2t.F90 index 115c4c7e4..7126b5e8e 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_finalize.F90 b/lis/surfacemodels/land/jules.5.0/jules50_finalize.F90 index 644a45584..b1193b8d2 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.0/jules50_getrunoffs.F90 index 08cb098f6..edaf9a342 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_initialize.F90 b/lis/surfacemodels/land/jules.5.0/jules50_initialize.F90 index 6caf9de79..fc0d8f66d 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_lsmMod.F90 b/lis/surfacemodels/land/jules.5.0/jules50_lsmMod.F90 index 0c1e09071..f70c450de 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_main.F90 b/lis/surfacemodels/land/jules.5.0/jules50_main.F90 index dec997a1d..70e4fb18c 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_main.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_main.F90.original b/lis/surfacemodels/land/jules.5.0/jules50_main.F90.original index c201f6a59..717ba8d31 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_main.F90.original +++ b/lis/surfacemodels/land/jules.5.0/jules50_main.F90.original @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_module.F90 b/lis/surfacemodels/land/jules.5.0/jules50_module.F90 index 9a0409e17..4f87cb8a6 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_module.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.0/jules50_read_multilevel_param.F90 index 897fc5cb1..e0f346e3a 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_readcrd.F90 b/lis/surfacemodels/land/jules.5.0/jules50_readcrd.F90 index 013c06884..4aa0038a6 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_readrst.F90 b/lis/surfacemodels/land/jules.5.0/jules50_readrst.F90 index 3ab07d029..e46e87735 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_setup.F90 b/lis/surfacemodels/land/jules.5.0/jules50_setup.F90 index c33f28200..69d104d76 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_setup.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules50_writerst.F90 b/lis/surfacemodels/land/jules.5.0/jules50_writerst.F90 index 7363993b2..bdc9327ae 100644 --- a/lis/surfacemodels/land/jules.5.0/jules50_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules50_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/jules_internal_to_tile.F90 index 171f4b78e..0d2c0d373 100644 --- a/lis/surfacemodels/land/jules.5.0/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/jules_lis_exchange.f90 b/lis/surfacemodels/land/jules.5.0/jules_lis_exchange.f90 index 22fbaaee6..7fab94c63 100644 --- a/lis/surfacemodels/land/jules.5.0/jules_lis_exchange.f90 +++ b/lis/surfacemodels/land/jules.5.0/jules_lis_exchange.f90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.0/l_to_rc.F90 index 876760a77..993d1ad4a 100644 --- a/lis/surfacemodels/land/jules.5.0/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.0/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/lis_control.F90 b/lis/surfacemodels/land/jules.5.0/lis_control.F90 index e2551ab40..e040c31a7 100644 --- a/lis/surfacemodels/land/jules.5.0/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.0/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/prog_to_tile.F90 index d12f1d298..23c6ecbdc 100644 --- a/lis/surfacemodels/land/jules.5.0/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/ps_to_tile.F90 index 8e75c1b17..28bae6f86 100644 --- a/lis/surfacemodels/land/jules.5.0/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_hymap2.F90 index 40f324153..c28706dd5 100644 --- a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_hymap2.F90 @@ -1,7 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- -! NASA Goddard Space Flight Center Land Information System (LIS) v7.2 +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 ! -! Copyright (c) 2015 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_mm.F90 b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_mm.F90 index 487e3e30f..2df87ff0c 100644 --- a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_rapid.F90 b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_rapid.F90 index ea637a3af..03e957042 100644 --- a/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_rapid.F90 +++ b/lis/surfacemodels/land/jules.5.0/routing/jules50_getrunoffs_rapid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/routing/jules50_getsws_hymap2.F90 b/lis/surfacemodels/land/jules.5.0/routing/jules50_getsws_hymap2.F90 index fa7532754..08ea96c8a 100644 --- a/lis/surfacemodels/land/jules.5.0/routing/jules50_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/jules.5.0/routing/jules50_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/sf_diag_to_tile.F90 index 160825994..98e823041 100644 --- a/lis/surfacemodels/land/jules.5.0/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_ancil.F90 index 06c174e52..6d58c0cd0 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_bvoc_vars.F90 index 94f8f5e0d..b02b573c4 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_fluxes.F90 index 38976069d..24846620c 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_forcing.F90 index 780ab7aa3..c3422cb8b 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_jules_internal.F90 index 5b903ff99..7b93fe861 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_prog.F90 index e48011f50..d96167d03 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_ps.F90 index f16c6aaf5..b061c79ff 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_sf_diag.F90 index f1b09d896..c818cf666 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_top_pdm.F90 index 58b9752b2..7325f9b12 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.0/tile_to_trifctl.F90 index f4697fb88..15b7acee8 100644 --- a/lis/surfacemodels/land/jules.5.0/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.0/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/top_pdm_to_tile.F90 index 385f90dda..69b6dd782 100644 --- a/lis/surfacemodels/land/jules.5.0/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.0/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.0/trifctl_to_tile.F90 index dc668ce21..da03421f0 100644 --- a/lis/surfacemodels/land/jules.5.0/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.0/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/ancil_to_tile.F90 index 6b7dd8769..dfcaf95db 100644 --- a/lis/surfacemodels/land/jules.5.1/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/bvoc_vars_to_tile.F90 index 7db34366e..8bcc25dc6 100644 --- a/lis/surfacemodels/land/jules.5.1/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.1/couple_jules_to_lis.sh index d3330d008..2043f0626 100755 --- a/lis/surfacemodels/land/jules.5.1/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.1/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.1/debug_latlon.F90 index e36a1ec95..295150b63 100644 --- a/lis/surfacemodels/land/jules.5.1/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.1/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/fluxes_to_tile.F90 index 0feb3c166..242f66d11 100644 --- a/lis/surfacemodels/land/jules.5.1/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_coldstart.F90 b/lis/surfacemodels/land/jules.5.1/jules51_coldstart.F90 index 8abf853f4..70cb03694 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_dynsetup.F90 b/lis/surfacemodels/land/jules.5.1/jules51_dynsetup.F90 index 03619949d..1c11bcb2f 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_f2t.F90 b/lis/surfacemodels/land/jules.5.1/jules51_f2t.F90 index 0fc49503e..ce823a4f3 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_finalize.F90 b/lis/surfacemodels/land/jules.5.1/jules51_finalize.F90 index 00591fc0a..f51c96859 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.1/jules51_getrunoffs.F90 index 31199ccd3..81e7d6822 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_initialize.F90 b/lis/surfacemodels/land/jules.5.1/jules51_initialize.F90 index 5bc9e27e8..9b2e0c617 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_lsmMod.F90 b/lis/surfacemodels/land/jules.5.1/jules51_lsmMod.F90 index 8294175a7..c6e822669 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_main.F90 b/lis/surfacemodels/land/jules.5.1/jules51_main.F90 index 5361f7446..e15a54c72 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_main.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_module.F90 b/lis/surfacemodels/land/jules.5.1/jules51_module.F90 index e8f0f639d..17af270eb 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_module.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.1/jules51_read_multilevel_param.F90 index 4921fad4f..560881794 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_readcrd.F90 b/lis/surfacemodels/land/jules.5.1/jules51_readcrd.F90 index ca4c87303..3f022a888 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_readrst.F90 b/lis/surfacemodels/land/jules.5.1/jules51_readrst.F90 index 616e5d679..da2068b82 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_setup.F90 b/lis/surfacemodels/land/jules.5.1/jules51_setup.F90 index 4f268b75b..c454a84d2 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_setup.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules51_writerst.F90 b/lis/surfacemodels/land/jules.5.1/jules51_writerst.F90 index dd06fdd2d..05d98b28f 100644 --- a/lis/surfacemodels/land/jules.5.1/jules51_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules51_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/jules_internal_to_tile.F90 index 6a4d0e5d8..ea48c097b 100644 --- a/lis/surfacemodels/land/jules.5.1/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/jules_lis_exchange.F90 b/lis/surfacemodels/land/jules.5.1/jules_lis_exchange.F90 index 22fbaaee6..7fab94c63 100644 --- a/lis/surfacemodels/land/jules.5.1/jules_lis_exchange.F90 +++ b/lis/surfacemodels/land/jules.5.1/jules_lis_exchange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.1/l_to_rc.F90 index ecbfd2e2b..50e664687 100644 --- a/lis/surfacemodels/land/jules.5.1/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.1/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/lis_control.F90 b/lis/surfacemodels/land/jules.5.1/lis_control.F90 index 26cbb3c14..f6ff68137 100644 --- a/lis/surfacemodels/land/jules.5.1/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.1/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/prog_to_tile.F90 index 60063640a..e624a7cd2 100644 --- a/lis/surfacemodels/land/jules.5.1/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/ps_to_tile.F90 index ccd470763..5a1800105 100644 --- a/lis/surfacemodels/land/jules.5.1/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/sf_diag_to_tile.F90 index e497846cd..28a6b0ca9 100644 --- a/lis/surfacemodels/land/jules.5.1/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_ancil.F90 index 33d9d6614..49227b21d 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_bvoc_vars.F90 index 61baa8c75..7f03e50fc 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_fluxes.F90 index 503d52401..25304d5f9 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_forcing.F90 index 45cad16e1..13fc418a3 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_jules_internal.F90 index cd3a9746c..260b29318 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_prog.F90 index 217c1415a..4f38b583b 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_ps.F90 index 2f392d4cb..a3001d458 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_sf_diag.F90 index 240dbcf51..795fff986 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_top_pdm.F90 index 6d7ce3367..90fad386b 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.1/tile_to_trifctl.F90 index da092a081..e40a5c852 100644 --- a/lis/surfacemodels/land/jules.5.1/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.1/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/top_pdm_to_tile.F90 index 1019a81f5..10ddecc94 100644 --- a/lis/surfacemodels/land/jules.5.1/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.1/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.1/trifctl_to_tile.F90 index fc8ed5106..5c38fb7d6 100644 --- a/lis/surfacemodels/land/jules.5.1/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.1/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/ancil_to_tile.F90 index 69d207e28..783a57379 100644 --- a/lis/surfacemodels/land/jules.5.2/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/bvoc_vars_to_tile.F90 index 97f611660..d9dbf0e85 100644 --- a/lis/surfacemodels/land/jules.5.2/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.2/couple_jules_to_lis.sh index d3330d008..2043f0626 100755 --- a/lis/surfacemodels/land/jules.5.2/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.2/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_dasoilm_Mod.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_dasoilm_Mod.F90 index a836bc795..4d7050385 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_descale_soilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_descale_soilm.F90 index efecce0c0..c8181554e 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_descale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getLbandTbPred.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getLbandTbPred.F90 index d89b3a8ee..898010113 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsmpred.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsmpred.F90 index a23614492..cb5944628 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsmpred.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsoilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsoilm.F90 index 523efa225..2cd4f6427 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qc_soilmobs.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qc_soilmobs.F90 index ad5e0c0ef..bc0bcc60d 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qcsoilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qcsoilm.F90 index a9f6f61ff..d3373903d 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qcsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_scale_soilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_scale_soilm.F90 index 92af8fa90..4bb1d7d0d 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_scale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_setsoilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_setsoilm.F90 index d3c1beeed..12f164b36 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_setsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_updatesoilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_updatesoilm.F90 index adb832bb7..54e86df7b 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_updatesoilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_write_soilm.F90 b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_write_soilm.F90 index 55ff510eb..cfb7e14a6 100644 --- a/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_write_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.2/da_soilm/jules52_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.2/debug_latlon.F90 index e36a1ec95..295150b63 100644 --- a/lis/surfacemodels/land/jules.5.2/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.2/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/fluxes_to_tile.F90 index 567472ce6..bf97e9015 100644 --- a/lis/surfacemodels/land/jules.5.2/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_coldstart.F90 b/lis/surfacemodels/land/jules.5.2/jules52_coldstart.F90 index 21c3b8a5f..36d26ab20 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_dynsetup.F90 b/lis/surfacemodels/land/jules.5.2/jules52_dynsetup.F90 index 5b2b09caa..199d3d544 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_f2t.F90 b/lis/surfacemodels/land/jules.5.2/jules52_f2t.F90 index 042af5e32..5d406885b 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_finalize.F90 b/lis/surfacemodels/land/jules.5.2/jules52_finalize.F90 index c6a45a6ba..de40f95d1 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.2/jules52_getrunoffs.F90 index 40d06e251..2f72c328b 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_initialize.F90 b/lis/surfacemodels/land/jules.5.2/jules52_initialize.F90 index f7046f5ec..cb1d983cd 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_lsmMod.F90 b/lis/surfacemodels/land/jules.5.2/jules52_lsmMod.F90 index eaca8dd58..1119d8c8b 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_main.F90 b/lis/surfacemodels/land/jules.5.2/jules52_main.F90 index b0d19bb2d..ea33131a3 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_main.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_module.F90 b/lis/surfacemodels/land/jules.5.2/jules52_module.F90 index f52f5054b..a9ac3a12f 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_module.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.2/jules52_read_multilevel_param.F90 index 9c4a160af..136aa9e29 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_readcrd.F90 b/lis/surfacemodels/land/jules.5.2/jules52_readcrd.F90 index 4c2c46fa0..19af47359 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_readrst.F90 b/lis/surfacemodels/land/jules.5.2/jules52_readrst.F90 index 5c1d6d9a8..d651fdeb6 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_setup.F90 b/lis/surfacemodels/land/jules.5.2/jules52_setup.F90 index d4101b592..75af7f520 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_setup.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules52_writerst.F90 b/lis/surfacemodels/land/jules.5.2/jules52_writerst.F90 index 141ff4cd8..de55ec0f2 100644 --- a/lis/surfacemodels/land/jules.5.2/jules52_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules52_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/jules_internal_to_tile.F90 index dbc683a44..fa2c3aa3d 100644 --- a/lis/surfacemodels/land/jules.5.2/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/jules_lis_exchange.F90 b/lis/surfacemodels/land/jules.5.2/jules_lis_exchange.F90 index 22fbaaee6..7fab94c63 100644 --- a/lis/surfacemodels/land/jules.5.2/jules_lis_exchange.F90 +++ b/lis/surfacemodels/land/jules.5.2/jules_lis_exchange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.2/l_to_rc.F90 index 876760a77..993d1ad4a 100644 --- a/lis/surfacemodels/land/jules.5.2/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.2/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/lis_control.F90 b/lis/surfacemodels/land/jules.5.2/lis_control.F90 index c8f8e4f55..e897b5e1e 100755 --- a/lis/surfacemodels/land/jules.5.2/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.2/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/prog_to_tile.F90 index be0721908..d3cead31c 100644 --- a/lis/surfacemodels/land/jules.5.2/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/ps_to_tile.F90 index eb4d2b14a..2505ca40e 100644 --- a/lis/surfacemodels/land/jules.5.2/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/routing/jules52_getrunoffs_mm.F90 b/lis/surfacemodels/land/jules.5.2/routing/jules52_getrunoffs_mm.F90 index ea917121e..8c5afb058 100644 --- a/lis/surfacemodels/land/jules.5.2/routing/jules52_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/jules.5.2/routing/jules52_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/sf_diag_to_tile.F90 index e93dbcb04..7e8cbae60 100644 --- a/lis/surfacemodels/land/jules.5.2/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_ancil.F90 index fc64a6572..93d8c595d 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_bvoc_vars.F90 index a77971c16..b290943c5 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_fluxes.F90 index 8e6e68cd4..028081811 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_forcing.F90 index 66482abab..033d177a7 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_jules_internal.F90 index e8abaac66..3afe78582 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_prog.F90 index 2b610ba14..a090cce51 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_ps.F90 index 28a1c4b41..42a32bf0a 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_sf_diag.F90 index 459802ac9..5da9661d4 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_top_pdm.F90 index d6bc248c7..02d8beac8 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.2/tile_to_trifctl.F90 index 9e06fea08..aa17e5d9f 100644 --- a/lis/surfacemodels/land/jules.5.2/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.2/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/top_pdm_to_tile.F90 index 9c65c71f2..d295c7c8f 100644 --- a/lis/surfacemodels/land/jules.5.2/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.2/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.2/trifctl_to_tile.F90 index dfb8e6d06..509931e27 100644 --- a/lis/surfacemodels/land/jules.5.2/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.2/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/ancil_to_tile.F90 index 2e8093b14..beb6c1320 100644 --- a/lis/surfacemodels/land/jules.5.3/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/bvoc_vars_to_tile.F90 index 9a0ef0bc5..cc22bea37 100644 --- a/lis/surfacemodels/land/jules.5.3/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.3/couple_jules_to_lis.sh index 7bf73fe0f..bcaf7636b 100755 --- a/lis/surfacemodels/land/jules.5.3/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.3/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_dasoilm_Mod.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_dasoilm_Mod.F90 index f969703c8..4a34d350f 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_descale_soilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_descale_soilm.F90 index 217862539..787e39fb5 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_descale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getLbandTbPred.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getLbandTbPred.F90 index 09a9d71a0..14d3aa5af 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsmpred.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsmpred.F90 index 031569b0c..18ab01d2a 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsmpred.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsoilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsoilm.F90 index 290b158d8..9ff2db746 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qc_soilmobs.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qc_soilmobs.F90 index 0b99ad04c..ac674cfd5 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qcsoilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qcsoilm.F90 index fc4cdd282..54b3891b0 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qcsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_scale_soilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_scale_soilm.F90 index e52d30b88..78bd703e4 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_scale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_setsoilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_setsoilm.F90 index 49ea15d7d..10fcd58c1 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_setsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_updatesoilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_updatesoilm.F90 index e38c71f55..6d9867272 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_updatesoilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_write_soilm.F90 b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_write_soilm.F90 index 5e5a6ba4e..5ab9042b6 100644 --- a/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_write_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.3/da_soilm/jules53_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.3/debug_latlon.F90 index e36a1ec95..295150b63 100644 --- a/lis/surfacemodels/land/jules.5.3/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.3/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/fluxes_to_tile.F90 index 61a70a43b..c98b7afb2 100644 --- a/lis/surfacemodels/land/jules.5.3/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_coldstart.F90 b/lis/surfacemodels/land/jules.5.3/jules53_coldstart.F90 index 27406d9b2..d25f0b280 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_dynsetup.F90 b/lis/surfacemodels/land/jules.5.3/jules53_dynsetup.F90 index 5033ea3ca..3129e55ef 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_f2t.F90 b/lis/surfacemodels/land/jules.5.3/jules53_f2t.F90 index 0ac28f911..199ad0ad1 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_finalize.F90 b/lis/surfacemodels/land/jules.5.3/jules53_finalize.F90 index 2c9a9d8f8..dcd873dee 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.3/jules53_getrunoffs.F90 index 1913c7a89..e979b8796 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_initialize.F90 b/lis/surfacemodels/land/jules.5.3/jules53_initialize.F90 index 93bad2c22..d762b293b 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_lsmMod.F90 b/lis/surfacemodels/land/jules.5.3/jules53_lsmMod.F90 index c57fdc23b..8319a3d63 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_main.F90 b/lis/surfacemodels/land/jules.5.3/jules53_main.F90 index c9bd32dbf..41097bcc2 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_main.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_module.F90 b/lis/surfacemodels/land/jules.5.3/jules53_module.F90 index 82cb1ffd3..bd52599ef 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_module.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.3/jules53_read_multilevel_param.F90 index f654b5630..5828edf6b 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_readcrd.F90 b/lis/surfacemodels/land/jules.5.3/jules53_readcrd.F90 index 73a83e9c3..09d759afa 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_readrst.F90 b/lis/surfacemodels/land/jules.5.3/jules53_readrst.F90 index 1a812c72b..a9c6945b8 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_setup.F90 b/lis/surfacemodels/land/jules.5.3/jules53_setup.F90 index 1267039b0..f9911cde2 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_setup.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules53_writerst.F90 b/lis/surfacemodels/land/jules.5.3/jules53_writerst.F90 index 73405e42a..d4c2d7b9c 100644 --- a/lis/surfacemodels/land/jules.5.3/jules53_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules53_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/jules_internal_to_tile.F90 index eb311a0e5..e0b71c51b 100644 --- a/lis/surfacemodels/land/jules.5.3/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/jules_lis_exchange.F90 b/lis/surfacemodels/land/jules.5.3/jules_lis_exchange.F90 index 22fbaaee6..7fab94c63 100644 --- a/lis/surfacemodels/land/jules.5.3/jules_lis_exchange.F90 +++ b/lis/surfacemodels/land/jules.5.3/jules_lis_exchange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.3/l_to_rc.F90 index 876760a77..993d1ad4a 100644 --- a/lis/surfacemodels/land/jules.5.3/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.3/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/lis_control.F90 b/lis/surfacemodels/land/jules.5.3/lis_control.F90 index b8aa87100..4e09fa4db 100755 --- a/lis/surfacemodels/land/jules.5.3/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.3/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/prog_to_tile.F90 index e1561796e..d8fb7b51f 100644 --- a/lis/surfacemodels/land/jules.5.3/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/ps_to_tile.F90 index f127a9fd1..b4951b5e2 100644 --- a/lis/surfacemodels/land/jules.5.3/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90 b/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90 index 1504510d6..6ca291b09 100644 --- a/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90.0 b/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90.0 index ea917121e..8c5afb058 100644 --- a/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90.0 +++ b/lis/surfacemodels/land/jules.5.3/routing/jules53_getrunoffs_mm.F90.0 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/sf_diag_to_tile.F90 index 7e8b3dfce..80ecd4fe1 100644 --- a/lis/surfacemodels/land/jules.5.3/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_ancil.F90 index 2cfaf3bb0..f962e1d24 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_bvoc_vars.F90 index 199f3e6b2..2960b597d 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_fluxes.F90 index 64f16abeb..2c100c2ca 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_forcing.F90 index ec78f5a6e..f660b45d6 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_jules_internal.F90 index 13e045b8e..325717007 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_prog.F90 index a9047e42f..e216d036e 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_ps.F90 index e15786939..4f46fcdf0 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_sf_diag.F90 index 1aa10bc68..cd5bbb95f 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_top_pdm.F90 index c943b94f7..70ddeb699 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.3/tile_to_trifctl.F90 index 8f5361d9f..b556ebe62 100644 --- a/lis/surfacemodels/land/jules.5.3/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.3/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/top_pdm_to_tile.F90 index 9f65d6612..dfc4ff881 100644 --- a/lis/surfacemodels/land/jules.5.3/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.3/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.3/trifctl_to_tile.F90 index b2427ac4f..c5fd59209 100644 --- a/lis/surfacemodels/land/jules.5.3/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.3/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/ancil_to_tile.F90 index 18ff7a83e..eb6c12431 100644 --- a/lis/surfacemodels/land/jules.5.4/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/bvoc_vars_to_tile.F90 index c79a4f422..dadeba143 100644 --- a/lis/surfacemodels/land/jules.5.4/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.4/couple_jules_to_lis.sh index 94fa12eb9..cbd207954 100755 --- a/lis/surfacemodels/land/jules.5.4/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.4/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.4/debug_latlon.F90 index e36a1ec95..295150b63 100644 --- a/lis/surfacemodels/land/jules.5.4/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.4/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/fluxes_to_tile.F90 index cb739eb83..75f93d7d6 100644 --- a/lis/surfacemodels/land/jules.5.4/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_coldstart.F90 b/lis/surfacemodels/land/jules.5.4/jules54_coldstart.F90 index 05651a5f3..517ccbd42 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_dynsetup.F90 b/lis/surfacemodels/land/jules.5.4/jules54_dynsetup.F90 index e69b67c0f..995978bfc 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_f2t.F90 b/lis/surfacemodels/land/jules.5.4/jules54_f2t.F90 index d165f361a..3b41ea8d2 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_finalize.F90 b/lis/surfacemodels/land/jules.5.4/jules54_finalize.F90 index e226160c8..27da8a105 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.4/jules54_getrunoffs.F90 index 2e71cc137..3dc116d7a 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_initialize.F90 b/lis/surfacemodels/land/jules.5.4/jules54_initialize.F90 index cba7f54e4..c608b25ba 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_lsmMod.F90 b/lis/surfacemodels/land/jules.5.4/jules54_lsmMod.F90 index 3c763e1e1..d0d260c73 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_main.F90 b/lis/surfacemodels/land/jules.5.4/jules54_main.F90 index e946a27c1..a75b26360 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_main.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_module.F90 b/lis/surfacemodels/land/jules.5.4/jules54_module.F90 index b29088c71..5a0aeb90f 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_module.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.4/jules54_read_multilevel_param.F90 index 3b688ad27..cf6c39545 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_readcrd.F90 b/lis/surfacemodels/land/jules.5.4/jules54_readcrd.F90 index 24727aae2..6e5e1e79f 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_readrst.F90 b/lis/surfacemodels/land/jules.5.4/jules54_readrst.F90 index cba056263..1a12cbacf 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_setup.F90 b/lis/surfacemodels/land/jules.5.4/jules54_setup.F90 index a7b67be1f..99c605944 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_setup.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules54_writerst.F90 b/lis/surfacemodels/land/jules.5.4/jules54_writerst.F90 index 681a0938a..ac2fe631c 100644 --- a/lis/surfacemodels/land/jules.5.4/jules54_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules54_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/jules_internal_to_tile.F90 index 07f4f0c66..d97112a50 100644 --- a/lis/surfacemodels/land/jules.5.4/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/jules_lis_exchange.F90 b/lis/surfacemodels/land/jules.5.4/jules_lis_exchange.F90 index 22fbaaee6..7fab94c63 100644 --- a/lis/surfacemodels/land/jules.5.4/jules_lis_exchange.F90 +++ b/lis/surfacemodels/land/jules.5.4/jules_lis_exchange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.4/l_to_rc.F90 index 876760a77..993d1ad4a 100644 --- a/lis/surfacemodels/land/jules.5.4/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.4/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/lis_control.F90 b/lis/surfacemodels/land/jules.5.4/lis_control.F90 index 9a9cd0b0f..c92d18608 100755 --- a/lis/surfacemodels/land/jules.5.4/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.4/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/prog_to_tile.F90 index 44a9f5a13..6eabe84b6 100644 --- a/lis/surfacemodels/land/jules.5.4/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/ps_to_tile.F90 index 044f17e6e..d2ebbd091 100644 --- a/lis/surfacemodels/land/jules.5.4/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/sf_diag_to_tile.F90 index 054bd8cc5..09d33db75 100644 --- a/lis/surfacemodels/land/jules.5.4/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_ancil.F90 index c8ab6b849..61f7c82cb 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_bvoc_vars.F90 index dd25d3180..df997d952 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_fluxes.F90 index 7a20e3603..8d22b2f74 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_forcing.F90 index cfe123acf..0ffce2bbb 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_jules_internal.F90 index ea61d4f50..9eb5e18aa 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_prog.F90 index 4b421aa08..90fed2fd4 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_ps.F90 index 1076d02c8..c676c5721 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_sf_diag.F90 index 3f59cc204..90be0257c 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_top_pdm.F90 index 189850fe6..bbb356217 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.4/tile_to_trifctl.F90 index 14b60241b..446325cae 100644 --- a/lis/surfacemodels/land/jules.5.4/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.4/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/top_pdm_to_tile.F90 index 1da2f179c..432e28c89 100644 --- a/lis/surfacemodels/land/jules.5.4/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.4/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.4/trifctl_to_tile.F90 index 4b3e50532..add97e938 100644 --- a/lis/surfacemodels/land/jules.5.4/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.4/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/ancil_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/ancil_to_tile.F90 index 82db0e87f..0a76a59f9 100755 --- a/lis/surfacemodels/land/jules.5.x/ancil_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/ancil_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/bvoc_vars_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/bvoc_vars_to_tile.F90 index 9b2af26d2..a10553acf 100755 --- a/lis/surfacemodels/land/jules.5.x/bvoc_vars_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/bvoc_vars_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/couple_jules_to_lis.sh b/lis/surfacemodels/land/jules.5.x/couple_jules_to_lis.sh index 94fa12eb9..cbd207954 100755 --- a/lis/surfacemodels/land/jules.5.x/couple_jules_to_lis.sh +++ b/lis/surfacemodels/land/jules.5.x/couple_jules_to_lis.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_dasnodep_Mod.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_dasnodep_Mod.F90 index f399e3b7c..02bc4a539 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_dasnodep_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_dasnodep_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_descale_snodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_descale_snodep.F90 index ea21b69a8..57cb68e49 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_descale_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodeppred.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodeppred.F90 index d0234fdfe..ad4d1c9ad 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodeppred.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodepvars.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodepvars.F90 index 7cb2adbae..24bf01311 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodepvars.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_map_snodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_map_snodep.F90 index cb5cfbcb7..195d95521 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_map_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qc_snodepobs.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qc_snodepobs.F90 index 256c7fb7c..77a51dba8 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qcsnodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qcsnodep.F90 index 4e4d5b32e..b19fa2d20 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qcsnodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_scale_snodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_scale_snodep.F90 index ed0770def..c14d42627 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_scale_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_setsnodepvars.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_setsnodepvars.F90 index ac1599d3f..d259faca3 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_setsnodepvars.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_snodep_update.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_snodep_update.F90 index 170d1c905..cb2d7fa9e 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_snodep_update.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_snodep_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_transform_snodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_transform_snodep.F90 index c62b7d324..5d01a7900 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_transform_snodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_updatesnodep.F90 b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_updatesnodep.F90 index 384c8d768..d20847fc2 100755 --- a/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_updatesnodep.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_snodep/jules5x_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_dasoilm_Mod.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_dasoilm_Mod.F90 index f4142b6aa..ba9c1ed26 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_descale_soilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_descale_soilm.F90 index e7a8baa1f..5bbf5b339 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_descale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getLbandTbPred.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getLbandTbPred.F90 index f8ff419f0..028e907ed 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsmpred.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsmpred.F90 index cf083d5bf..f82141d22 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsmpred.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsoilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsoilm.F90 index e5004df1c..c14eeaafd 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qc_soilmobs.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qc_soilmobs.F90 index bf0195751..84de07913 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qcsoilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qcsoilm.F90 index 9abfba077..c9cd84f31 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qcsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_scale_soilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_scale_soilm.F90 index 8f53344b8..a4b34309a 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_scale_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_setsoilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_setsoilm.F90 index c8586d9b9..cfbfc5417 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_setsoilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_updatesoilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_updatesoilm.F90 index ab38a0e92..4aa95cd5b 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_updatesoilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_write_soilm.F90 b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_write_soilm.F90 index c7aa548d5..cda9af477 100755 --- a/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_write_soilm.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_soilm/jules5x_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_dausafsi_Mod.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_dausafsi_Mod.F90 index f48cfb061..f0bf60021 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_dausafsi_Mod.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_dausafsi_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_descale_usafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_descale_usafsi.F90 index b31f1a51a..d4c1fa593 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_descale_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_descale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsipred.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsipred.F90 index fd37e6cb2..7a774edfb 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsipred.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsipred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsivars.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsivars.F90 index e6e84ecdf..b03ad6a1e 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsivars.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_getusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_map_usafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_map_usafsi.F90 index 952ec7837..d81a215ec 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_map_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_map_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qc_usafsiobs.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qc_usafsiobs.F90 index 13c844f33..d2b7339a7 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qc_usafsiobs.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qc_usafsiobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qcusafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qcusafsi.F90 index 2fba8c037..abfb3ff0c 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qcusafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_qcusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_scale_usafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_scale_usafsi.F90 index c57b0139c..029d24e6b 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_scale_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_scale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_setusafsivars.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_setusafsivars.F90 index ceea198ec..4eb624b96 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_setusafsivars.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_setusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_transform_usafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_transform_usafsi.F90 index aefceefaf..a1d977ad3 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_transform_usafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_transform_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_updateusafsi.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_updateusafsi.F90 index bd397f80f..2fdec70de 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_updateusafsi.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_updateusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_usafsi_update.F90 b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_usafsi_update.F90 index 7061510a3..46037b79b 100644 --- a/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_usafsi_update.F90 +++ b/lis/surfacemodels/land/jules.5.x/da_usafsi/jules5x_usafsi_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/debug_latlon.F90 b/lis/surfacemodels/land/jules.5.x/debug_latlon.F90 index e36a1ec95..295150b63 100755 --- a/lis/surfacemodels/land/jules.5.x/debug_latlon.F90 +++ b/lis/surfacemodels/land/jules.5.x/debug_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/fluxes_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/fluxes_to_tile.F90 index f9f430137..aa06d9a8d 100755 --- a/lis/surfacemodels/land/jules.5.x/fluxes_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/fluxes_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_coldstart.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_coldstart.F90 index 4c4278220..99de079c9 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_coldstart.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_dynsetup.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_dynsetup.F90 index 9fbe567d0..7a8abf3bf 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_dynsetup.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_f2t.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_f2t.F90 index 1f7bde983..35a639842 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_f2t.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_finalize.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_finalize.F90 index 15bfeb2b7..02e73b85b 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_finalize.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_getrunoffs.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_getrunoffs.F90 index 1d76c4d88..f4899b9ef 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_getrunoffs.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_initialize.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_initialize.F90 index 80a47b3d1..5ba0c5f0d 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_initialize.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_initialize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_lsmMod.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_lsmMod.F90 index a77087a61..307c49aba 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_lsmMod.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_main.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_main.F90 index cf1d86269..5582ae4af 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_main.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_module.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_module.F90 index 06bf5d9f7..c13f82fd8 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_module.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_read_multilevel_param.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_read_multilevel_param.F90 index e588c55cf..363ff1ec1 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_read_multilevel_param.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_read_multilevel_param.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_readcrd.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_readcrd.F90 index 817b7204c..19871155e 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_readcrd.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_readrst.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_readrst.F90 index efd0f3c23..1e45c5cdb 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_readrst.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_setup.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_setup.F90 index 6e9d33e2a..80a9bf21f 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_setup.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules5x_writerst.F90 b/lis/surfacemodels/land/jules.5.x/jules5x_writerst.F90 index e77448bdd..13e26e832 100755 --- a/lis/surfacemodels/land/jules.5.x/jules5x_writerst.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules5x_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules_internal_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/jules_internal_to_tile.F90 index f46ba9c13..792a603dc 100755 --- a/lis/surfacemodels/land/jules.5.x/jules_internal_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules_internal_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/jules_lis_exchange.F90 b/lis/surfacemodels/land/jules.5.x/jules_lis_exchange.F90 index 22fbaaee6..7fab94c63 100755 --- a/lis/surfacemodels/land/jules.5.x/jules_lis_exchange.F90 +++ b/lis/surfacemodels/land/jules.5.x/jules_lis_exchange.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/l_to_rc.F90 b/lis/surfacemodels/land/jules.5.x/l_to_rc.F90 index 876760a77..993d1ad4a 100755 --- a/lis/surfacemodels/land/jules.5.x/l_to_rc.F90 +++ b/lis/surfacemodels/land/jules.5.x/l_to_rc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/lis_control.F90 b/lis/surfacemodels/land/jules.5.x/lis_control.F90 index a5b39428e..084b7fbe3 100755 --- a/lis/surfacemodels/land/jules.5.x/lis_control.F90 +++ b/lis/surfacemodels/land/jules.5.x/lis_control.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/prog_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/prog_to_tile.F90 index 717f1a7ef..e13e887ba 100755 --- a/lis/surfacemodels/land/jules.5.x/prog_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/prog_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/ps_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/ps_to_tile.F90 index abef03b81..70a079676 100755 --- a/lis/surfacemodels/land/jules.5.x/ps_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/ps_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90 b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90 index 1c3e5e4d1..0a699f459 100755 --- a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90.0 b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90.0 index ea917121e..8c5afb058 100755 --- a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90.0 +++ b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_mm.F90.0 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_rapid.F90 b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_rapid.F90 index a13ec5063..f44437825 100755 --- a/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_rapid.F90 +++ b/lis/surfacemodels/land/jules.5.x/routing/jules5x_getrunoffs_rapid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/sf_diag_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/sf_diag_to_tile.F90 index b2c755978..f1fbda92c 100755 --- a/lis/surfacemodels/land/jules.5.x/sf_diag_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/sf_diag_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_ancil.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_ancil.F90 index 88cd92be4..02233c2a4 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_ancil.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_ancil.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_bvoc_vars.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_bvoc_vars.F90 index 983f29d6f..1152af4ea 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_bvoc_vars.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_bvoc_vars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_fluxes.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_fluxes.F90 index 1a979d7d0..d02e13a26 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_fluxes.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_fluxes.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_forcing.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_forcing.F90 index 3c17357df..8775bac85 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_forcing.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_forcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_jules_internal.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_jules_internal.F90 index 61ebb76af..acc37cb0d 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_jules_internal.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_jules_internal.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_prog.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_prog.F90 index 1ba992254..86cd04037 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_prog.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_prog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_ps.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_ps.F90 index 2b29f7a65..c5aea0501 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_ps.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_ps.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_sf_diag.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_sf_diag.F90 index 0a492ec26..fa09b2145 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_sf_diag.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_sf_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_top_pdm.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_top_pdm.F90 index 3c8e8bf12..c2ba825a1 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_top_pdm.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_top_pdm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/tile_to_trifctl.F90 b/lis/surfacemodels/land/jules.5.x/tile_to_trifctl.F90 index f14717068..7aa757a2c 100755 --- a/lis/surfacemodels/land/jules.5.x/tile_to_trifctl.F90 +++ b/lis/surfacemodels/land/jules.5.x/tile_to_trifctl.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/top_pdm_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/top_pdm_to_tile.F90 index 642465190..5cf03fe99 100755 --- a/lis/surfacemodels/land/jules.5.x/top_pdm_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/top_pdm_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/jules.5.x/trifctl_to_tile.F90 b/lis/surfacemodels/land/jules.5.x/trifctl_to_tile.F90 index dcab8fb3b..a5af5d176 100755 --- a/lis/surfacemodels/land/jules.5.x/trifctl_to_tile.F90 +++ b/lis/surfacemodels/land/jules.5.x/trifctl_to_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/0Intro_mosaic.txt b/lis/surfacemodels/land/mosaic/0Intro_mosaic.txt index a5f3b1a69..2a587a84d 100644 --- a/lis/surfacemodels/land/mosaic/0Intro_mosaic.txt +++ b/lis/surfacemodels/land/mosaic/0Intro_mosaic.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_descale_soilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_descale_soilm.F90 index aac85c18a..139805ba6 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_descale_soilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_getsoilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_getsoilm.F90 index c86c53dae..c6ccabe77 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_getsoilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_getsynsmpred.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_getsynsmpred.F90 index 232765f09..fc863c3dc 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_getsynsmpred.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_getsynsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_qcsoilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_qcsoilm.F90 index 98bf88777..4d96a1b8d 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_qcsoilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_scale_soilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_scale_soilm.F90 index 83c1f2e64..c94932a56 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_scale_soilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_setsoilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_setsoilm.F90 index 68d293332..6c7be950f 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_setsoilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_updatesoilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_updatesoilm.F90 index 6465949d9..4b5058389 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_updatesoilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/da_soilm/mos_write_soilm.F90 b/lis/surfacemodels/land/mosaic/da_soilm/mos_write_soilm.F90 index ebd87051b..8ee314c05 100644 --- a/lis/surfacemodels/land/mosaic/da_soilm/mos_write_soilm.F90 +++ b/lis/surfacemodels/land/mosaic/da_soilm/mos_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mapsib2umd.F90 b/lis/surfacemodels/land/mosaic/mapsib2umd.F90 index ad89e15c7..64c2f1d0b 100644 --- a/lis/surfacemodels/land/mosaic/mapsib2umd.F90 +++ b/lis/surfacemodels/land/mosaic/mapsib2umd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_coldstart.F90 b/lis/surfacemodels/land/mosaic/mos_coldstart.F90 index 31939db82..0667ac1a8 100644 --- a/lis/surfacemodels/land/mosaic/mos_coldstart.F90 +++ b/lis/surfacemodels/land/mosaic/mos_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_f2t.F90 b/lis/surfacemodels/land/mosaic/mos_f2t.F90 index ea3ac12b4..ae063e19c 100644 --- a/lis/surfacemodels/land/mosaic/mos_f2t.F90 +++ b/lis/surfacemodels/land/mosaic/mos_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_finalize.F90 b/lis/surfacemodels/land/mosaic/mos_finalize.F90 index 50663a55b..161f4b40d 100644 --- a/lis/surfacemodels/land/mosaic/mos_finalize.F90 +++ b/lis/surfacemodels/land/mosaic/mos_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_lsmMod.F90 b/lis/surfacemodels/land/mosaic/mos_lsmMod.F90 index 6bb43cf1a..4c30f900c 100644 --- a/lis/surfacemodels/land/mosaic/mos_lsmMod.F90 +++ b/lis/surfacemodels/land/mosaic/mos_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_main.F90 b/lis/surfacemodels/land/mosaic/mos_main.F90 index ab6d46331..370967ff0 100644 --- a/lis/surfacemodels/land/mosaic/mos_main.F90 +++ b/lis/surfacemodels/land/mosaic/mos_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_module.F90 b/lis/surfacemodels/land/mosaic/mos_module.F90 index 5ed4fca7b..014b3e76e 100644 --- a/lis/surfacemodels/land/mosaic/mos_module.F90 +++ b/lis/surfacemodels/land/mosaic/mos_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_readrestart.F90 b/lis/surfacemodels/land/mosaic/mos_readrestart.F90 index 9022ad7e0..3cb92026a 100644 --- a/lis/surfacemodels/land/mosaic/mos_readrestart.F90 +++ b/lis/surfacemodels/land/mosaic/mos_readrestart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_setup.F90 b/lis/surfacemodels/land/mosaic/mos_setup.F90 index daec5dd58..ac6336e4f 100644 --- a/lis/surfacemodels/land/mosaic/mos_setup.F90 +++ b/lis/surfacemodels/land/mosaic/mos_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_tile.F90 b/lis/surfacemodels/land/mosaic/mos_tile.F90 index 2af44fc31..350e4ee9e 100644 --- a/lis/surfacemodels/land/mosaic/mos_tile.F90 +++ b/lis/surfacemodels/land/mosaic/mos_tile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mos_writerst.F90 b/lis/surfacemodels/land/mosaic/mos_writerst.F90 index 219bb1957..f493cf976 100644 --- a/lis/surfacemodels/land/mosaic/mos_writerst.F90 +++ b/lis/surfacemodels/land/mosaic/mos_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/mosdynp.F90 b/lis/surfacemodels/land/mosaic/mosdynp.F90 index e8d48d0a0..11e702682 100644 --- a/lis/surfacemodels/land/mosaic/mosdynp.F90 +++ b/lis/surfacemodels/land/mosaic/mosdynp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/moslairead.F90.notemp b/lis/surfacemodels/land/mosaic/moslairead.F90.notemp index 769f2c464..a42737b83 100644 --- a/lis/surfacemodels/land/mosaic/moslairead.F90.notemp +++ b/lis/surfacemodels/land/mosaic/moslairead.F90.notemp @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/paramb.F90 b/lis/surfacemodels/land/mosaic/paramb.F90 index 396c1a719..83e3ecc57 100644 --- a/lis/surfacemodels/land/mosaic/paramb.F90 +++ b/lis/surfacemodels/land/mosaic/paramb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/readmoscrd.F90 b/lis/surfacemodels/land/mosaic/readmoscrd.F90 index 15cb5e11a..cf5b184a5 100644 --- a/lis/surfacemodels/land/mosaic/readmoscrd.F90 +++ b/lis/surfacemodels/land/mosaic/readmoscrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/setmosp.F90 b/lis/surfacemodels/land/mosaic/setmosp.F90 index 968be7aa2..91cbb2622 100644 --- a/lis/surfacemodels/land/mosaic/setmosp.F90 +++ b/lis/surfacemodels/land/mosaic/setmosp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/sfc_cmem3/mos_sfc2cmem3.F90 b/lis/surfacemodels/land/mosaic/sfc_cmem3/mos_sfc2cmem3.F90 index fa53dd420..f54f90653 100644 --- a/lis/surfacemodels/land/mosaic/sfc_cmem3/mos_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/mosaic/sfc_cmem3/mos_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/sibalb_module.F90 b/lis/surfacemodels/land/mosaic/sibalb_module.F90 index dd9dcf51b..4f227371b 100644 --- a/lis/surfacemodels/land/mosaic/sibalb_module.F90 +++ b/lis/surfacemodels/land/mosaic/sibalb_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/texture.F90 b/lis/surfacemodels/land/mosaic/texture.F90 index 4afd38e8f..2fd5672bb 100644 --- a/lis/surfacemodels/land/mosaic/texture.F90 +++ b/lis/surfacemodels/land/mosaic/texture.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/mosaic/umd_sibalb.F90 b/lis/surfacemodels/land/mosaic/umd_sibalb.F90 index 1381fb10d..16f578157 100644 --- a/lis/surfacemodels/land/mosaic/umd_sibalb.F90 +++ b/lis/surfacemodels/land/mosaic/umd_sibalb.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/0Intro_noah271.txt b/lis/surfacemodels/land/noah.2.7.1/0Intro_noah271.txt index 001301481..f74ac5a56 100644 --- a/lis/surfacemodels/land/noah.2.7.1/0Intro_noah271.txt +++ b/lis/surfacemodels/land/noah.2.7.1/0Intro_noah271.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.old b/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.old index 6a5298e9b..094ee2bab 100755 --- a/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.old +++ b/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.wrf b/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.wrf index 3d3ae5f95..a395b1550 100755 --- a/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.wrf +++ b/lis/surfacemodels/land/noah.2.7.1/SFLXALL_SRC_VER_2.7.1.F90.wrf @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_gce_f2t.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_gce_f2t.F90 index 78821213b..a17e54ec4 100644 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_gce_f2t.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_gce_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_setgceexport.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_setgceexport.F90 index f2351f5e4..5ee6be42b 100755 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_setgceexport.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_gce/noah271_setgceexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_setwrfesmfexport.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_setwrfesmfexport.F90 index ef2a761da..4945bb818 100755 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_setwrfesmfexport.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_setwrfesmfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_wrf_esmff2t.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_wrf_esmff2t.F90 index ce27eb639..08a3add69 100644 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_wrf_esmff2t.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_esmf/noah271_wrf_esmff2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_setwrfexport.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_setwrfexport.F90 index 43401f89e..e5960c067 100755 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_setwrfexport.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_wrf_f2t.F90 b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_wrf_f2t.F90 index bdaa84b9d..2875690ab 100755 --- a/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_wrf_f2t.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/cpl_wrf_noesmf/noah271_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_descale_multism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_descale_multism.F90 index 7f8a0a288..e4fe2c03a 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_descale_multism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_descale_multism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultism.F90 index 086cf9bb9..e4c93c4f1 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultismpred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultismpred.F90 index 6fd343152..62c9a3ba6 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultismpred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_getmultismpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_qcmultism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_qcmultism.F90 index 555d093c8..64b994320 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_qcmultism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_qcmultism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_scale_multism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_scale_multism.F90 index fc3c0a640..13fe50e1b 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_scale_multism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_scale_multism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_setmultism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_setmultism.F90 index 42eb581d6..07c16444e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_setmultism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_setmultism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_updatemultism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_updatemultism.F90 index 4e17b3e5a..8390060c6 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_updatemultism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_updatemultism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_write_multism.F90 b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_write_multism.F90 index 1ff858f72..e4ad4a498 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_write_multism.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_multism/noah271_write_multism.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_descale_scf.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_descale_scf.F90 index dea721003..6e398ab34 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_descale_scf.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_descale_scf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfpred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfpred.F90 index 0972d811b..fbd306d1a 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfpred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfvars.F90 index ce1c59cd9..d95c6d026 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_getscfvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_map_scf.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_map_scf.F90 index e73208ac6..ed987a13b 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_map_scf.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_map_scf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_qc_scf.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_qc_scf.F90 index 157ce9907..fd585d5b8 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_qc_scf.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_qc_scf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_scale_scf.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_scale_scf.F90 index 25e157a82..8a1646d6f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_scale_scf.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_scale_scf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_setscfvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_setscfvars.F90 index 6b6474c4b..7d74f112b 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_setscfvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_setscfvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_transform_scf.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_transform_scf.F90 index 47326278f..aa245411e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_transform_scf.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_transform_scf.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_updatescfvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_updatescfvars.F90 index 1c7b56be2..ad771b8a9 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_updatescfvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_scf/noah271_updatescfvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_dasnow_Mod.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_dasnow_Mod.F90 index 22161084d..4975aa09e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_getsnodepvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_getsnodepvars.F90 index 6edbf9d7c..3c2e6fccf 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_map_snodep.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_map_snodep.F90 index 083d0953d..bbf6275a9 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_map_snodep.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_qcsnodep.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_qcsnodep.F90 index 8647d1e15..cc046140e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_qcsnodep.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_setsnodepvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_setsnodepvars.F90 index 8f84a62d4..f51099b22 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_transform_snodep.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_transform_snodep.F90 index 57c207cb5..02febd9a6 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_transform_snodep.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_updatesnodep.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_updatesnodep.F90 index 5419ba7a8..312a7b948 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_updatesnodep.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snodep/noah271_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_descale_snow.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_descale_snow.F90 index f84186d1b..67a0a7c48 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_descale_snow.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getscapred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getscapred.F90 index 6c3fef4a3..7903d497d 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getscapred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getscapred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsnowvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsnowvars.F90 index bf4ae108e..c0dbc10d1 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsnowvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsynswepred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsynswepred.F90 index 9d2fa0980..09ec02292 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsynswepred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_getsynswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_snow.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_snow.F90 index 93caa5efc..aedb6dfb1 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_snow.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_swe.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_swe.F90 index edfa39ac8..0b06bc477 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_swe.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_map_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qc_snowobs.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qc_snowobs.F90 index b1704d0c0..c44ed3fa0 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qcsnow.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qcsnow.F90 index a8f8719ec..3eff05a25 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qcsnow.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_scale_snow.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_scale_snow.F90 index 0f3880714..01fd0b7ef 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_scale_snow.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_setsnowvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_setsnowvars.F90 index 83b9048b9..9403f39ea 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_setsnowvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_transform_snow.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_transform_snow.F90 index 38544c73c..75d7b5024 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_transform_snow.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_transform_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_updatesnowvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_updatesnowvars.F90 index 19a519435..561f49b44 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_wrtswe.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_wrtswe.F90 index 83d6919c1..02a256498 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_wrtswe.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snow/noah271_wrtswe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_descale_snwd.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_descale_snwd.F90 index 79bc26f9b..b9eeff97a 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_descale_snwd.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_descale_snwd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdpred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdpred.F90 index 68e3a9fc9..ce5194c0c 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdpred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdvars.F90 index 2f24f2628..4e3aa91dd 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_getsnwdvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_qcsnwd.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_qcsnwd.F90 index 1c31bacf6..f0adf458f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_qcsnwd.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_qcsnwd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_scale_snwd.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_scale_snwd.F90 index f9581166f..4945eb78e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_scale_snwd.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_scale_snwd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_setsnwdvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_setsnwdvars.F90 index d0128115c..dd5c1e159 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_setsnwdvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_setsnwdvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_updatesnwdvars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_updatesnwdvars.F90 index 6b3e64a46..bc8a0bafe 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_updatesnwdvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_snwd/noah271_updatesnwdvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_descale_soilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_descale_soilm.F90 index fec11c4fc..173aa444a 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_descale_soilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsoilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsoilm.F90 index 8a1d1544c..4738218e3 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsoilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsynsmpred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsynsmpred.F90 index 71f79d3f7..d78f8442d 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsynsmpred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_getsynsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_map_sm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_map_sm.F90 index 63d2e0cf2..50f32378f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_map_sm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_map_sm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qc_soilmobs.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qc_soilmobs.F90 index 53624a2dd..07428be9a 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qcsoilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qcsoilm.F90 index 5060a5bbe..a056173ce 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qcsoilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_scale_soilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_scale_soilm.F90 index b388a9540..7c2fe3f8d 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_scale_soilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_setsoilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_setsoilm.F90 index e439334c2..18c3feac0 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_setsoilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_transform_synsm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_transform_synsm.F90 index a9e904cef..9a27687b3 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_transform_synsm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_transform_synsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_updatesoilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_updatesoilm.F90 index 59da3e30e..9d23a6556 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_updatesoilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_write_soilm.F90 b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_write_soilm.F90 index 3008daa57..c140997ad 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_write_soilm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_soilm/noah271_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_descale_swe.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_descale_swe.F90 index 018aab468..092d9490e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_descale_swe.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_descale_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswepred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswepred.F90 index 4a54d0f12..1c7ac69e3 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswepred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswevars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswevars.F90 index cd78b5559..bcc40ba46 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswevars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_getswevars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_qcswe.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_qcswe.F90 index dda05264c..a26ba1002 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_qcswe.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_qcswe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_scale_swe.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_scale_swe.F90 index 94bd3f8ab..616c30e5f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_scale_swe.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_scale_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_setswevars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_setswevars.F90 index 4e3f82a8e..ddfe3f79c 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_setswevars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_setswevars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_updateswevars.F90 b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_updateswevars.F90 index 8818728fa..2fd8b81d8 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_updateswevars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_swe/noah271_updateswevars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_descale_tskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_descale_tskin.F90 index 6cc910bf9..a85a27d66 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_descale_tskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_descale_tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_getTskinPred.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_getTskinPred.F90 index e04e8ddd7..c529155fb 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_getTskinPred.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_getTskinPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_gettskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_gettskin.F90 index b548a53fb..725804257 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_gettskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_gettskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qc_tskinobs.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qc_tskinobs.F90 index 282006216..6439b47d5 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qc_tskinobs.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qc_tskinobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qctskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qctskin.F90 index 55e2fadc8..c1c7a6d4b 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qctskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_qctskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_scale_tskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_scale_tskin.F90 index f86fe9d6e..f6b33ea31 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_scale_tskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_scale_tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_settskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_settskin.F90 index 6be76b453..cacba28fc 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_settskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_settskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_update_tskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_update_tskin.F90 index 76af36223..afaf4d7e0 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_update_tskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_update_tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_wrttskin.F90 b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_wrttskin.F90 index f62809f7d..7481a705d 100644 --- a/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_wrttskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/da_tskin/noah271_wrttskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/module_sf_noah271lsm.F90 b/lis/surfacemodels/land/noah.2.7.1/module_sf_noah271lsm.F90 index d2b7ea35d..2cf6da2d0 100755 --- a/lis/surfacemodels/land/noah.2.7.1/module_sf_noah271lsm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/module_sf_noah271lsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_calc_tskin.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_calc_tskin.F90 index 5ca6a5328..de87f8a0f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_calc_tskin.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_calc_tskin.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_coldstart.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_coldstart.F90 index bbef164dc..f449386b0 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_coldstart.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_dynsetup.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_dynsetup.F90 index 35b81ea45..ea66ac52b 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_dynsetup.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_f2t.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_f2t.F90 index 89bf5f6a3..b753b955d 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_f2t.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_finalize.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_finalize.F90 index a430b01f6..0d4b15be9 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_finalize.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_lsmMod.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_lsmMod.F90 index 46167a1b7..459bc7047 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_main.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_main.F90 index 2ff7650ba..24bd883e8 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_main.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_module.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_module.F90 index f44613890..a1b0fb1bb 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_module.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_readcrd.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_readcrd.F90 index 411f84cd2..8fd15724f 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_readcrd.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_readrst.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_readrst.F90 index 44b11833f..ea3ea18f2 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_readrst.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_setsoils.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_setsoils.F90 index 2318ad587..a756b4a95 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_setsoils.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_setsoils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_settbot.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_settbot.F90 index e7eb29f94..c4042c8ce 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_settbot.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_setup.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_setup.F90 index 351833282..57ca98901 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_setup.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_setvegparms.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_setvegparms.F90 index d1e4ad3e4..e4f937dad 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_setvegparms.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/noah271_writerst.F90 b/lis/surfacemodels/land/noah.2.7.1/noah271_writerst.F90 index 0ff7edd43..394cf9bc3 100644 --- a/lis/surfacemodels/land/noah.2.7.1/noah271_writerst.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/noah271_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_getpeobspred_wgPBMRsm.F90 b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_getpeobspred_wgPBMRsm.F90 index 7022bc8a3..bc14b11ef 100644 --- a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_getpeobspred_wgPBMRsm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_getpeobspred_wgPBMRsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_peMod.F90 b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_peMod.F90 index ed7bb9360..62c6365dd 100644 --- a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_peMod.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_set_pedecvars.F90 b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_set_pedecvars.F90 index 87e7f9c60..e74b0a30e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_setupobspred_wgPBMRsm.F90 b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_setupobspred_wgPBMRsm.F90 index 581caf806..620903a1e 100644 --- a/lis/surfacemodels/land/noah.2.7.1/pe/noah271_setupobspred_wgPBMRsm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/pe/noah271_setupobspred_wgPBMRsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs.F90 b/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs.F90 index 3bb2fac4b..62d3d5daa 100644 --- a/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs_mm.F90 b/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs_mm.F90 index 6867f6b6e..6d22259ab 100644 --- a/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/routing/noah271_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/sfc_cmem3/noah271_sfc2cmem3.F90 b/lis/surfacemodels/land/noah.2.7.1/sfc_cmem3/noah271_sfc2cmem3.F90 index abfd7269e..1b9d66442 100644 --- a/lis/surfacemodels/land/noah.2.7.1/sfc_cmem3/noah271_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/sfc_cmem3/noah271_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.2.7.1/sfc_crtm/noah271_sfc2crtm.F90 b/lis/surfacemodels/land/noah.2.7.1/sfc_crtm/noah271_sfc2crtm.F90 index 7ca0fee1b..70aec1462 100644 --- a/lis/surfacemodels/land/noah.2.7.1/sfc_crtm/noah271_sfc2crtm.F90 +++ b/lis/surfacemodels/land/noah.2.7.1/sfc_crtm/noah271_sfc2crtm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_setwrfexport.F90 b/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_setwrfexport.F90 index 5577c5492..acbad1187 100755 --- a/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_setwrfexport.F90 +++ b/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_wrf_f2t.F90 b/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_wrf_f2t.F90 index 79f4fb949..72b334e9d 100644 --- a/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_wrf_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.2/cpl_wrf_noesmf/noah32_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_getsnodepvars.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_getsnodepvars.F90 index 42122661c..38844fbd4 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_map_snodep.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_map_snodep.F90 index a2679e470..3f7eb006b 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_map_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_qcsnodep.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_qcsnodep.F90 index 23d3e7235..31a7e44c4 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_qcsnodep.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_setsnodepvars.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_setsnodepvars.F90 index e19361162..2c0cba57c 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_transform_snodep.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_transform_snodep.F90 index b670e8cf0..443f13b98 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_transform_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_updatesnodep.F90 b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_updatesnodep.F90 index 0862d11ee..ad902909a 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_updatesnodep.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snodep/noah32_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_dascf_Mod.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_dascf_Mod.F90 index 6682d65f4..5b94d760a 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_dascf_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_dascf_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_descale_snow.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_descale_snow.F90 index 42e23eef0..f5c50e3fa 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_descale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnowvars.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnowvars.F90 index 291a0fd07..61fc6d9f2 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnwdpred.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnwdpred.F90 index b22595a4b..31415805e 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnwdpred.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getswepred.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getswepred.F90 index cd3bc8ad4..744990298 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getswepred.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_snow.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_snow.F90 index 512d9afe7..4b3b06ffa 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_snow.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_swe.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_swe.F90 index 359a8bb4b..4cc6d678f 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_swe.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_map_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qc_snowobs.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qc_snowobs.F90 index 255e7e51f..4d85650e8 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qcsnow.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qcsnow.F90 index 3fded8b9d..2e5f359b8 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qcsnow.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_scale_snow.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_scale_snow.F90 index 608f319a0..0b967834a 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_scale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_setsnowvars.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_setsnowvars.F90 index 93c3e2779..76f9e60cb 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_setsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_transform_snow.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_transform_snow.F90 index a608c87e3..f232d242a 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_transform_snow.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_transform_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_updatesnowvars.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_updatesnowvars.F90 index 1407828e2..d5680fde5 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_wrtswe.F90 b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_wrtswe.F90 index cd37a2ea5..9c769f97e 100644 --- a/lis/surfacemodels/land/noah.3.2/da_snow/noah32_wrtswe.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_snow/noah32_wrtswe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_descale_soilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_descale_soilm.F90 index b4bddd5c2..199ce464c 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_descale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsmpred.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsmpred.F90 index 310faabff..0ebb7d0fe 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsmpred.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsoilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsoilm.F90 index bb2d3912f..59e08be37 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qc_soilmobs.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qc_soilmobs.F90 index 576b7bbd1..7767a024a 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qcsoilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qcsoilm.F90 index 2d038bb0b..2e010b825 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qcsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_scale_soilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_scale_soilm.F90 index 740494e31..97e1a7ea4 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_scale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_setsoilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_setsoilm.F90 index 82fe7e115..e807799bf 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_setsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_updatesoilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_updatesoilm.F90 index e4ee03749..99f238e13 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_updatesoilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_write_soilm.F90 b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_write_soilm.F90 index 457b582b5..e7ad361a8 100644 --- a/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_write_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.2/da_soilm/noah32_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/module_model_constants_32.F90 b/lis/surfacemodels/land/noah.3.2/module_model_constants_32.F90 index cd15e98ab..025f5dee6 100644 --- a/lis/surfacemodels/land/noah.3.2/module_model_constants_32.F90 +++ b/lis/surfacemodels/land/noah.3.2/module_model_constants_32.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/module_sf_noah32lsm.F90 b/lis/surfacemodels/land/noah.3.2/module_sf_noah32lsm.F90 index a1fb75ab6..53b66e6ec 100644 --- a/lis/surfacemodels/land/noah.3.2/module_sf_noah32lsm.F90 +++ b/lis/surfacemodels/land/noah.3.2/module_sf_noah32lsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/module_sfcdif_wrf_32.F90 b/lis/surfacemodels/land/noah.3.2/module_sfcdif_wrf_32.F90 index b56d34b8b..7d36a3a0d 100644 --- a/lis/surfacemodels/land/noah.3.2/module_sfcdif_wrf_32.F90 +++ b/lis/surfacemodels/land/noah.3.2/module_sfcdif_wrf_32.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_coldstart.F90 b/lis/surfacemodels/land/noah.3.2/noah32_coldstart.F90 index feb34469a..8364111fe 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_coldstart.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_dynsetup.F90 b/lis/surfacemodels/land/noah.3.2/noah32_dynsetup.F90 index 64ee1acf6..3892b5d3e 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_dynsetup.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_f2t.F90 b/lis/surfacemodels/land/noah.3.2/noah32_f2t.F90 index 73da96235..a14bdd85c 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_finalize.F90 b/lis/surfacemodels/land/noah.3.2/noah32_finalize.F90 index e7081d2ea..ec0cca886 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_finalize.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_lsmMod.F90 b/lis/surfacemodels/land/noah.3.2/noah32_lsmMod.F90 index edb8b7a73..0f3362934 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_main.F90 b/lis/surfacemodels/land/noah.3.2/noah32_main.F90 index 5af82542f..c74a83773 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_main.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_module.F90 b/lis/surfacemodels/land/noah.3.2/noah32_module.F90 index d1cf5deea..a52f40c37 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_module.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_readcrd.F90 b/lis/surfacemodels/land/noah.3.2/noah32_readcrd.F90 index 5fbb59685..0411bd169 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_readcrd.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_readrst.F90 b/lis/surfacemodels/land/noah.3.2/noah32_readrst.F90 index fc84ac76c..573659e13 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_readrst.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_setsoils.F90 b/lis/surfacemodels/land/noah.3.2/noah32_setsoils.F90 index c9ae402e4..ce0bdd6eb 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_setsoils.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_setsoils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_settbot.F90 b/lis/surfacemodels/land/noah.3.2/noah32_settbot.F90 index fd0a4e8fb..3902993c2 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_settbot.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_setup.F90 b/lis/surfacemodels/land/noah.3.2/noah32_setup.F90 index a60a8a445..f8e99133f 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_setup.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_setvegparms.F90 b/lis/surfacemodels/land/noah.3.2/noah32_setvegparms.F90 index 46b85a06a..a440fa902 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_setvegparms.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/noah32_writerst.F90 b/lis/surfacemodels/land/noah.3.2/noah32_writerst.F90 index 51aa89d78..a37a6d0e3 100644 --- a/lis/surfacemodels/land/noah.3.2/noah32_writerst.F90 +++ b/lis/surfacemodels/land/noah.3.2/noah32_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_ARMobs.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_ARMobs.F90 index c862e638c..4f73128b5 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_ARMobs.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_ARMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_template.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_template.F90 index ba735acdb..b9abc569f 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_template.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_getpeobspred_template.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_peMod.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_peMod.F90 index ef323ef09..422b6d1db 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_peMod.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_set_pedecvars.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_set_pedecvars.F90 index 197c001af..f8cfa28b1 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_ARMobs.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_ARMobs.F90 index 92f06ef52..3f5e09524 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_ARMobs.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_ARMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_template.F90 b/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_template.F90 index f7b8c929f..a2aeaf982 100644 --- a/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_template.F90 +++ b/lis/surfacemodels/land/noah.3.2/pe/noah32_setupobspred_template.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs.F90 b/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs.F90 index caaa24317..9007ed92c 100644 --- a/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs.F90 +++ b/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs_mm.F90 b/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs_mm.F90 index c36a49bb6..784bb85ad 100644 --- a/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noah.3.2/routing/noah32_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/sfc_cmem3/noah32_sfc2cmem3.F90 b/lis/surfacemodels/land/noah.3.2/sfc_cmem3/noah32_sfc2cmem3.F90 index 210d1ce5b..65c8b41e9 100644 --- a/lis/surfacemodels/land/noah.3.2/sfc_cmem3/noah32_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/noah.3.2/sfc_cmem3/noah32_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.2/sfc_crtm/noah32_sfc2crtm.F90 b/lis/surfacemodels/land/noah.3.2/sfc_crtm/noah32_sfc2crtm.F90 index 17dfda444..03a217b08 100644 --- a/lis/surfacemodels/land/noah.3.2/sfc_crtm/noah32_sfc2crtm.F90 +++ b/lis/surfacemodels/land/noah.3.2/sfc_crtm/noah32_sfc2crtm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_setwrfexport.F90 b/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_setwrfexport.F90 index ef8ac5ff6..147c02043 100644 --- a/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_setwrfexport.F90 +++ b/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_wrf_f2t.F90 b/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_wrf_f2t.F90 index 83019b375..69bdbebd3 100644 --- a/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_wrf_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.3/cpl_wrf_noesmf/noah33_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_descale_snodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_descale_snodep.F90 index 0ae6d6b8f..0c482f3f6 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_descale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodeppred.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodeppred.F90 index 88a13fbcb..49ff0ca33 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodeppred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodepvars.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodepvars.F90 index 85d67063a..4c6832d72 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_map_snodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_map_snodep.F90 index b0b04c06e..eef12d05a 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_map_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qc_snodepobs.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qc_snodepobs.F90 index af1907b31..f6f0d5b06 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qcsnodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qcsnodep.F90 index 5c316166d..b690ce7e1 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qcsnodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_scale_snodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_scale_snodep.F90 index 59801a660..09f85dd6e 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_scale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_setsnodepvars.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_setsnodepvars.F90 index 06b379841..e325b829f 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_transform_snodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_transform_snodep.F90 index eae3fe08c..15153d60c 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_transform_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_updatesnodep.F90 b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_updatesnodep.F90 index 501ecf68c..5302045d0 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_updatesnodep.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snodep/noah33_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_dasnow_Mod.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_dasnow_Mod.F90 index 1be0601d5..9ff91f8ae 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_descale_snow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_descale_snow.F90 index 7f62fbb35..9ccc3daad 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_descale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getscfpred.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getscfpred.F90 index a0c80618c..32d0f3bf4 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getscfpred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getscfpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowpred_PMWsnow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowpred_PMWsnow.F90 index c85362c25..2437633b7 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowpred_PMWsnow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowpred_PMWsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowvars.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowvars.F90 index 8c4fe09a4..13d1e3410 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnwdpred.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnwdpred.F90 index 85a1d5fcd..0adcd1b9f 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnwdpred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getswepred.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getswepred.F90 index 39eaade48..01ca35aaf 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getswepred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow.F90 index 33935fb83..beee72529 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow_DI.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow_DI.F90 index 0335b0fa9..4430fd3fc 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow_DI.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_snow_DI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_swe.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_swe.F90 index 127d02635..5e548a0a4 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_swe.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_map_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_PMWsnowobs.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_PMWsnowobs.F90 index 3cbf50ef7..16c51c943 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_PMWsnowobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_PMWsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_scfobs.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_scfobs.F90 index 381a903a1..331a4e6ed 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_scfobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_scfobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_snowobs.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_snowobs.F90 index 0ae0f7307..04110c3c2 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qcsnow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qcsnow.F90 index 80a4f7735..380520853 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qcsnow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_scale_snow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_scale_snow.F90 index 742f6fa8a..61c0d02be 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_scale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_setsnowvars.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_setsnowvars.F90 index 260e673b3..d7c227d4f 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_setsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_transform_snow.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_transform_snow.F90 index eee08f487..643a9e541 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_transform_snow.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_transform_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars.F90 index 2b2b2cefa..3d55fa30a 100644 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars_scfda.F90 b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars_scfda.F90 index 92e756886..1dfa48940 100755 --- a/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars_scfda.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_snow/noah33_updatesnowvars_scfda.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_dasoilm_Mod.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_dasoilm_Mod.F90 index 066e59af8..937c68beb 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_descale_soilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_descale_soilm.F90 index 898021991..4c327b1a1 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_descale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getLbandTbPred.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getLbandTbPred.F90 index 441d0e351..fc6a61f25 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsmpred.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsmpred.F90 index c0c819e45..4259f8930 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsmpred.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsoilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsoilm.F90 index e29e5fde6..ad3ced9ed 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qc_soilmobs.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qc_soilmobs.F90 index 811a280ab..8512fc087 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qcsoilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qcsoilm.F90 index 18cbe9e01..52749227d 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qcsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_scale_soilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_scale_soilm.F90 index 07e660d6c..d9499e076 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_scale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_setsoilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_setsoilm.F90 index 02950873a..d872b2aff 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_setsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_updatesoilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_updatesoilm.F90 index bf0f117e5..e960d0265 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_updatesoilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_write_soilm.F90 b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_write_soilm.F90 index 38327bfa5..b2d2c0e86 100644 --- a/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_write_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.3/da_soilm/noah33_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/irrigation/noah33_getirrigationstates.F90 b/lis/surfacemodels/land/noah.3.3/irrigation/noah33_getirrigationstates.F90 index 744d59c09..bf1b878ed 100644 --- a/lis/surfacemodels/land/noah.3.3/irrigation/noah33_getirrigationstates.F90 +++ b/lis/surfacemodels/land/noah.3.3/irrigation/noah33_getirrigationstates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/module_model_constants_33.F90 b/lis/surfacemodels/land/noah.3.3/module_model_constants_33.F90 index 73d17636a..e618678b0 100644 --- a/lis/surfacemodels/land/noah.3.3/module_model_constants_33.F90 +++ b/lis/surfacemodels/land/noah.3.3/module_model_constants_33.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm.F90 b/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm.F90 index cdbf14ba8..5b6c652ae 100644 --- a/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm.F90 +++ b/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm_glacial.F90 b/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm_glacial.F90 index 8fa955dfc..2bd1c047d 100644 --- a/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm_glacial.F90 +++ b/lis/surfacemodels/land/noah.3.3/module_sf_noah33lsm_glacial.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/module_sfcdif_wrf_33.F90 b/lis/surfacemodels/land/noah.3.3/module_sfcdif_wrf_33.F90 index c7165c924..f46a9ce7e 100644 --- a/lis/surfacemodels/land/noah.3.3/module_sfcdif_wrf_33.F90 +++ b/lis/surfacemodels/land/noah.3.3/module_sfcdif_wrf_33.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_coldstart.F90 b/lis/surfacemodels/land/noah.3.3/noah33_coldstart.F90 index cf5b0bb50..af1c7c4d3 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_coldstart.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_dynsetup.F90 b/lis/surfacemodels/land/noah.3.3/noah33_dynsetup.F90 index d15b2633c..c26f47649 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_dynsetup.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_f2t.F90 b/lis/surfacemodels/land/noah.3.3/noah33_f2t.F90 index 8f9adfee4..c78776a65 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_finalize.F90 b/lis/surfacemodels/land/noah.3.3/noah33_finalize.F90 index 04bf6275a..29f52522c 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_finalize.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_lsmMod.F90 b/lis/surfacemodels/land/noah.3.3/noah33_lsmMod.F90 index a546401bd..3ca38fcbb 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_main.F90 b/lis/surfacemodels/land/noah.3.3/noah33_main.F90 index 0e7c4f25d..0e74fd451 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_main.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_module.F90 b/lis/surfacemodels/land/noah.3.3/noah33_module.F90 index f652b855d..22db934d3 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_module.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_readcrd.F90 b/lis/surfacemodels/land/noah.3.3/noah33_readcrd.F90 index 4e0fe3e0a..6327d6915 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_readcrd.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_readrst.F90 b/lis/surfacemodels/land/noah.3.3/noah33_readrst.F90 index db731ceb3..1c2494eb8 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_readrst.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_reset.F90 b/lis/surfacemodels/land/noah.3.3/noah33_reset.F90 index 0085e5ae7..3dbbb458d 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_reset.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_setsoils.F90 b/lis/surfacemodels/land/noah.3.3/noah33_setsoils.F90 index 6fc588c17..797453887 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_setsoils.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_setsoils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_settbot.F90 b/lis/surfacemodels/land/noah.3.3/noah33_settbot.F90 index 3f9f41a53..32c41e57a 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_settbot.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_setup.F90 b/lis/surfacemodels/land/noah.3.3/noah33_setup.F90 index 69734916d..c08cb8324 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_setup.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_setvegparms.F90 b/lis/surfacemodels/land/noah.3.3/noah33_setvegparms.F90 index 9c45e616f..2d3fab51f 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_setvegparms.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/noah33_writerst.F90 b/lis/surfacemodels/land/noah.3.3/noah33_writerst.F90 index 9133657cb..77a857f95 100644 --- a/lis/surfacemodels/land/noah.3.3/noah33_writerst.F90 +++ b/lis/surfacemodels/land/noah.3.3/noah33_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/noah33_peMod.F90 b/lis/surfacemodels/land/noah.3.3/pe/noah33_peMod.F90 index a83abb7b5..d79ec924a 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/noah33_peMod.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/noah33_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/noah33_set_pedecvars.F90 b/lis/surfacemodels/land/noah.3.3/pe/noah33_set_pedecvars.F90 index 56aa50d17..320299685 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/noah33_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/noah33_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_getpeobspred_ARMobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_getpeobspred_ARMobs.F90 index 30f452136..645ef3d56 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_getpeobspred_ARMobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_getpeobspred_ARMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_setupobspred_ARMobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_setupobspred_ARMobs.F90 index 6b6779091..b7971c4e8 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_setupobspred_ARMobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/ARM/noah33_setupobspred_ARMobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_getpeobspred_FLUXNETobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_getpeobspred_FLUXNETobs.F90 index 564a2f593..ac7ccf80d 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_getpeobspred_FLUXNETobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_getpeobspred_FLUXNETobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_setupobspred_FLUXNETobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_setupobspred_FLUXNETobs.F90 index 5c49dfcd2..038003ed6 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_setupobspred_FLUXNETobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/FLUXNET/noah33_setupobspred_FLUXNETobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_getpeobspred_LPRMsmobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_getpeobspred_LPRMsmobs.F90 index 9eb4ef5c6..c17766151 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_getpeobspred_LPRMsmobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_getpeobspred_LPRMsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_setupobspred_LPRMsmobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_setupobspred_LPRMsmobs.F90 index d4f1b4d8f..b1d6a396b 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_setupobspred_LPRMsmobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/LPRM_AMSREsm/noah33_setupobspred_LPRMsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_getpeobspred_USDA_ARSsmobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_getpeobspred_USDA_ARSsmobs.F90 index 03c309622..63524d874 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_getpeobspred_USDA_ARSsmobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_getpeobspred_USDA_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_setupobspred_USDA_ARSsmobs.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_setupobspred_USDA_ARSsmobs.F90 index 27b7db10f..5d3aa91cc 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_setupobspred_USDA_ARSsmobs.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/USDA_ARSsm/noah33_setupobspred_USDA_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_getpeobspred_template.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_getpeobspred_template.F90 index 50d6160d6..74f6957e0 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_getpeobspred_template.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_getpeobspred_template.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_setupobspred_template.F90 b/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_setupobspred_template.F90 index bbdeef84b..84ffa1e85 100644 --- a/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_setupobspred_template.F90 +++ b/lis/surfacemodels/land/noah.3.3/pe/obspred/template/noah33_setupobspred_template.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs.F90 b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs.F90 index 93bd07c63..baf3f27da 100644 --- a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs.F90 +++ b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_et.F90 b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_et.F90 index aa0836f57..d5fb87404 100644 --- a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_et.F90 +++ b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_et.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_mm.F90 b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_mm.F90 index 4e1014353..c36d8eee6 100644 --- a/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noah.3.3/routing/noah33_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/sfc_cmem3/noah33_sfc2cmem3.F90 b/lis/surfacemodels/land/noah.3.3/sfc_cmem3/noah33_sfc2cmem3.F90 index 17067fd8f..975f3b1f2 100644 --- a/lis/surfacemodels/land/noah.3.3/sfc_cmem3/noah33_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/noah.3.3/sfc_cmem3/noah33_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/sfc_crtm/noah33_sfc2crtm.F90 b/lis/surfacemodels/land/noah.3.3/sfc_crtm/noah33_sfc2crtm.F90 index 95c18ceb6..9ba0bd6ff 100644 --- a/lis/surfacemodels/land/noah.3.3/sfc_crtm/noah33_sfc2crtm.F90 +++ b/lis/surfacemodels/land/noah.3.3/sfc_crtm/noah33_sfc2crtm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.3/sfc_tauomega/noah33_sfc2tauomega.F90 b/lis/surfacemodels/land/noah.3.3/sfc_tauomega/noah33_sfc2tauomega.F90 index 89baeda14..a0d1fc39a 100644 --- a/lis/surfacemodels/land/noah.3.3/sfc_tauomega/noah33_sfc2tauomega.F90 +++ b/lis/surfacemodels/land/noah.3.3/sfc_tauomega/noah33_sfc2tauomega.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_setwrfexport.F90 b/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_setwrfexport.F90 index ddfac88d3..01138307a 100644 --- a/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_setwrfexport.F90 +++ b/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_wrf_f2t.F90 b/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_wrf_f2t.F90 index 7d2c08936..7025583f1 100644 --- a/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_wrf_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.6/cpl_wrf_noesmf/noah36_wrf_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_descale_snodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_descale_snodep.F90 index 6b2a62a74..663747d1f 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_descale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodeppred.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodeppred.F90 index f02418c2d..5a8ca78ba 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodeppred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodepvars.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodepvars.F90 index a57c05a00..86ce41a29 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_map_snodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_map_snodep.F90 index 3773d1315..0d383e195 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_map_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qc_snodepobs.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qc_snodepobs.F90 index fa7d2fdb4..2f5d96519 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qcsnodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qcsnodep.F90 index ff4384859..85b9d41ce 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qcsnodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_scale_snodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_scale_snodep.F90 index e7d662393..1bee6d1f2 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_scale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_setsnodepvars.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_setsnodepvars.F90 index 40b13f2fa..4a4cb5a08 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_transform_snodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_transform_snodep.F90 index 57e135257..d2d4423e1 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_transform_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_updatesnodep.F90 b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_updatesnodep.F90 index 12a0d65c9..d5d26d143 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_updatesnodep.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snodep/noah36_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_dasnow_Mod.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_dasnow_Mod.F90 index edc67595d..1b93e0f0a 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_descale_snow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_descale_snow.F90 index da514ae11..e7d41a89f 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_descale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getscfpred.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getscfpred.F90 index 864b917d0..5ff581c6c 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getscfpred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getscfpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowpred_PMWsnow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowpred_PMWsnow.F90 index d9d1fd571..e1516f656 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowpred_PMWsnow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowpred_PMWsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowvars.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowvars.F90 index e54a800f0..d62aa6543 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnwdpred.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnwdpred.F90 index b0660b2c7..867354b96 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnwdpred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getswepred.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getswepred.F90 index 0732f4584..69bed9c5c 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getswepred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow.F90 index a831793e4..c3a0534f5 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow_DI.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow_DI.F90 index 3c147582d..d46db9d9b 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow_DI.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_snow_DI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_swe.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_swe.F90 index c7b4f1eae..f7f767816 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_swe.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_map_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_PMWsnowobs.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_PMWsnowobs.F90 index 9b2cfe6df..3ce9144e3 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_PMWsnowobs.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_PMWsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_scfobs.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_scfobs.F90 index e5a6fa8a5..23d50d020 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_scfobs.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_scfobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_snowobs.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_snowobs.F90 index ae3411cf6..e860905cb 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qcsnow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qcsnow.F90 index 3af77f5ba..15563af06 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qcsnow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_scale_snow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_scale_snow.F90 index 0f53c081b..bd1f2b97b 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_scale_snow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_setsnowvars.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_setsnowvars.F90 index 641b79cf1..5b41322d1 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_setsnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_transform_snow.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_transform_snow.F90 index 573754e59..340a11343 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_transform_snow.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_transform_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars.F90 index 7633e78a2..829fe80e9 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars_scfda.F90 b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars_scfda.F90 index caa77d198..b9a65af5b 100644 --- a/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars_scfda.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_snow/noah36_updatesnowvars_scfda.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_dasoilm_Mod.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_dasoilm_Mod.F90 index ae494a658..5ac9d330d 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_descale_soilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_descale_soilm.F90 index 0c1a3cfdc..61fd178d4 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_descale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getLbandTbPred.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getLbandTbPred.F90 index 9ee961770..716e8aaef 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsmpred.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsmpred.F90 index f069c87c2..7e69b89df 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsmpred.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsoilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsoilm.F90 index d364dfe0e..d5a13259f 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qc_soilmobs.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qc_soilmobs.F90 index 878ec1443..c77bf2211 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qcsoilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qcsoilm.F90 index a722e6cdd..464b65d63 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qcsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_scale_soilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_scale_soilm.F90 index e2543099b..fd9156d55 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_scale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_setsoilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_setsoilm.F90 index 6101fa196..d30633b64 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_setsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_updatesoilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_updatesoilm.F90 index c9968b528..a27865ab6 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_updatesoilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_write_soilm.F90 b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_write_soilm.F90 index 08e27d4d8..5f8c6140a 100644 --- a/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_write_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.6/da_soilm/noah36_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/module_model_constants_36.F90 b/lis/surfacemodels/land/noah.3.6/module_model_constants_36.F90 index c943a926b..4fb4577b7 100644 --- a/lis/surfacemodels/land/noah.3.6/module_model_constants_36.F90 +++ b/lis/surfacemodels/land/noah.3.6/module_model_constants_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm.F90 b/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm.F90 index 0902ac272..3914c57f2 100644 --- a/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm.F90 +++ b/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm_glacial.F90 b/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm_glacial.F90 index 55df5e4cc..28de344fa 100644 --- a/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm_glacial.F90 +++ b/lis/surfacemodels/land/noah.3.6/module_sf_noah36lsm_glacial.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/module_sfcdif_wrf_36.F90 b/lis/surfacemodels/land/noah.3.6/module_sfcdif_wrf_36.F90 index 44f044950..b986c786a 100644 --- a/lis/surfacemodels/land/noah.3.6/module_sfcdif_wrf_36.F90 +++ b/lis/surfacemodels/land/noah.3.6/module_sfcdif_wrf_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_coldstart.F90 b/lis/surfacemodels/land/noah.3.6/noah36_coldstart.F90 index 32837f1c3..fa007aa3a 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_coldstart.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_dynsetup.F90 b/lis/surfacemodels/land/noah.3.6/noah36_dynsetup.F90 index 527a523af..e9f3a9a35 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_dynsetup.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_f2t.F90 b/lis/surfacemodels/land/noah.3.6/noah36_f2t.F90 index a641086f7..357b9e6ab 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_finalize.F90 b/lis/surfacemodels/land/noah.3.6/noah36_finalize.F90 index ddd4c740b..75c3da296 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_finalize.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 b/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 index 92fd1dbf6..efba0f78d 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_main.F90 b/lis/surfacemodels/land/noah.3.6/noah36_main.F90 index 7ead980e4..a25630ce5 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_main.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_module.F90 b/lis/surfacemodels/land/noah.3.6/noah36_module.F90 index 45ba960a7..2c1f5d463 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_module.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_readcrd.F90 b/lis/surfacemodels/land/noah.3.6/noah36_readcrd.F90 index a612cd683..8c430aeed 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_readcrd.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_readrst.F90 b/lis/surfacemodels/land/noah.3.6/noah36_readrst.F90 index 30139986c..5107213aa 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_readrst.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_reset.F90 b/lis/surfacemodels/land/noah.3.6/noah36_reset.F90 index 15269f5a5..c2de91950 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_reset.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_setsoils.F90 b/lis/surfacemodels/land/noah.3.6/noah36_setsoils.F90 index 9321f7080..663da5567 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_setsoils.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_setsoils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_settbot.F90 b/lis/surfacemodels/land/noah.3.6/noah36_settbot.F90 index 334644ea0..b264e956c 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_settbot.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_setup.F90 b/lis/surfacemodels/land/noah.3.6/noah36_setup.F90 index 4e252c60c..3c1b0b6da 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_setup.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_setvegparms.F90 b/lis/surfacemodels/land/noah.3.6/noah36_setvegparms.F90 index 8c01558a4..df10fcf6d 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_setvegparms.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/noah36_writerst.F90 b/lis/surfacemodels/land/noah.3.6/noah36_writerst.F90 index 57df5c9eb..88640e4eb 100644 --- a/lis/surfacemodels/land/noah.3.6/noah36_writerst.F90 +++ b/lis/surfacemodels/land/noah.3.6/noah36_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/pe/noah36_peMod.F90 b/lis/surfacemodels/land/noah.3.6/pe/noah36_peMod.F90 index 34f197f40..0f8140fb7 100644 --- a/lis/surfacemodels/land/noah.3.6/pe/noah36_peMod.F90 +++ b/lis/surfacemodels/land/noah.3.6/pe/noah36_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/pe/noah36_set_pedecvars.F90 b/lis/surfacemodels/land/noah.3.6/pe/noah36_set_pedecvars.F90 index ac3fafbd6..ca107d408 100644 --- a/lis/surfacemodels/land/noah.3.6/pe/noah36_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noah.3.6/pe/noah36_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs.F90 b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs.F90 index 78971cab6..804c2f2b8 100644 --- a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs.F90 +++ b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_hymap2.F90 index 6073405fd..2546ec004 100644 --- a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_mm.F90 b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_mm.F90 index 832bb6cd7..40959e120 100644 --- a/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noah.3.6/routing/noah36_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/routing/noah36_getsws_hymap2.F90 b/lis/surfacemodels/land/noah.3.6/routing/noah36_getsws_hymap2.F90 index 373ae8c99..9c7558a7d 100644 --- a/lis/surfacemodels/land/noah.3.6/routing/noah36_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/noah.3.6/routing/noah36_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.6/sfc_cmem3/noah36_sfc2cmem3.F90 b/lis/surfacemodels/land/noah.3.6/sfc_cmem3/noah36_sfc2cmem3.F90 index e36ed4fe0..02bf9eebf 100644 --- a/lis/surfacemodels/land/noah.3.6/sfc_cmem3/noah36_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/noah.3.6/sfc_cmem3/noah36_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_getCROCUSexport.F90 b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_getCROCUSexport.F90 index 195ef793b..4f9bd8b6d 100644 --- a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_getCROCUSexport.F90 +++ b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_getCROCUSexport.F90 @@ -1,7 +1,7 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! ! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. diff --git a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_setCROCUSimport.F90 b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_setCROCUSimport.F90 index 45ab46f76..984ccbafc 100755 --- a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_setCROCUSimport.F90 +++ b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_setCROCUSimport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_snow_update.F90 b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_snow_update.F90 index c3a57e238..27aa535d2 100644 --- a/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_snow_update.F90 +++ b/lis/surfacemodels/land/noah.3.9/cplsubLSM/noah39_snow_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_descale_snodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_descale_snodep.F90 index 7741a48c4..140e4ffd2 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_descale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodeppred.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodeppred.F90 index 1acc6e5c4..9a7980be2 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodeppred.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodepvars.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodepvars.F90 index 304923d17..53aa5cdc5 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_map_snodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_map_snodep.F90 index 85f4f608a..e85b6ec98 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_map_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qc_snodepobs.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qc_snodepobs.F90 index 8dbd0e092..05c7cea92 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qcsnodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qcsnodep.F90 index 8b7d93eca..98019bf75 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qcsnodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_scale_snodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_scale_snodep.F90 index 5e022fb86..031e2adeb 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_scale_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_setsnodepvars.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_setsnodepvars.F90 index 0a305c639..1779a84e4 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_transform_snodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_transform_snodep.F90 index ca936d2d6..4f1d42d12 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_transform_snodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_updatesnodep.F90 b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_updatesnodep.F90 index 6ce58b595..f28b11111 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_updatesnodep.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snodep/noah39_updatesnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_snow/noah39_dasnow_Mod.F90 b/lis/surfacemodels/land/noah.3.9/da_snow/noah39_dasnow_Mod.F90 index e4bc967af..118d9ba7b 100644 --- a/lis/surfacemodels/land/noah.3.9/da_snow/noah39_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_snow/noah39_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_dasoilm_Mod.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_dasoilm_Mod.F90 index 58ee58d43..41b105b2b 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_descale_soilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_descale_soilm.F90 index c4eeb60ba..7f48a0eb8 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_descale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getLbandTbPred.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getLbandTbPred.F90 index abfce1244..18e3dda8f 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsmpred.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsmpred.F90 index 08fe83746..606971b97 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsmpred.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsoilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsoilm.F90 index fc4346ca5..e41fce088 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qc_soilmobs.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qc_soilmobs.F90 index 1be06ca1a..4a566aa91 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qcsoilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qcsoilm.F90 index 06680ec5e..02245a69d 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qcsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_scale_soilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_scale_soilm.F90 index 5b33dfecd..14045cb72 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_scale_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_setsoilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_setsoilm.F90 index 090b1844f..29ac91a93 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_setsoilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_updatesoilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_updatesoilm.F90 index a5ecc8cf0..db645d5d5 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_updatesoilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_write_soilm.F90 b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_write_soilm.F90 index 1a90131c7..0a755a7dc 100644 --- a/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_write_soilm.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_soilm/noah39_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_descale_usafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_descale_usafsi.F90 index 6dac4d97c..fbfed3a22 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_descale_usafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_descale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsipred.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsipred.F90 index 6667174c9..0e59efff5 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsipred.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsipred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsivars.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsivars.F90 index 3917d8cbd..2a9f381e0 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsivars.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_getusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_map_usafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_map_usafsi.F90 index 945f4903c..d36353cf9 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_map_usafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_map_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qc_usafsiobs.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qc_usafsiobs.F90 index adb595a58..5f6eb2544 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qc_usafsiobs.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qc_usafsiobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qcusafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qcusafsi.F90 index b5b4e9605..183aebbd5 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qcusafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_qcusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_scale_usafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_scale_usafsi.F90 index 4795e61e2..44d81884f 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_scale_usafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_scale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_setusafsivars.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_setusafsivars.F90 index 5d017c71c..ddc8a03be 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_setusafsivars.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_setusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_transform_usafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_transform_usafsi.F90 index dac51c30e..598de6545 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_transform_usafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_transform_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_updateusafsi.F90 b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_updateusafsi.F90 index 42bdca03d..71722d3b8 100644 --- a/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_updateusafsi.F90 +++ b/lis/surfacemodels/land/noah.3.9/da_usafsi/noah39_updateusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/module_sfcdif_wrf_39.F90 b/lis/surfacemodels/land/noah.3.9/module_sfcdif_wrf_39.F90 index 566490079..ffb689eea 100644 --- a/lis/surfacemodels/land/noah.3.9/module_sfcdif_wrf_39.F90 +++ b/lis/surfacemodels/land/noah.3.9/module_sfcdif_wrf_39.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_coldstart.F90 b/lis/surfacemodels/land/noah.3.9/noah39_coldstart.F90 index 8207c7d58..f8032bb95 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_coldstart.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_dynsetup.F90 b/lis/surfacemodels/land/noah.3.9/noah39_dynsetup.F90 index 4bd11c13b..5acb2c2e5 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_dynsetup.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_f2t.F90 b/lis/surfacemodels/land/noah.3.9/noah39_f2t.F90 index d71265406..e6101550d 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_f2t.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_finalize.F90 b/lis/surfacemodels/land/noah.3.9/noah39_finalize.F90 index 80b38a84f..dd92b1dee 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_finalize.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_lsmMod.F90 b/lis/surfacemodels/land/noah.3.9/noah39_lsmMod.F90 index b78c5c71d..b69b40765 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_lsmMod.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_main.F90 b/lis/surfacemodels/land/noah.3.9/noah39_main.F90 index c283b4697..7a8a5b9f8 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_main.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_module.F90 b/lis/surfacemodels/land/noah.3.9/noah39_module.F90 index 6a43ad0a6..58d6cf9ef 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_module.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_readcrd.F90 b/lis/surfacemodels/land/noah.3.9/noah39_readcrd.F90 index 2bde5d67a..9abfa764f 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_readcrd.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 b/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 index 574f3a153..bbd95b854 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_reset.F90 b/lis/surfacemodels/land/noah.3.9/noah39_reset.F90 index b3e0145da..da92e4e45 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_reset.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_setsoils.F90 b/lis/surfacemodels/land/noah.3.9/noah39_setsoils.F90 index 7e7691e82..2ec5f7b8d 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_setsoils.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_setsoils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_settbot.F90 b/lis/surfacemodels/land/noah.3.9/noah39_settbot.F90 index 9efe0efa0..8320b2fa3 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_settbot.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_settbot.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_setup.F90 b/lis/surfacemodels/land/noah.3.9/noah39_setup.F90 index a44a14d20..8dc2da04d 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_setup.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_setvegparms.F90 b/lis/surfacemodels/land/noah.3.9/noah39_setvegparms.F90 index 7f791cfb6..53fef6dfd 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_setvegparms.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_setvegparms.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/noah39_writerst.F90 b/lis/surfacemodels/land/noah.3.9/noah39_writerst.F90 index 880ba0904..bbc0b119a 100644 --- a/lis/surfacemodels/land/noah.3.9/noah39_writerst.F90 +++ b/lis/surfacemodels/land/noah.3.9/noah39_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/phys/module_sf_noah39lsm.F90 b/lis/surfacemodels/land/noah.3.9/phys/module_sf_noah39lsm.F90 index dda91bdd1..d42e8d8e0 100644 --- a/lis/surfacemodels/land/noah.3.9/phys/module_sf_noah39lsm.F90 +++ b/lis/surfacemodels/land/noah.3.9/phys/module_sf_noah39lsm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs.F90 b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs.F90 index 474e41773..b19851c16 100644 --- a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs.F90 +++ b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_hymap2.F90 index 9c3343ee6..90cbdcc02 100644 --- a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_mm.F90 b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_mm.F90 index e8dfff558..5d355375a 100644 --- a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_rapid.F90 b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_rapid.F90 index d555a237d..3ff48a887 100644 --- a/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_rapid.F90 +++ b/lis/surfacemodels/land/noah.3.9/routing/noah39_getrunoffs_rapid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noah.3.9/routing/noah39_getsws_hymap2.F90 b/lis/surfacemodels/land/noah.3.9/routing/noah39_getsws_hymap2.F90 index 3c351cf1d..5913fec5c 100644 --- a/lis/surfacemodels/land/noah.3.9/routing/noah39_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/noah.3.9/routing/noah39_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_coldstart.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_coldstart.F90 index 1ac3b2983..d4d17fe82 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_coldstart.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_dynsetup.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_dynsetup.F90 index 0165ca05e..85895a56e 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_dynsetup.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_f2t.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_f2t.F90 index 0fe18affa..e07a38624 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_f2t.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_finalize.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_finalize.F90 index 8cb39be23..fd35655ac 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_finalize.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_lsmMod.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_lsmMod.F90 index 1138e56e5..689946cce 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_lsmMod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_main.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_main.F90 index 185544938..0a16cfc84 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_main.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_module.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_module.F90 index c176d925b..78366844e 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_module.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readcrd.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readcrd.F90 index f2df681e2..9b1a1e524 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readcrd.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readrst.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readrst.F90 index eaf761cce..f759a4844 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readrst.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_reset.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_reset.F90 index b760ff162..6da19c7ac 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_reset.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_setup.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_setup.F90 index dc863a7cf..34a20872e 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_setup.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_writerst.F90 b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_writerst.F90 index 702767c37..781e4c5c3 100644 --- a/lis/surfacemodels/land/noahmp.3.6/NoahMP36_writerst.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/NoahMP36_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/SOIL_VEG_GEN_PARM_36.F90 b/lis/surfacemodels/land/noahmp.3.6/SOIL_VEG_GEN_PARM_36.F90 index 7dd4c9ad9..c2409728f 100644 --- a/lis/surfacemodels/land/noahmp.3.6/SOIL_VEG_GEN_PARM_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/SOIL_VEG_GEN_PARM_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/cpl_wrf_noesmf/noahMP36_setwrfexport.F90 b/lis/surfacemodels/land/noahmp.3.6/cpl_wrf_noesmf/noahMP36_setwrfexport.F90 index c167b3329..3971349c4 100755 --- a/lis/surfacemodels/land/noahmp.3.6/cpl_wrf_noesmf/noahMP36_setwrfexport.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/cpl_wrf_noesmf/noahMP36_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_daveg_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_daveg_Mod.F90 index d85e7a8a3..71f312e2f 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_daveg_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_daveg_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_descale_veg.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_descale_veg.F90 index 4125faf47..eee4fc4df 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_descale_veg.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_descale_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getLAIpred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getLAIpred.F90 index 443f3052d..7402c722c 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getLAIpred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getLAIpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getvegvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getvegvars.F90 index 9006075f2..b3ac05d68 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getvegvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_getvegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_map_veg.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_map_veg.F90 index f0d652a89..dba99adfc 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_map_veg.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_map_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qc_LAIobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qc_LAIobs.F90 index 155485c94..e8bd797b2 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qc_LAIobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qc_LAIobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qcveg.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qcveg.F90 index 53b59306e..b46725949 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qcveg.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_qcveg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_scale_veg.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_scale_veg.F90 index 4b12aac56..8f840433d 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_scale_veg.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_scale_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_setvegvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_setvegvars.F90 index 7fe92d4af..faea83575 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_setvegvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_setvegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_transform_veg.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_transform_veg.F90 index 5ed818ccc..bd82c03c7 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_transform_veg.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_transform_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_updatevegvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_updatevegvars.F90 index 6421716f8..0173ffa6a 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_updatevegvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_LAI/noahmp36_updatevegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_daalbedo_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_daalbedo_Mod.F90 index 0c25cd08e..6a9b9be69 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_daalbedo_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_daalbedo_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_descale_albedo.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_descale_albedo.F90 index 1251c6a9c..eda92e49e 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_descale_albedo.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_descale_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedopred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedopred.F90 index 14c64075e..ba57f2632 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedopred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedopred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedovars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedovars.F90 index 4d5e23a08..4fbf158f2 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedovars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_getalbedovars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_map_albedo.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_map_albedo.F90 index eb8f5f650..a447a04e8 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_map_albedo.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_map_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qc_albedoobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qc_albedoobs.F90 index 162501f0d..321cd202a 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qc_albedoobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qc_albedoobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qcalbedo.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qcalbedo.F90 index 47f2d59bf..188ae1dfc 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qcalbedo.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_qcalbedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_scale_albedo.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_scale_albedo.F90 index 9bbea908e..d54019e22 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_scale_albedo.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_scale_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_setalbedovars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_setalbedovars.F90 index 73a9731ec..1871e81f9 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_setalbedovars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_setalbedovars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_transform_albedo.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_transform_albedo.F90 index 7d1803a43..8130554a3 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_transform_albedo.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_transform_albedo.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_updatealbedovars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_updatealbedovars.F90 index c6c1fc513..e73531b26 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_updatealbedovars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_albedo/noahmp36_updatealbedovars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_dasnodep_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_dasnodep_Mod.F90 index c90195e2c..0c4d88967 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_dasnodep_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_dasnodep_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_descale_snodep.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_descale_snodep.F90 index 42dddd924..3f701adbd 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_descale_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodeppred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodeppred.F90 index eff18139e..e83429727 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodeppred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodepvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodepvars.F90 index c31b1a0cd..c0bf63d94 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_map_snodep.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_map_snodep.F90 index 8d479899f..bccfeab85 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_map_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qc_snodepobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qc_snodepobs.F90 index f2b8ecf4f..6be930d63 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qcsnodep.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qcsnodep.F90 index 7fff820db..27ff043d7 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qcsnodep.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_scale_snodep.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_scale_snodep.F90 index 9b3586850..64cc4c0f0 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_scale_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_setsnodepvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_setsnodepvars.F90 index 58f941f54..4fa476d5b 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_snodep_update.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_snodep_update.F90 index 0fbf27188..780553245 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_snodep_update.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_snodep_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_transform_snodep.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_transform_snodep.F90 index aff680a25..bc2dc255c 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_transform_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_updatesnodepvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_updatesnodepvars.F90 index 93669b015..d024ff895 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_updatesnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snodep/noahmp36_updatesnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_dasnow_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_dasnow_Mod.F90 index e8bf6cf2f..bb243a283 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_descale_snow.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_descale_snow.F90 index 9512ebfa3..ce578e3c8 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_descale_snow.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnowvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnowvars.F90 index 84ad38d1c..9a454b148 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnwdpred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnwdpred.F90 index 97f245395..c44cbfde2 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnwdpred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getswepred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getswepred.F90 index dfdba28fa..a7453c7ad 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getswepred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qc_snowobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qc_snowobs.F90 index afa5a16a4..045c67cdb 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qcsnow.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qcsnow.F90 index dea58b51a..0e269e427 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qcsnow.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_scale_snow.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_scale_snow.F90 index e8c2e43f7..5ace73f06 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_scale_snow.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_setsnowvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_setsnowvars.F90 index e26444a11..48ce2a0bd 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_setsnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_snow_update.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_snow_update.F90 index f6adb1dcd..15afedb38 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_snow_update.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_snow_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_updatesnowvars.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_updatesnowvars.F90 index 1a0e15d38..da4128413 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snow/noahmp36_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/mwSVM_routines.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/mwSVM_routines.F90 index e767736ef..ba09cd9cf 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/mwSVM_routines.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/mwSVM_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_LIS_SVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_LIS_SVM.F90 index cebff4c4d..b7b642021 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_LIS_SVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_LIS_SVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_dasnowSVM_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_dasnowSVM_Mod.F90 index afd8fedd2..7e12bf199 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_dasnowSVM_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_dasnowSVM_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_descale_snowSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_descale_snowSVM.F90 index 8894bfeb9..25193c669 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_descale_snowSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_descale_snowSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnowvarsSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnowvarsSVM.F90 index 6ce841451..8e90876b8 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnowvarsSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnowvarsSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnwdpred_TB.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnwdpred_TB.F90 index 0f1b64206..6c26d1393 100755 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnwdpred_TB.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_getsnwdpred_TB.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qc_snowobsSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qc_snowobsSVM.F90 index d84070480..46fcd79f9 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qc_snowobsSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qc_snowobsSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qcsnowSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qcsnowSVM.F90 index d37f4de30..e6b818ed9 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qcsnowSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_qcsnowSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_scale_snowSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_scale_snowSVM.F90 index 28af6d5c5..da6b0bbb6 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_scale_snowSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_scale_snowSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_setsnowvarsSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_setsnowvarsSVM.F90 index cd5915bcf..19f77c750 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_setsnowvarsSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_setsnowvarsSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_updatesnowvarsSVM.F90 b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_updatesnowvarsSVM.F90 index c61e9425f..98b5a1409 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_updatesnowvarsSVM.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_snowSVM/noahmp36_updatesnowvarsSVM.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_dasoilm_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_dasoilm_Mod.F90 index 14fd0fd20..2eb261054 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_descale_soilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_descale_soilm.F90 index 9ed5a9296..79382a8d6 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_descale_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsmpred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsmpred.F90 index 53a44483f..e2e9c0d15 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsmpred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsoilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsoilm.F90 index d8e0f0287..eb6fa795e 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qc_soilmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qc_soilmobs.F90 index a4e01b86b..af1b2a9cf 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qcsoilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qcsoilm.F90 index a2c83636b..f6ea257df 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qcsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_scale_soilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_scale_soilm.F90 index 3826306dc..cfa2d047d 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_scale_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_setsoilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_setsoilm.F90 index a46bdf90b..5679758a1 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_setsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_updatesoilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_updatesoilm.F90 index c279fef25..c2fd35f6b 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_updatesoilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_write_soilm.F90 b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_write_soilm.F90 index 2c1c0fa75..d2cd244c6 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_write_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_soilm/noahmp36_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_datws_Mod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_datws_Mod.F90 index c817b55ae..d9a262851 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_datws_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_datws_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_descale_tws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_descale_tws.F90 index 4effc5676..10cdcc397 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_descale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_descale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettws.F90 index 04c87eed2..337c5fe5c 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettwspred.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettwspred.F90 index 11e3127b9..f3c061f7d 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettwspred.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_gettwspred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qc_twsobs.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qc_twsobs.F90 index 7979a3ffb..88a5364f3 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qc_twsobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qc_twsobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qctws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qctws.F90 index e6a9ef7d5..d7bb4ac59 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qctws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_qctws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_scale_tws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_scale_tws.F90 index f32748704..825d6eb7a 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_scale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_scale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_settws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_settws.F90 index 8a95801e1..0d21dd05f 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_settws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_settws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_tws_DAlogMod.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_tws_DAlogMod.F90 index f849c1193..6e34651c1 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_tws_DAlogMod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_tws_DAlogMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_updatetws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_updatetws.F90 index 0239a54be..0f19852a9 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_updatetws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_updatetws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_write_tws.F90 b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_write_tws.F90 index 1006b8302..862c6a4b5 100644 --- a/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_write_tws.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/da_tws/noahmp36_write_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/irrigation/noahmp36_getirrigationstates.F90 b/lis/surfacemodels/land/noahmp.3.6/irrigation/noahmp36_getirrigationstates.F90 index fa686995d..ac60788d4 100755 --- a/lis/surfacemodels/land/noahmp.3.6/irrigation/noahmp36_getirrigationstates.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/irrigation/noahmp36_getirrigationstates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/kwm_date_utilities_36.F90 b/lis/surfacemodels/land/noahmp.3.6/kwm_date_utilities_36.F90 index 809ff57be..aa5d2bacf 100644 --- a/lis/surfacemodels/land/noahmp.3.6/kwm_date_utilities_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/kwm_date_utilities_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/module_model_constants_36.F90 b/lis/surfacemodels/land/noahmp.3.6/module_model_constants_36.F90 index 1bd48d618..4745622bf 100644 --- a/lis/surfacemodels/land/noahmp.3.6/module_model_constants_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/module_model_constants_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/module_sf_myjsfc_36.F90 b/lis/surfacemodels/land/noahmp.3.6/module_sf_myjsfc_36.F90 index 0966ce614..3adf8354c 100644 --- a/lis/surfacemodels/land/noahmp.3.6/module_sf_myjsfc_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/module_sf_myjsfc_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/module_sf_noahlsm_36.F90 b/lis/surfacemodels/land/noahmp.3.6/module_sf_noahlsm_36.F90 index 2c832a065..1655ff3b7 100644 --- a/lis/surfacemodels/land/noahmp.3.6/module_sf_noahlsm_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/module_sf_noahlsm_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/module_sf_noahmplsm_36.F90 b/lis/surfacemodels/land/noahmp.3.6/module_sf_noahmplsm_36.F90 index 8e073f35b..f4f4f5d94 100644 --- a/lis/surfacemodels/land/noahmp.3.6/module_sf_noahmplsm_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/module_sf_noahmplsm_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/module_sf_sfclay_36.F90 b/lis/surfacemodels/land/noahmp.3.6/module_sf_sfclay_36.F90 index 75893ef33..adf562237 100644 --- a/lis/surfacemodels/land/noahmp.3.6/module_sf_sfclay_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/module_sf_sfclay_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/noahmp36_wrf_routines.F90 b/lis/surfacemodels/land/noahmp.3.6/noahmp36_wrf_routines.F90 index 4d8040473..88f1e83e1 100644 --- a/lis/surfacemodels/land/noahmp.3.6/noahmp36_wrf_routines.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/noahmp36_wrf_routines.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/noahmp_driver_36.F90 b/lis/surfacemodels/land/noahmp.3.6/noahmp_driver_36.F90 index 254cbef71..a0e1a8acc 100644 --- a/lis/surfacemodels/land/noahmp.3.6/noahmp_driver_36.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/noahmp_driver_36.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_peMod.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_peMod.F90 index 1e7d1bf1d..6d31d47c5 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_peMod.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_set_pedecvars.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_set_pedecvars.F90 index 18231b358..249cf7c39 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/NoahMP36_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_getpeobspred_ARSsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_getpeobspred_ARSsmobs.F90 index 4867e2caf..56b819063 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_getpeobspred_ARSsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_getpeobspred_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_setupobspred_ARSsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_setupobspred_ARSsmobs.F90 index 0a4209544..7b4a12c0c 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_setupobspred_ARSsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ARSsm/NoahMP36_setupobspred_ARSsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_getpeobspred_ISMNsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_getpeobspred_ISMNsmobs.F90 index 0e4f7bf3f..fba497201 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_getpeobspred_ISMNsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_getpeobspred_ISMNsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_setupobspred_ISMNsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_setupobspred_ISMNsmobs.F90 index 39b26fdad..f661c33b3 100755 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_setupobspred_ISMNsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/ISMNsm/NoahMP36_setupobspred_ISMNsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_getpeobspred_SMAPsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_getpeobspred_SMAPsmobs.F90 index 723c60029..5d62a7f8d 100644 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_getpeobspred_SMAPsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_getpeobspred_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_setupobspred_SMAPsmobs.F90 b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_setupobspred_SMAPsmobs.F90 index ab615fbb6..ed4f8596a 100644 --- a/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_setupobspred_SMAPsmobs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/pe/obspred/SMAPsm/NoahMP36_setupobspred_SMAPsmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs.F90 b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs.F90 index e0a0fcdd6..8dad79839 100644 --- a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_hymap2.F90 index 4dc30b082..c5ac23eb4 100644 --- a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_mm.F90 b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_mm.F90 index 9919e77c6..ff40cf082 100644 --- a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_rapid.F90 b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_rapid.F90 index 49c87cf20..b535d2300 100644 --- a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_rapid.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getrunoffs_rapid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getsws_hymap2.F90 b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getsws_hymap2.F90 index ce1cdb1ee..24299fd50 100755 --- a/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/routing/noahmp36_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.3.6/sfc_cmem3/noahmp36_sfc2cmem3.F90 b/lis/surfacemodels/land/noahmp.3.6/sfc_cmem3/noahmp36_sfc2cmem3.F90 index 4b14b4fbe..093b647a1 100755 --- a/lis/surfacemodels/land/noahmp.3.6/sfc_cmem3/noahmp36_sfc2cmem3.F90 +++ b/lis/surfacemodels/land/noahmp.3.6/sfc_cmem3/noahmp36_sfc2cmem3.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_coldstart.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_coldstart.F90 index fbc18408d..e6c64a28f 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_coldstart.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_dynsetup.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_dynsetup.F90 index 4d6cc1917..833dea5b7 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_dynsetup.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_f2t.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_f2t.F90 index 07721e343..78d71e92f 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_f2t.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_finalize.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_finalize.F90 index 6c1d68277..9448f5068 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_finalize.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 index cf1078f06..d38c5c959 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 index 73579e51f..b87ee3c0b 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_module.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_module.F90 index 2c33d7195..1b47bd72d 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_module.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_read_OPT_parameters.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_read_OPT_parameters.F90 index ca8ca3da0..4d9b53d5b 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_read_OPT_parameters.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_read_OPT_parameters.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 index 9f6ef947d..17d28ff07 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readrst.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readrst.F90 index 606a12682..ca55e253e 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readrst.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_reset.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_reset.F90 index 8d041f4c5..48fd142ce 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_reset.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_setup.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_setup.F90 index 2491e4849..7799d9952 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_setup.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 index b2bb11e33..eb44a25fc 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/NoahMP401_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cpl_wrf_noesmf/noahMP401_setwrfexport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cpl_wrf_noesmf/noahMP401_setwrfexport.F90 index e81a4b346..9f66a7897 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/cpl_wrf_noesmf/noahMP401_setwrfexport.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/cpl_wrf_noesmf/noahMP401_setwrfexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getCROCUSexport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getCROCUSexport.F90 index 1241fa81e..22602af4f 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getCROCUSexport.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getCROCUSexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 index 8346a1798..1eb346e43 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_getSnowModelexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setCROCUSimport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setCROCUSimport.F90 index 6889274e6..de6790324 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setCROCUSimport.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setCROCUSimport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 index 51d3723a9..467c07f99 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/cplsubLSM/noahmp401_setSnowModelimport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_daveg_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_daveg_Mod.F90 index 3630931d2..0e62ae676 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_daveg_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_daveg_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_descale_veg.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_descale_veg.F90 index bd317c20b..a51ecd488 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_descale_veg.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_descale_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getLAIpred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getLAIpred.F90 index d0fe9d6b1..2b75f1d36 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getLAIpred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getLAIpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getvegvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getvegvars.F90 index e7ce945f7..5611bd3a7 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getvegvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_getvegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qc_LAIobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qc_LAIobs.F90 index cb6be1e72..63da30a45 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qc_LAIobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qc_LAIobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qcveg.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qcveg.F90 index 546655de7..b5eb9cade 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qcveg.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_qcveg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_scale_veg.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_scale_veg.F90 index d617f0f8e..745c67223 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_scale_veg.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_scale_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_setvegvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_setvegvars.F90 index 2ef4fc49d..68fa55de0 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_setvegvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_setvegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_updatevegvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_updatevegvars.F90 index 38760e06d..43dfc8a3c 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_updatevegvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_updatevegvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_veg_DAlog.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_veg_DAlog.F90 index 5f9bcb19e..85a3eb471 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_veg_DAlog.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_veg_DAlog.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_write_veg.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_write_veg.F90 index 83ec93f15..804436f67 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_write_veg.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_LAI/noahmp401_write_veg.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_dasnodep_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_dasnodep_Mod.F90 index 8db8ac65c..b625b20e7 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_dasnodep_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_dasnodep_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_descale_snodep.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_descale_snodep.F90 index 1776e2864..548719dd4 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_descale_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_descale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodeppred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodeppred.F90 index da3b4a3c0..dae311ec4 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodeppred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodeppred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodepvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodepvars.F90 index abdeea682..7bcae28f6 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_getsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_map_snodep.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_map_snodep.F90 index 7b08f8f1b..f2781e23d 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_map_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_map_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qc_snodepobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qc_snodepobs.F90 index a563d03e2..3d3688810 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qc_snodepobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qc_snodepobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qcsnodep.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qcsnodep.F90 index c63b36e0f..903811d6d 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qcsnodep.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_qcsnodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_scale_snodep.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_scale_snodep.F90 index f5e10c834..bb0049ca5 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_scale_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_scale_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_setsnodepvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_setsnodepvars.F90 index df7ce3975..2466de25b 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_setsnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_setsnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_snodep_update.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_snodep_update.F90 index e8cff9847..ecca8a290 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_snodep_update.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_snodep_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_transform_snodep.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_transform_snodep.F90 index f7796c12f..29557f881 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_transform_snodep.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_transform_snodep.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_updatesnodepvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_updatesnodepvars.F90 index 3a41edc43..5bc167c03 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_updatesnodepvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snodep/noahmp401_updatesnodepvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_dasnow_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_dasnow_Mod.F90 index 0c869bd91..2d6def21f 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_descale_snow.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_descale_snow.F90 index 9a363f08d..93d04ed68 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_descale_snow.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowpred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowpred.F90 index 6fa842c3c..48bdb9cff 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowpred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowvars.F90 index 50e2ca540..c21d02585 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getswepred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getswepred.F90 index 5ffb0c359..074953af3 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getswepred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qc_snowobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qc_snowobs.F90 index 4849d1b66..1cc06f089 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qc_snowobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qcsnow.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qcsnow.F90 index fe465f285..3c90c0915 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qcsnow.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_scale_snow.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_scale_snow.F90 index 2165f3a84..43da59153 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_scale_snow.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_setsnowvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_setsnowvars.F90 index b40e85c5b..f28accea9 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_setsnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 index 8f9173232..8df9ca2f1 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_snow_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_updatesnowvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_updatesnowvars.F90 index 35afc3c87..c5518d156 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_updatesnowvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_snow/noahmp401_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_dasoilm_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_dasoilm_Mod.F90 index 38e7e3e84..cb7dddc5d 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_descale_soilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_descale_soilm.F90 index c0531e090..527e805fb 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_descale_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsmpred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsmpred.F90 index 3662eae99..f96424228 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsmpred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsoilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsoilm.F90 index d461f2091..ac6bcdd7e 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qc_soilmobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qc_soilmobs.F90 index 17bdef5dd..4c38990c9 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qcsoilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qcsoilm.F90 index 7e7a3b3ed..d77f93e1a 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qcsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_scale_soilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_scale_soilm.F90 index 0595e7553..3be9d1553 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_scale_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_setsoilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_setsoilm.F90 index 045bde466..c6e8a443c 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_setsoilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_updatesoilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_updatesoilm.F90 index 7e0b0e198..319cd5c21 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_updatesoilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_write_soilm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_write_soilm.F90 index ecbb563dc..78a7356cc 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_write_soilm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_soilm/noahmp401_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 index 1e8bf81af..aac1c6b56 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_datws_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 index edca8f7d2..09c499da6 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_descale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 index d234bc9b9..7386fa95f 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettwspred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettwspred.F90 index 02a3f19e4..c523adc45 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettwspred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_gettwspred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qc_twsobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qc_twsobs.F90 index 82dd50ea4..b6e340314 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qc_twsobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qc_twsobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 index 71b7db2b3..bc405ac28 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_qctws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 index 8d71fb50a..1dbd7a96e 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_scale_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 index 0397497d7..7a22d7b81 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_settws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_tws_DAlogMod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_tws_DAlogMod.F90 index 31d6ebdd5..4def6005d 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_tws_DAlogMod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_tws_DAlogMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 index 50a3df816..8b15211b6 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_updatetws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_write_tws.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_write_tws.F90 index 8ae4e18df..7eb016ceb 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_write_tws.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_tws/noahmp401_write_tws.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_dausafsi_Mod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_dausafsi_Mod.F90 index 1831d9cff..ddc91ab4e 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_dausafsi_Mod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_dausafsi_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_descale_usafsi.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_descale_usafsi.F90 index 9bc4b914b..af300a581 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_descale_usafsi.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_descale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsipred.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsipred.F90 index 690b09f83..455d7e2c8 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsipred.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsipred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsivars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsivars.F90 index cbc48409e..34e560f27 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsivars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_getusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_map_usafsi.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_map_usafsi.F90 index 2d92a9ae4..5a340cc59 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_map_usafsi.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_map_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qc_usafsiobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qc_usafsiobs.F90 index 4e524a4ed..2a79be4c8 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qc_usafsiobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qc_usafsiobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qcusafsi.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qcusafsi.F90 index ed92c10cf..9ff1d1a4e 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qcusafsi.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_qcusafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_scale_usafsi.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_scale_usafsi.F90 index 033c003f5..47313927c 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_scale_usafsi.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_scale_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_setusafsivars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_setusafsivars.F90 index 7b13c3a20..a5ce79a9a 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_setusafsivars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_setusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_transform_usafsi.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_transform_usafsi.F90 index c380462c6..eaf312c24 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_transform_usafsi.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_transform_usafsi.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_updateusafsivars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_updateusafsivars.F90 index f039d344a..8d0887160 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_updateusafsivars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_updateusafsivars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_usafsi_update.F90 b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_usafsi_update.F90 index 57d09f12d..53d37d02e 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_usafsi_update.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/da_usafsi/noahmp401_usafsi_update.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/irrigation/noahmp401_getirrigationstates.F90 b/lis/surfacemodels/land/noahmp.4.0.1/irrigation/noahmp401_getirrigationstates.F90 index f155e79f3..f6a550e2d 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/irrigation/noahmp401_getirrigationstates.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/irrigation/noahmp401_getirrigationstates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/kwm_date_utilities_401.F90 b/lis/surfacemodels/land/noahmp.4.0.1/kwm_date_utilities_401.F90 index e5d02bb70..f0150381c 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/kwm_date_utilities_401.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/kwm_date_utilities_401.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/noahmp_driver_401.F90 b/lis/surfacemodels/land/noahmp.4.0.1/noahmp_driver_401.F90 index 88c747a5f..715264d19 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/noahmp_driver_401.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/noahmp_driver_401.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_peMod.F90 b/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_peMod.F90 index c70c9d026..dab00a9d4 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_peMod.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_peMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_set_pedecvars.F90 b/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_set_pedecvars.F90 index 86af58f9a..fdc7fd790 100755 --- a/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_set_pedecvars.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/pe/NoahMP401_set_pedecvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_getpeobspred_UAsnowobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_getpeobspred_UAsnowobs.F90 index d0669daad..d4f04bc60 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_getpeobspred_UAsnowobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_getpeobspred_UAsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_setupobspred_UAsnowobs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_setupobspred_UAsnowobs.F90 index 5fda39680..25761d945 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_setupobspred_UAsnowobs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/pe/obspred/UAsnow/NoahMP401_setupobspred_UAsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs.F90 b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs.F90 index 6678496d0..bc9c3134b 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_hymap2.F90 b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_hymap2.F90 index 50ba761c4..f119d6eb6 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_hymap2.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_mm.F90 b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_mm.F90 index 56e68d3d4..ae25aa2aa 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_rapid.F90 b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_rapid.F90 index 01d8769aa..69c4d2a97 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_rapid.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getrunoffs_rapid.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getsws_hymap2.F90 b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getsws_hymap2.F90 index 1c04b9186..cafdd895f 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getsws_hymap2.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/routing/noahmp401_getsws_hymap2.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/noahmp.4.0.1/wrf_debug.F90 b/lis/surfacemodels/land/noahmp.4.0.1/wrf_debug.F90 index 88e560de3..9477a6c39 100644 --- a/lis/surfacemodels/land/noahmp.4.0.1/wrf_debug.F90 +++ b/lis/surfacemodels/land/noahmp.4.0.1/wrf_debug.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356.lis.config b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356.lis.config index e8927d30b..d71673c92 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356.lis.config +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356.lis.config @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_coldstart.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_coldstart.F90 index 9950b6ec4..5afa6544e 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_coldstart.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_dynsetup.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_dynsetup.F90 index 0cf577ec7..cb64b76be 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_dynsetup.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_f2t.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_f2t.F90 index 209cd6c17..4e710edfe 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_f2t.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_finalize.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_finalize.F90 index ff68a7395..39b757aaf 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_finalize.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_lsmMod.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_lsmMod.F90 index bc796085a..31f6c78ae 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_lsmMod.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90 index 7fa70a33d..1a447d302 100644 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90.old b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90.old index 1fa766a46..64c412a66 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90.old +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_main.F90.old @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_module.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_module.F90 index 3df9c7c8f..aea5c8acb 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_module.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readcrd.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readcrd.F90 index 410fe9126..3ea47139e 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readcrd.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readrst.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readrst.F90 index f896ab331..d61313efe 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readrst.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_setup.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_setup.F90 index e57636814..603a571c8 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_setup.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_writerst.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_writerst.F90 index 89ebf9d34..ec4b1bb58 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_writerst.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM356_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/RDHM_356.F90 b/lis/surfacemodels/land/rdhm.3.5.6/RDHM_356.F90 index e928c918c..ece1b1329 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/RDHM_356.F90 +++ b/lis/surfacemodels/land/rdhm.3.5.6/RDHM_356.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/SOILPAR2.F b/lis/surfacemodels/land/rdhm.3.5.6/SOILPAR2.F index 812be7de8..5cdb3e3c4 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/SOILPAR2.F +++ b/lis/surfacemodels/land/rdhm.3.5.6/SOILPAR2.F @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/com_header.h b/lis/surfacemodels/land/rdhm.3.5.6/com_header.h index 77b50fb02..fb74f4a4f 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/com_header.h +++ b/lis/surfacemodels/land/rdhm.3.5.6/com_header.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/init_soil_moisture.f b/lis/surfacemodels/land/rdhm.3.5.6/init_soil_moisture.f index c36cc5a2d..0c1f89fcb 100644 --- a/lis/surfacemodels/land/rdhm.3.5.6/init_soil_moisture.f +++ b/lis/surfacemodels/land/rdhm.3.5.6/init_soil_moisture.f @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/linux.h b/lis/surfacemodels/land/rdhm.3.5.6/linux.h index 615669f79..16f496670 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/linux.h +++ b/lis/surfacemodels/land/rdhm.3.5.6/linux.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/logfromfortran.c b/lis/surfacemodels/land/rdhm.3.5.6/logfromfortran.c index 43f9620ce..de889c0d7 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/logfromfortran.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/logfromfortran.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/models.h b/lis/surfacemodels/land/rdhm.3.5.6/models.h index 27395381a..69448d1e9 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/models.h +++ b/lis/surfacemodels/land/rdhm.3.5.6/models.h @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c b/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c index ad97bf88e..6011922b8 100755 --- a/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c +++ b/lis/surfacemodels/land/rdhm.3.5.6/rdhm_get_ped.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_coldstart.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_coldstart.F90 index 67cf16edb..52972c254 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_coldstart.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_dynsetup.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_dynsetup.F90 index 1d85100ac..1147998ba 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_dynsetup.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_f2t.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_f2t.F90 index 52baf9f5d..2fc2f767d 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_f2t.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_finalize.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_finalize.F90 index 4ed128521..3e370dcad 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_finalize.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_lsmMod.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_lsmMod.F90 index 48268126c..498fd2575 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_lsmMod.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_main.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_main.F90 index 2410bf037..0f3632ea4 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_main.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_module.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_module.F90 index 3929c73bb..0c4f4256f 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_module.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_readcrd.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_readcrd.F90 index fe18c98d8..ae492db35 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_readcrd.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_readrst.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_readrst.F90 index 0f3a1eebb..f3ba6d90a 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_readrst.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_setup.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_setup.F90 index 1496f134a..403a95bdb 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_setup.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/RUC37_writerst.F90 b/lis/surfacemodels/land/ruc.3.7/RUC37_writerst.F90 index 7271c4fe6..cc4bc4527 100644 --- a/lis/surfacemodels/land/ruc.3.7/RUC37_writerst.F90 +++ b/lis/surfacemodels/land/ruc.3.7/RUC37_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_dasnow_Mod.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_dasnow_Mod.F90 index ea3358d36..49fac63d8 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_dasnow_Mod.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_dasnow_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_descale_snow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_descale_snow.F90 index e6fc0801f..d3dc59415 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_descale_snow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_descale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getscfpred.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getscfpred.F90 index 4413d11f3..f15fc60fc 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getscfpred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getscfpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowpred_PMWsnow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowpred_PMWsnow.F90 index 387216d64..bd0d6824f 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowpred_PMWsnow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowpred_PMWsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowvars.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowvars.F90 index b0a378d53..44f36752d 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowvars.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnwdpred.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnwdpred.F90 index daf913f74..f72e5722c 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnwdpred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getsnwdpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getswepred.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getswepred.F90 index c56c6d310..21cf41379 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getswepred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_getswepred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow.F90 index 5d6783e25..a5272de8c 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow_DI.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow_DI.F90 index 44e49939c..73c4523d0 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow_DI.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_snow_DI.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_swe.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_swe.F90 index c7b493099..52b97fe61 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_swe.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_map_swe.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_PMWsnowobs.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_PMWsnowobs.F90 index 6921eba30..79fbd9a20 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_PMWsnowobs.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_PMWsnowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_scfobs.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_scfobs.F90 index 711fbed67..11240bdf0 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_scfobs.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_scfobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_snowobs.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_snowobs.F90 index d0797314d..75c2c2abd 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_snowobs.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qc_snowobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qcsnow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qcsnow.F90 index 8a6be9a50..a734f64aa 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qcsnow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_qcsnow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_scale_snow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_scale_snow.F90 index e9ea6dde0..7ae998374 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_scale_snow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_scale_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_setsnowvars.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_setsnowvars.F90 index 7a53ea40c..9ab68a5fb 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_setsnowvars.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_setsnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_transform_snow.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_transform_snow.F90 index 3b4dc348a..6325defd8 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_transform_snow.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_transform_snow.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars.F90 index 00616247b..b84e084f7 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars_scfda.F90 b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars_scfda.F90 index 088f61d8b..00ed11ee8 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars_scfda.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_snow/ruc37_updatesnowvars_scfda.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_dasoilm_Mod.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_dasoilm_Mod.F90 index 18e9cecb8..75e12acfe 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_dasoilm_Mod.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_dasoilm_Mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_descale_soilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_descale_soilm.F90 index f3a807df4..233bedbe0 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_descale_soilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_descale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getLbandTbPred.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getLbandTbPred.F90 index a7179dfce..5313c28f6 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getLbandTbPred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getLbandTbPred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsmpred.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsmpred.F90 index ecbf22f5d..c68d6e6c9 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsmpred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsoilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsoilm.F90 index 97406f1e8..bdc796b36 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsoilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsynsmpred.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsynsmpred.F90 index 610ca2f3f..be1d81605 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsynsmpred.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_getsynsmpred.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qc_soilmobs.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qc_soilmobs.F90 index 3a6e5291e..5e039bb48 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qc_soilmobs.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qc_soilmobs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qcsoilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qcsoilm.F90 index 92775c654..794e4edad 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qcsoilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_qcsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_scale_soilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_scale_soilm.F90 index e42fdb39e..aa3e98da3 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_scale_soilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_scale_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_setsoilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_setsoilm.F90 index f1cb99d0a..eed8b7d95 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_setsoilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_setsoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_updatesoilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_updatesoilm.F90 index 643694b52..0a76854ce 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_updatesoilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_updatesoilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_write_soilm.F90 b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_write_soilm.F90 index 4e6efb168..43c0ec07f 100644 --- a/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_write_soilm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/da_soilm/ruc37_write_soilm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/irrigation/ruc37_getirrigationstates.F90 b/lis/surfacemodels/land/ruc.3.7/irrigation/ruc37_getirrigationstates.F90 index c92c50ff6..d9eac1dce 100644 --- a/lis/surfacemodels/land/ruc.3.7/irrigation/ruc37_getirrigationstates.F90 +++ b/lis/surfacemodels/land/ruc.3.7/irrigation/ruc37_getirrigationstates.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs.F90 b/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs.F90 index 9ffc814d8..899aab113 100644 --- a/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs.F90 +++ b/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs_mm.F90 b/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs_mm.F90 index 2ff1d5ef0..ebdc856a3 100644 --- a/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/ruc.3.7/routing/ruc37_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_coldstart.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_coldstart.F90 index fa6ff31fb..a06729144 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_coldstart.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_dynsetup.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_dynsetup.F90 index bc6df9bbb..e04e8aeaf 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_dynsetup.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_f2t.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_f2t.F90 index c26b0d196..0567528a3 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_f2t.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_finalize.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_finalize.F90 index 8fb138ec7..da79fe451 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_finalize.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_lsmMod.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_lsmMod.F90 index 44945ad45..7c0410ec5 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_lsmMod.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_main.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_main.F90 index 92223c88b..4c72cc48b 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_main.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_module.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_module.F90 index a5766b2f2..d7acce444 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_module.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readcrd.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readcrd.F90 index 3e4dfd1e3..2a129b0cd 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readcrd.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readrst.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readrst.F90 index 693f4ed77..2307d4f9f 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readrst.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_setup.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_setup.F90 index 09d923f1a..187d945d2 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_setup.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_writerst.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_writerst.F90 index 5bae79a67..3479e8639 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_writerst.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/Crocus81_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_getLSMexport.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_getLSMexport.F90 index d44e160dc..13ba2844e 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_getLSMexport.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_getLSMexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_setLSMimport.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_setLSMimport.F90 index 386737416..79c6eed91 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_setLSMimport.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/cplLSM/Crocus81_setLSMimport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/crocus_driver.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/crocus_driver.F90 index e55bac7ab..5cecf3fe2 100755 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/crocus_driver.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/crocus_driver.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/crocus.8.1/kwm_date_utilities_crocus81.F90 b/lis/surfacemodels/land/subLSM/crocus.8.1/kwm_date_utilities_crocus81.F90 index f7a5d4e2f..9a5b14836 100644 --- a/lis/surfacemodels/land/subLSM/crocus.8.1/kwm_date_utilities_crocus81.F90 +++ b/lis/surfacemodels/land/subLSM/crocus.8.1/kwm_date_utilities_crocus81.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 index bbfdb1017..eac8acfd0 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_getLSMexport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 index 5daa596c4..61a2f9d3b 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/cplLSM/Snowmodel_setLSMimport.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.3 +! Version 7.5 ! -! Copyright (c) 2020 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 b/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 index 42647dad5..fb48073f2 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/micromet_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 index 59e063ed9..2e5d1aa1f 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_coldstart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 index 4e8f378f4..8e490c882 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 index c87755a93..6832545ea 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 index cfc3d71c2..7a9ca95b8 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 index 0f959ca7d..8df719942 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 index 77db618ee..2561f231b 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 index 8c0e74032..a874285e0 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 index 4d7bcd934..bcf1c6887 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readconfig.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 index 03126dd51..0df43d6d7 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 index ca87ae59e..8dcdfb4cf 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 index cc70febd6..5f99dd55b 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 index e0cd86ea5..6261eeabe 100644 --- a/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 +++ b/lis/surfacemodels/land/subLSM/snowmodel/snowmodel_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_dynsetup.F90 b/lis/surfacemodels/land/summa.1.0/summa1_dynsetup.F90 index fe47502c9..fbad0802a 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_dynsetup.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_f2t.F90 b/lis/surfacemodels/land/summa.1.0/summa1_f2t.F90 index b1ad31ab4..ee8a2638b 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_f2t.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_finalize.F90 b/lis/surfacemodels/land/summa.1.0/summa1_finalize.F90 index 043ef98ed..5b7af2484 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_finalize.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_lsmMod.F90 b/lis/surfacemodels/land/summa.1.0/summa1_lsmMod.F90 index f72c39283..20c3ec0e9 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_lsmMod.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_main.F90 b/lis/surfacemodels/land/summa.1.0/summa1_main.F90 index 86838b9d8..0ec10ac74 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_main.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_module.F90 b/lis/surfacemodels/land/summa.1.0/summa1_module.F90 index 2d3c927cb..92edfec9a 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_module.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_readcrd.F90 b/lis/surfacemodels/land/summa.1.0/summa1_readcrd.F90 index 66d77674b..d48f4b061 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_readcrd.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_readrst.F90 b/lis/surfacemodels/land/summa.1.0/summa1_readrst.F90 index 2dd4f4816..44563a97e 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_readrst.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_setup.F90 b/lis/surfacemodels/land/summa.1.0/summa1_setup.F90 index a14f9c1f7..a196a0522 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_setup.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/summa.1.0/summa1_writerst.F90 b/lis/surfacemodels/land/summa.1.0/summa1_writerst.F90 index c7852e971..c81fe3679 100644 --- a/lis/surfacemodels/land/summa.1.0/summa1_writerst.F90 +++ b/lis/surfacemodels/land/summa.1.0/summa1_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/0Intro_template.txt b/lis/surfacemodels/land/template/0Intro_template.txt index ed6d9dd01..e08787dde 100644 --- a/lis/surfacemodels/land/template/0Intro_template.txt +++ b/lis/surfacemodels/land/template/0Intro_template.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_dynsetup.F90 b/lis/surfacemodels/land/template/template_dynsetup.F90 index 2b6a9462e..4ca6f14f3 100644 --- a/lis/surfacemodels/land/template/template_dynsetup.F90 +++ b/lis/surfacemodels/land/template/template_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_f2t.F90 b/lis/surfacemodels/land/template/template_f2t.F90 index 4a2de5b6f..7e04c4970 100644 --- a/lis/surfacemodels/land/template/template_f2t.F90 +++ b/lis/surfacemodels/land/template/template_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_finalize.F90 b/lis/surfacemodels/land/template/template_finalize.F90 index 92cdd9e68..5edcf0914 100644 --- a/lis/surfacemodels/land/template/template_finalize.F90 +++ b/lis/surfacemodels/land/template/template_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_getrunoffs.F90 b/lis/surfacemodels/land/template/template_getrunoffs.F90 index 8f1ac1c9c..82bd6f0aa 100644 --- a/lis/surfacemodels/land/template/template_getrunoffs.F90 +++ b/lis/surfacemodels/land/template/template_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_lsmMod.F90 b/lis/surfacemodels/land/template/template_lsmMod.F90 index 175d9ec06..94215fde9 100644 --- a/lis/surfacemodels/land/template/template_lsmMod.F90 +++ b/lis/surfacemodels/land/template/template_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_main.F90 b/lis/surfacemodels/land/template/template_main.F90 index 0c7e9e003..124626783 100644 --- a/lis/surfacemodels/land/template/template_main.F90 +++ b/lis/surfacemodels/land/template/template_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_module.F90 b/lis/surfacemodels/land/template/template_module.F90 index 9485cfd1a..cb22f4ee8 100755 --- a/lis/surfacemodels/land/template/template_module.F90 +++ b/lis/surfacemodels/land/template/template_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_readcrd.F90 b/lis/surfacemodels/land/template/template_readcrd.F90 index 089ca8e0f..db59377af 100644 --- a/lis/surfacemodels/land/template/template_readcrd.F90 +++ b/lis/surfacemodels/land/template/template_readcrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_readrst.F90 b/lis/surfacemodels/land/template/template_readrst.F90 index cdd0b1b70..02ae709e6 100644 --- a/lis/surfacemodels/land/template/template_readrst.F90 +++ b/lis/surfacemodels/land/template/template_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_reset.F90 b/lis/surfacemodels/land/template/template_reset.F90 index ff09be980..ace14ac97 100644 --- a/lis/surfacemodels/land/template/template_reset.F90 +++ b/lis/surfacemodels/land/template/template_reset.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_setup.F90 b/lis/surfacemodels/land/template/template_setup.F90 index c97db8742..d31873d89 100644 --- a/lis/surfacemodels/land/template/template_setup.F90 +++ b/lis/surfacemodels/land/template/template_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/template/template_writerst.F90 b/lis/surfacemodels/land/template/template_writerst.F90 index 787cd199c..66779e321 100644 --- a/lis/surfacemodels/land/template/template_writerst.F90 +++ b/lis/surfacemodels/land/template/template_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/0Intro_vic411.txt b/lis/surfacemodels/land/vic.4.1.1/0Intro_vic411.txt index f26c61e7c..f93966e9d 100644 --- a/lis/surfacemodels/land/vic.4.1.1/0Intro_vic411.txt +++ b/lis/surfacemodels/land/vic.4.1.1/0Intro_vic411.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/finalize_vic411.c b/lis/surfacemodels/land/vic.4.1.1/finalize_vic411.c index f8c27e604..d9415522e 100644 --- a/lis/surfacemodels/land/vic.4.1.1/finalize_vic411.c +++ b/lis/surfacemodels/land/vic.4.1.1/finalize_vic411.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c index b7fabf560..0e2952c49 100644 --- a/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c +++ b/lis/surfacemodels/land/vic.4.1.1/setup_vic411.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_add_atmosdata.c b/lis/surfacemodels/land/vic.4.1.1/vic411_add_atmosdata.c index 36d7e3c94..d0b6944d1 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_add_atmosdata.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_add_atmosdata.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_compute_treeline_lis.c b/lis/surfacemodels/land/vic.4.1.1/vic411_compute_treeline_lis.c index ea17a668a..cee4060fc 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_compute_treeline_lis.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_compute_treeline_lis.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_diag.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_diag.F90 index cdfbd9ebf..80260240f 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_diag.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_dynsetup.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_dynsetup.F90 index 028dd683f..5cd8ac93c 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_dynsetup.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_f2t.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_f2t.F90 index 2b43686a1..d85bc20ed 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_f2t.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_finalize.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_finalize.F90 index e9eef8221..e8d85498d 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_finalize.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_find_min_tfactor.c b/lis/surfacemodels/land/vic.4.1.1/vic411_find_min_tfactor.c index 0e1eeea2a..d51b4aca5 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_find_min_tfactor.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_find_min_tfactor.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_fsvp.c b/lis/surfacemodels/land/vic.4.1.1/vic411_fsvp.c index 41579bb96..196c3cd64 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_fsvp.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_fsvp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_get_max_snow_temp.c b/lis/surfacemodels/land/vic.4.1.1/vic411_get_max_snow_temp.c index 250e9ae0f..3734432f6 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_get_max_snow_temp.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_get_max_snow_temp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_lis_read_soilparam_arc.c b/lis/surfacemodels/land/vic.4.1.1/vic411_lis_read_soilparam_arc.c index 4aae096ce..b965fc569 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_lis_read_soilparam_arc.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_lis_read_soilparam_arc.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_lis_scan_soilparam_flat_ascii.c b/lis/surfacemodels/land/vic.4.1.1/vic411_lis_scan_soilparam_flat_ascii.c index bdfe785b2..a0e3802fc 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_lis_scan_soilparam_flat_ascii.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_lis_scan_soilparam_flat_ascii.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_lsmMod.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_lsmMod.F90 index af837eba8..11a3b0d18 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_lsmMod.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_main.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_main.F90 index bbd5a7737..aac874d85 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_main.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_module.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_module.F90 index a5810b34f..dd5309dad 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_module.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c b/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c index e02ca8bfb..0c7b7b16e 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_read_vegparam_lis.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_readcard.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_readcard.F90 index 8926d0dba..ff04993c9 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_readcard.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_readcard.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_readrst.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_readrst.F90 index 5518c2c2e..254992023 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_readrst.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_run.c b/lis/surfacemodels/land/vic.4.1.1/vic411_run.c index c41114f99..648892d3c 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_run.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_run.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c index cfe7e8c04..5231d61c2 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_set_vegparam.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_setup.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_setup.F90 index 709d5eada..21dd4bc74 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_setup.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_write_atmos.c b/lis/surfacemodels/land/vic.4.1.1/vic411_write_atmos.c index 69d82a931..f75366f9d 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_write_atmos.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_write_atmos.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_write_bin_atmosdata.c b/lis/surfacemodels/land/vic.4.1.1/vic411_write_bin_atmosdata.c index 0994124b9..b84535001 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_write_bin_atmosdata.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_write_bin_atmosdata.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_write_lakecon.c b/lis/surfacemodels/land/vic.4.1.1/vic411_write_lakecon.c index fb625479a..64a97ce4b 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_write_lakecon.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_write_lakecon.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_write_prcp.c b/lis/surfacemodels/land/vic.4.1.1/vic411_write_prcp.c index e6fb0a4b8..a304973e0 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_write_prcp.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_write_prcp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_write_state.c b/lis/surfacemodels/land/vic.4.1.1/vic411_write_state.c index 19a37f086..29c7f6b00 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_write_state.c +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_write_state.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.1/vic411_writerst.F90 b/lis/surfacemodels/land/vic.4.1.1/vic411_writerst.F90 index 620753624..316589169 100644 --- a/lis/surfacemodels/land/vic.4.1.1/vic411_writerst.F90 +++ b/lis/surfacemodels/land/vic.4.1.1/vic411_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/0Intro_vic412.txt b/lis/surfacemodels/land/vic.4.1.2.l/0Intro_vic412.txt index ca93ee1a8..e6a4cc331 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/0Intro_vic412.txt +++ b/lis/surfacemodels/land/vic.4.1.2.l/0Intro_vic412.txt @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/finalize_vic412.c b/lis/surfacemodels/land/vic.4.1.2.l/finalize_vic412.c index 355cfc3d2..5d8a080ff 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/finalize_vic412.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/finalize_vic412.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/find_min_tfactor.c b/lis/surfacemodels/land/vic.4.1.2.l/find_min_tfactor.c index c0ec54590..ac1cc062d 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/find_min_tfactor.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/find_min_tfactor.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/fsvp.c b/lis/surfacemodels/land/vic.4.1.2.l/fsvp.c index 5120be2e3..b35726a2b 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/fsvp.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/fsvp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/get_max_snow_temp.c b/lis/surfacemodels/land/vic.4.1.2.l/get_max_snow_temp.c index 8eb876dd9..913c720e9 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/get_max_snow_temp.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/get_max_snow_temp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/lis_read_soilparam_arc.c.original b/lis/surfacemodels/land/vic.4.1.2.l/lis_read_soilparam_arc.c.original index 80114ff70..53a88bc35 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/lis_read_soilparam_arc.c.original +++ b/lis/surfacemodels/land/vic.4.1.2.l/lis_read_soilparam_arc.c.original @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/lis_scan_soilparam_flat_ascii.c b/lis/surfacemodels/land/vic.4.1.2.l/lis_scan_soilparam_flat_ascii.c index 0edfdfce9..129240ce6 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/lis_scan_soilparam_flat_ascii.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/lis_scan_soilparam_flat_ascii.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoff.c b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoff.c index ac02972ea..ed2a04bb1 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoff.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoff.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs.F90 b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs.F90 index a27cf6946..799ad39fe 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs_mm.F90 b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs_mm.F90 index f71a92e3c..a5f708f14 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs_mm.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/routing/vic412_getrunoffs_mm.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c index 043efd7ea..fa5866b9f 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c.origin b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c.origin index e2be7a891..6cb3f3d53 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c.origin +++ b/lis/surfacemodels/land/vic.4.1.2.l/set_vegparam.c.origin @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c b/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c index 0d11b4f81..36b44d71d 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/setup_vic412.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_add_atmosdata.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_add_atmosdata.c index 72f7d3990..5e9de36d6 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_add_atmosdata.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_add_atmosdata.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_compute_treeline.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_compute_treeline.c index 583c658cb..9d18ec484 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_compute_treeline.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_compute_treeline.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_count_model_state.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_count_model_state.c index 0a394b187..c4002fc11 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_count_model_state.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_count_model_state.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_diag.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_diag.F90 index b650b9456..64f5663df 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_diag.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_diag.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_dynsetup.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_dynsetup.F90 index 778a9c107..423669477 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_dynsetup.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_f2t.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_f2t.F90 index d4bbe1da2..c77d011a8 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_f2t.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_finalize.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_finalize.F90 index 0ae25682f..5acc82319 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_finalize.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_intialize.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_intialize.c index 7a43c286d..369d7f50a 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_intialize.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_intialize.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_lsmMod.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_lsmMod.F90 index 71ff2dfcf..4cc89b426 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_lsmMod.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_lsmMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_main.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_main.F90 index 63d0bbcb6..2f0d795dc 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_main.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_module.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_module.F90 index a141fbc2d..60084f536 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_module.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_read_vegparam.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_read_vegparam.c index 46070e9a9..b913082ab 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_read_vegparam.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_read_vegparam.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_readcard.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_readcard.F90 index 8beaf76d6..f76ad8bc7 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_readcard.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_readcard.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_readrst.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_readrst.F90 index f6e7b0c9f..a22c2b88e 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_readrst.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c index f6e322776..b253652f6 100644 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_run.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_setup.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_setup.F90 index c3510c8c1..3297cdd66 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_setup.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c index 9830394a3..93946d71f 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_atmos.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c index 4fbd36c50..8213dedaf 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_write_state.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/vic412_writerst.F90 b/lis/surfacemodels/land/vic.4.1.2.l/vic412_writerst.F90 index 60ad481a8..7a11a7377 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/vic412_writerst.F90 +++ b/lis/surfacemodels/land/vic.4.1.2.l/vic412_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/write_atmosdata.c b/lis/surfacemodels/land/vic.4.1.2.l/write_atmosdata.c index 83a078e75..abd750e0a 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/write_atmosdata.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/write_atmosdata.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/write_bin_atmosdata.c b/lis/surfacemodels/land/vic.4.1.2.l/write_bin_atmosdata.c index c64a36e9c..7449478dd 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/write_bin_atmosdata.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/write_bin_atmosdata.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/write_lakecon.c b/lis/surfacemodels/land/vic.4.1.2.l/write_lakecon.c index c84b345aa..c019d8bc0 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/write_lakecon.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/write_lakecon.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/land/vic.4.1.2.l/write_prcp.c b/lis/surfacemodels/land/vic.4.1.2.l/write_prcp.c index 9c86871e5..469f17be4 100755 --- a/lis/surfacemodels/land/vic.4.1.2.l/write_prcp.c +++ b/lis/surfacemodels/land/vic.4.1.2.l/write_prcp.c @@ -1,9 +1,9 @@ //-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- // NASA Goddard Space Flight Center // Land Information System Framework (LISF) -// Version 7.4 +// Version 7.5 // -// Copyright (c) 2022 United States Government as represented by the +// Copyright (c) 2024 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration. // All Rights Reserved. //-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 b/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 index 051d60e60..ff0926ece 100644 --- a/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 +++ b/lis/surfacemodels/openwater/template/readtemplateOpenWatercrd.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWaterMod.F90 b/lis/surfacemodels/openwater/template/templateOpenWaterMod.F90 index 99797fcc9..a711b8678 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWaterMod.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWaterMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_dynsetup.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_dynsetup.F90 index c85a9afcf..cc8847e85 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_dynsetup.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_dynsetup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_f2t.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_f2t.F90 index 2aceefaaf..907bb3122 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_f2t.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_f2t.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_finalize.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_finalize.F90 index 31e36d5fe..1bbbc7da7 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_finalize.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_finalize.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_main.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_main.F90 index a86211a59..f89b5f8d5 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_main.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_module.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_module.F90 index 4828170e1..9b7de68a1 100755 --- a/lis/surfacemodels/openwater/template/templateOpenWater_module.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_module.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_readrst.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_readrst.F90 index 9fad61d69..093bf003c 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_readrst.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_readrst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_setup.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_setup.F90 index 0e9db2044..07673df5b 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_setup.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_setup.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/surfacemodels/openwater/template/templateOpenWater_writerst.F90 b/lis/surfacemodels/openwater/template/templateOpenWater_writerst.F90 index bf89aef0a..021187d09 100644 --- a/lis/surfacemodels/openwater/template/templateOpenWater_writerst.F90 +++ b/lis/surfacemodels/openwater/template/templateOpenWater_writerst.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/afwa-cod/compute_cod_based_clouds.F90 b/lis/testcases/metforcing/afwa-cod/compute_cod_based_clouds.F90 index 916fc05de..a59bfaa51 100644 --- a/lis/testcases/metforcing/afwa-cod/compute_cod_based_clouds.F90 +++ b/lis/testcases/metforcing/afwa-cod/compute_cod_based_clouds.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/afwa-cod/compute_type_based_clouds.F90 b/lis/testcases/metforcing/afwa-cod/compute_type_based_clouds.F90 index 07ff6b96e..6fc7d0217 100644 --- a/lis/testcases/metforcing/afwa-cod/compute_type_based_clouds.F90 +++ b/lis/testcases/metforcing/afwa-cod/compute_type_based_clouds.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/afwa-cod/readagrmetforcing.F90 b/lis/testcases/metforcing/afwa-cod/readagrmetforcing.F90 index 8df4440d2..14dbc295d 100644 --- a/lis/testcases/metforcing/afwa-cod/readagrmetforcing.F90 +++ b/lis/testcases/metforcing/afwa-cod/readagrmetforcing.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_galwem.F90 b/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_galwem.F90 index 73f72176a..81c14471d 100644 --- a/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_galwem.F90 +++ b/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_precip_galwem.F90 b/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_precip_galwem.F90 index 68e2edaf4..d256fd0b6 100644 --- a/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_precip_galwem.F90 +++ b/lis/testcases/metforcing/afwa-galwem/AGRMET_fldbld_precip_galwem.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/merra2/read_CONSTANT_lc.F90 b/lis/testcases/metforcing/merra2/read_CONSTANT_lc.F90 index 5858118ac..826b8c4de 100644 --- a/lis/testcases/metforcing/merra2/read_CONSTANT_lc.F90 +++ b/lis/testcases/metforcing/merra2/read_CONSTANT_lc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/metforcing/merra2/read_merra2.F90.dbg b/lis/testcases/metforcing/merra2/read_merra2.F90.dbg index f85dc974a..f83cdf198 100644 --- a/lis/testcases/metforcing/merra2/read_merra2.F90.dbg +++ b/lis/testcases/metforcing/merra2/read_merra2.F90.dbg @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/misc/history/template_main.F90 b/lis/testcases/misc/history/template_main.F90 index c8b6eecc9..4c7600a63 100644 --- a/lis/testcases/misc/history/template_main.F90 +++ b/lis/testcases/misc/history/template_main.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/testcases/surfacemodels/land/geowrsi.2/wget_testcasefiles_portal.sh b/lis/testcases/surfacemodels/land/geowrsi.2/wget_testcasefiles_portal.sh index b5ce3d554..483f84bde 100755 --- a/lis/testcases/surfacemodels/land/geowrsi.2/wget_testcasefiles_portal.sh +++ b/lis/testcases/surfacemodels/land/geowrsi.2/wget_testcasefiles_portal.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-fire/index.html b/lis/utils/eis_visualization_portal/eis-fire/index.html index 16c1283fc..954ac7f7d 100644 --- a/lis/utils/eis_visualization_portal/eis-fire/index.html +++ b/lis/utils/eis_visualization_portal/eis-fire/index.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/MissRiverBasin0.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/MissRiverBasin0.js index ed58569cc..4672f72ca 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/MissRiverBasin0.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/MissRiverBasin0.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/columbia_basin_0.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/columbia_basin_0.js index cafafad5e..20a99e046 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/columbia_basin_0.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/columbia_basin_0.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/dams_columbia_all_3.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/dams_columbia_all_3.js index bb9bd245b..8c7334e37 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/dams_columbia_all_3.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/dams_columbia_all_3.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/downstream_reach_4.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/downstream_reach_4.js index 01e0292d6..189c89f07 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/downstream_reach_4.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/downstream_reach_4.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_only_6.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_only_6.js index b7df15a28..712ef2daa 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_only_6.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_only_6.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_7.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_7.js index 46724194d..94912f308 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_7.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_7.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_dnstream_8.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_dnstream_8.js index 005fe38a1..77bd14dac 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_dnstream_8.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoir_upstream_dnstream_8.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoirs_2.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoirs_2.js index 35e07ab56..1abd1eb8e 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoirs_2.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/reservoirs_2.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_1.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_1.js index c02713b3f..6d2697491 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_1.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_1.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_mrb_0.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_mrb_0.js index 7cd3bd1a7..130f88c95 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_mrb_0.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/rivers_mrb_0.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/data/upstream_reach_5.js b/lis/utils/eis_visualization_portal/eis-freshwater/data/upstream_reach_5.js index 19b7fc157..17d2c3df5 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/data/upstream_reach_5.js +++ b/lis/utils/eis_visualization_portal/eis-freshwater/data/upstream_reach_5.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/explorer.html b/lis/utils/eis_visualization_portal/eis-freshwater/explorer.html index a0efff7a7..b55e4f0bd 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/explorer.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/explorer.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/index.html b/lis/utils/eis_visualization_portal/eis-freshwater/index.html index a3caf58a4..3a0da00d7 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/index.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/index.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/storymap.html b/lis/utils/eis_visualization_portal/eis-freshwater/storymap.html index e0b4cd001..77c639496 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/storymap.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/storymap.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_altimeter.html b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_altimeter.html index 50f0f4f00..38a886f96 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_altimeter.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_altimeter.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html index 2f39bf58e..ceee0e052 100644 --- a/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html +++ b/lis/utils/eis_visualization_portal/eis-freshwater/timeseries_streamflow.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-sealevel/index.html b/lis/utils/eis_visualization_portal/eis-sealevel/index.html index ddb77156d..2cb2792cd 100644 --- a/lis/utils/eis_visualization_portal/eis-sealevel/index.html +++ b/lis/utils/eis_visualization_portal/eis-sealevel/index.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-sealevel/storymap.html b/lis/utils/eis_visualization_portal/eis-sealevel/storymap.html index 11f2f548c..7a9a48a30 100644 --- a/lis/utils/eis_visualization_portal/eis-sealevel/storymap.html +++ b/lis/utils/eis_visualization_portal/eis-sealevel/storymap.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/about.html b/lis/utils/eis_visualization_portal/eis-toplanding/about.html index 0821e46ce..83f5f52e6 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/about.html +++ b/lis/utils/eis_visualization_portal/eis-toplanding/about.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css index 7a1b5312d..83c09362d 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/about.css @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css index 7387b072e..94f191a82 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.css @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css index 9ba16e678..b747b42a2 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/agency.min.css @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css index 5c811d763..fa2b37bee 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/style.css @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css b/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css index 447269b27..552dbb282 100755 --- a/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css +++ b/lis/utils/eis_visualization_portal/eis-toplanding/css/styles.css @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/index.html b/lis/utils/eis_visualization_portal/eis-toplanding/index.html index e13018ba4..262934fe8 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/index.html +++ b/lis/utils/eis_visualization_portal/eis-toplanding/index.html @@ -3,9 +3,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js index b6e0463ca..38e70714c 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js +++ b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js index 207fc1e06..8dd52c9df 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js +++ b/lis/utils/eis_visualization_portal/eis-toplanding/js/agency.min.js @@ -5,9 +5,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/js/contact_me.js b/lis/utils/eis_visualization_portal/eis-toplanding/js/contact_me.js index 4bba70eb8..0dfbb7ecf 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/js/contact_me.js +++ b/lis/utils/eis_visualization_portal/eis-toplanding/js/contact_me.js @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/agency.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/agency.scss index e983a44cd..f4c42b9ed 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/agency.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/agency.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_mixins.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_mixins.scss index 0757d9f25..05e5bc9d2 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_mixins.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_mixins.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_page.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_page.scss index 3b1166013..eda40afe4 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_page.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_page.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_variables.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_variables.scss index c9d7c9b1f..b1d8a859a 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_variables.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/base/_variables.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_buttons.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_buttons.scss index 8c19f2c16..86dbb3c98 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_buttons.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_buttons.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_navbar.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_navbar.scss index d0994374d..1defc7b67 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_navbar.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/components/_navbar.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_contact.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_contact.scss index 818fcfd10..73f35075d 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_contact.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_contact.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_footer.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_footer.scss index 398d32923..1c3697180 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_footer.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_footer.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_masthead.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_masthead.scss index 4de060870..a949a432c 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_masthead.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_masthead.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_portfolio.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_portfolio.scss index 71985546c..68e9334f2 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_portfolio.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_portfolio.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_services.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_services.scss index 1f9757cf6..42ade2e16 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_services.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_services.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_team.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_team.scss index 075ec3bb7..336d66d33 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_team.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_team.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_timeline.scss b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_timeline.scss index c95631d3a..35c20695c 100644 --- a/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_timeline.scss +++ b/lis/utils/eis_visualization_portal/eis-toplanding/scss/layout/_timeline.scss @@ -2,9 +2,9 @@ -----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- NASA Goddard Space Flight Center Land Information System Framework (LISF) - Version 7.4 + Version 7.5 - Copyright (c) 2022 United States Government as represented by the + Copyright (c) 2024 United States Government as represented by the Administrator of the National Aeronautics and Space Administration. All Rights Reserved. -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/ensemble_downscale/restartFromEnsemble.F90 b/lis/utils/ensemble_downscale/restartFromEnsemble.F90 index 021d7383b..1d9f46762 100644 --- a/lis/utils/ensemble_downscale/restartFromEnsemble.F90 +++ b/lis/utils/ensemble_downscale/restartFromEnsemble.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/ensemble_upscale/restartForEnsemble.F90 b/lis/utils/ensemble_upscale/restartForEnsemble.F90 index 8b093c41a..b3e09aa5b 100644 --- a/lis/utils/ensemble_upscale/restartForEnsemble.F90 +++ b/lis/utils/ensemble_upscale/restartForEnsemble.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/grads/generateGrADsControlFile.F90 b/lis/utils/grads/generateGrADsControlFile.F90 index d4506a07e..1900adcbc 100644 --- a/lis/utils/grads/generateGrADsControlFile.F90 +++ b/lis/utils/grads/generateGrADsControlFile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/refman_scripts/doc.sh b/lis/utils/refman_scripts/doc.sh index 09c94e67c..36e1f6504 100755 --- a/lis/utils/refman_scripts/doc.sh +++ b/lis/utils/refman_scripts/doc.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/bilinear_interp.F90 b/lis/utils/restartConverter/bilinear_interp.F90 index 7293ab49d..721383791 100644 --- a/lis/utils/restartConverter/bilinear_interp.F90 +++ b/lis/utils/restartConverter/bilinear_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/bilinear_interp_input.F90 b/lis/utils/restartConverter/bilinear_interp_input.F90 index 1d2a8c3dc..35c5848a6 100644 --- a/lis/utils/restartConverter/bilinear_interp_input.F90 +++ b/lis/utils/restartConverter/bilinear_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord.F90 b/lis/utils/restartConverter/compute_earth_coord.F90 index 52c40c6dd..6d6571869 100644 --- a/lis/utils/restartConverter/compute_earth_coord.F90 +++ b/lis/utils/restartConverter/compute_earth_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_ease.F90 b/lis/utils/restartConverter/compute_earth_coord_ease.F90 index 70a9c0383..6a48ff5e7 100644 --- a/lis/utils/restartConverter/compute_earth_coord_ease.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_gauss.F90 b/lis/utils/restartConverter/compute_earth_coord_gauss.F90 index 6d93fc250..76e3c153a 100644 --- a/lis/utils/restartConverter/compute_earth_coord_gauss.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_hrap.F90 b/lis/utils/restartConverter/compute_earth_coord_hrap.F90 index ae5b12be4..c9f8d9bbf 100644 --- a/lis/utils/restartConverter/compute_earth_coord_hrap.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_lambert.F90 b/lis/utils/restartConverter/compute_earth_coord_lambert.F90 index 83b0896b5..b8551e31b 100644 --- a/lis/utils/restartConverter/compute_earth_coord_lambert.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_latlon.F90 b/lis/utils/restartConverter/compute_earth_coord_latlon.F90 index 230b43bad..2835322aa 100644 --- a/lis/utils/restartConverter/compute_earth_coord_latlon.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_latlon_ll.F90 b/lis/utils/restartConverter/compute_earth_coord_latlon_ll.F90 index ab5977ec1..d49d02514 100644 --- a/lis/utils/restartConverter/compute_earth_coord_latlon_ll.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_latlon_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_latlon_ur.F90 b/lis/utils/restartConverter/compute_earth_coord_latlon_ur.F90 index a7507aaf2..8593cbf21 100644 --- a/lis/utils/restartConverter/compute_earth_coord_latlon_ur.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_latlon_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_ll.F90 b/lis/utils/restartConverter/compute_earth_coord_ll.F90 index 13a4ee541..d3ef91711 100644 --- a/lis/utils/restartConverter/compute_earth_coord_ll.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_ll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_merc.F90 b/lis/utils/restartConverter/compute_earth_coord_merc.F90 index b682811f3..cb41179a3 100644 --- a/lis/utils/restartConverter/compute_earth_coord_merc.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_polar.F90 b/lis/utils/restartConverter/compute_earth_coord_polar.F90 index a52479036..18fe0dbdc 100644 --- a/lis/utils/restartConverter/compute_earth_coord_polar.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_earth_coord_ur.F90 b/lis/utils/restartConverter/compute_earth_coord_ur.F90 index 8e053d6cc..f4fa148d0 100644 --- a/lis/utils/restartConverter/compute_earth_coord_ur.F90 +++ b/lis/utils/restartConverter/compute_earth_coord_ur.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord.F90 b/lis/utils/restartConverter/compute_grid_coord.F90 index 7e2fc9dcf..6935de1a6 100644 --- a/lis/utils/restartConverter/compute_grid_coord.F90 +++ b/lis/utils/restartConverter/compute_grid_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_ease.F90 b/lis/utils/restartConverter/compute_grid_coord_ease.F90 index b64e844bd..527d436a3 100644 --- a/lis/utils/restartConverter/compute_grid_coord_ease.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_ease.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_gauss.F90 b/lis/utils/restartConverter/compute_grid_coord_gauss.F90 index d6e9293f3..69113d5cc 100644 --- a/lis/utils/restartConverter/compute_grid_coord_gauss.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_hrap.F90 b/lis/utils/restartConverter/compute_grid_coord_hrap.F90 index 4ab06dc56..2a412cda3 100644 --- a/lis/utils/restartConverter/compute_grid_coord_hrap.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_hrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_lambert.F90 b/lis/utils/restartConverter/compute_grid_coord_lambert.F90 index 804016734..6644f6c74 100644 --- a/lis/utils/restartConverter/compute_grid_coord_lambert.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_latlon.F90 b/lis/utils/restartConverter/compute_grid_coord_latlon.F90 index f33a89f5d..9568d7e26 100644 --- a/lis/utils/restartConverter/compute_grid_coord_latlon.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_merc.F90 b/lis/utils/restartConverter/compute_grid_coord_merc.F90 index e4acb1930..a10a2de19 100644 --- a/lis/utils/restartConverter/compute_grid_coord_merc.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/compute_grid_coord_polar.F90 b/lis/utils/restartConverter/compute_grid_coord_polar.F90 index a384919e7..6f6c12433 100644 --- a/lis/utils/restartConverter/compute_grid_coord_polar.F90 +++ b/lis/utils/restartConverter/compute_grid_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/ezlh_convert.F90 b/lis/utils/restartConverter/ezlh_convert.F90 index d86cb9a4f..e83289fd5 100755 --- a/lis/utils/restartConverter/ezlh_convert.F90 +++ b/lis/utils/restartConverter/ezlh_convert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/ezlh_inverse.F90 b/lis/utils/restartConverter/ezlh_inverse.F90 index dce789cfe..91843a741 100755 --- a/lis/utils/restartConverter/ezlh_inverse.F90 +++ b/lis/utils/restartConverter/ezlh_inverse.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/gaussian_mod.F90 b/lis/utils/restartConverter/gaussian_mod.F90 index 51d629563..bff36c8f8 100644 --- a/lis/utils/restartConverter/gaussian_mod.F90 +++ b/lis/utils/restartConverter/gaussian_mod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/gausslat.F90 b/lis/utils/restartConverter/gausslat.F90 index a68dce991..bf35a87cc 100644 --- a/lis/utils/restartConverter/gausslat.F90 +++ b/lis/utils/restartConverter/gausslat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/get_fieldpos.F90 b/lis/utils/restartConverter/get_fieldpos.F90 index 83fc0ed8c..13a4821ee 100644 --- a/lis/utils/restartConverter/get_fieldpos.F90 +++ b/lis/utils/restartConverter/get_fieldpos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/latlonTohrap.F90 b/lis/utils/restartConverter/latlonTohrap.F90 index f3a8928ab..8718605c6 100644 --- a/lis/utils/restartConverter/latlonTohrap.F90 +++ b/lis/utils/restartConverter/latlonTohrap.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/latlonTopolar.F90 b/lis/utils/restartConverter/latlonTopolar.F90 index 55df36918..365662ce0 100644 --- a/lis/utils/restartConverter/latlonTopolar.F90 +++ b/lis/utils/restartConverter/latlonTopolar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/map_utils.F90 b/lis/utils/restartConverter/map_utils.F90 index c1a84af2e..f1fca5a35 100644 --- a/lis/utils/restartConverter/map_utils.F90 +++ b/lis/utils/restartConverter/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/neighbor_interp.F90 b/lis/utils/restartConverter/neighbor_interp.F90 index 2309da9f8..ecc191d99 100644 --- a/lis/utils/restartConverter/neighbor_interp.F90 +++ b/lis/utils/restartConverter/neighbor_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/neighbor_interp_input.F90 b/lis/utils/restartConverter/neighbor_interp_input.F90 index 84cf49b79..dd622a592 100644 --- a/lis/utils/restartConverter/neighbor_interp_input.F90 +++ b/lis/utils/restartConverter/neighbor_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/polfixs.F90 b/lis/utils/restartConverter/polfixs.F90 index 303b0358a..10fdcf36c 100644 --- a/lis/utils/restartConverter/polfixs.F90 +++ b/lis/utils/restartConverter/polfixs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/restartConverter.F90 b/lis/utils/restartConverter/restartConverter.F90 index 50cc68089..8a5709255 100644 --- a/lis/utils/restartConverter/restartConverter.F90 +++ b/lis/utils/restartConverter/restartConverter.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/restartConverter.F90.afwa b/lis/utils/restartConverter/restartConverter.F90.afwa index a06a449e4..b994df4d2 100644 --- a/lis/utils/restartConverter/restartConverter.F90.afwa +++ b/lis/utils/restartConverter/restartConverter.F90.afwa @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartConverter/restartConverter.F90.orig b/lis/utils/restartConverter/restartConverter.F90.orig index aaea0de37..f7993c38d 100644 --- a/lis/utils/restartConverter/restartConverter.F90.orig +++ b/lis/utils/restartConverter/restartConverter.F90.orig @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/bilinear_interp.F90 b/lis/utils/restartGenAFWA/bilinear_interp.F90 index 9f263cd38..d2ea97a71 100644 --- a/lis/utils/restartGenAFWA/bilinear_interp.F90 +++ b/lis/utils/restartGenAFWA/bilinear_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/bilinear_interp_input.F90 b/lis/utils/restartGenAFWA/bilinear_interp_input.F90 index fef6f2628..62ed2c717 100644 --- a/lis/utils/restartGenAFWA/bilinear_interp_input.F90 +++ b/lis/utils/restartGenAFWA/bilinear_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord.F90 b/lis/utils/restartGenAFWA/compute_earth_coord.F90 index b8a0cfc8d..66b304f3d 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord_gauss.F90 b/lis/utils/restartGenAFWA/compute_earth_coord_gauss.F90 index 17a3685eb..93f36c3cb 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord_gauss.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord_lambert.F90 b/lis/utils/restartGenAFWA/compute_earth_coord_lambert.F90 index 83b0896b5..b8551e31b 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord_lambert.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord_latlon.F90 b/lis/utils/restartGenAFWA/compute_earth_coord_latlon.F90 index a73962334..90ab02df5 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord_latlon.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord_merc.F90 b/lis/utils/restartGenAFWA/compute_earth_coord_merc.F90 index 5bcb864ed..cc2b82718 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord_merc.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_earth_coord_polar.F90 b/lis/utils/restartGenAFWA/compute_earth_coord_polar.F90 index a52479036..18fe0dbdc 100644 --- a/lis/utils/restartGenAFWA/compute_earth_coord_polar.F90 +++ b/lis/utils/restartGenAFWA/compute_earth_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord.F90 b/lis/utils/restartGenAFWA/compute_grid_coord.F90 index 26f4f1c9f..abed65464 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord_gauss.F90 b/lis/utils/restartGenAFWA/compute_grid_coord_gauss.F90 index 743a5a64c..00453f9fd 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord_gauss.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord_gauss.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord_lambert.F90 b/lis/utils/restartGenAFWA/compute_grid_coord_lambert.F90 index 69176d81d..1e34eff79 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord_lambert.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord_lambert.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord_latlon.F90 b/lis/utils/restartGenAFWA/compute_grid_coord_latlon.F90 index 5672a5ed8..ad534acb1 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord_latlon.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord_latlon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord_merc.F90 b/lis/utils/restartGenAFWA/compute_grid_coord_merc.F90 index 6db653d24..e1d02cc18 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord_merc.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord_merc.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_grid_coord_polar.F90 b/lis/utils/restartGenAFWA/compute_grid_coord_polar.F90 index cabd76d16..d8684f83e 100644 --- a/lis/utils/restartGenAFWA/compute_grid_coord_polar.F90 +++ b/lis/utils/restartGenAFWA/compute_grid_coord_polar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/compute_stnwts.F90 b/lis/utils/restartGenAFWA/compute_stnwts.F90 index d2c883748..9e0ef6517 100644 --- a/lis/utils/restartGenAFWA/compute_stnwts.F90 +++ b/lis/utils/restartGenAFWA/compute_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/conserv_interp.F90 b/lis/utils/restartGenAFWA/conserv_interp.F90 index a2fb66de3..e3196fcfb 100644 --- a/lis/utils/restartGenAFWA/conserv_interp.F90 +++ b/lis/utils/restartGenAFWA/conserv_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/conserv_interp_input.F90 b/lis/utils/restartGenAFWA/conserv_interp_input.F90 index f0d67b345..cc399415e 100644 --- a/lis/utils/restartGenAFWA/conserv_interp_input.F90 +++ b/lis/utils/restartGenAFWA/conserv_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/createLISrestart.F90 b/lis/utils/restartGenAFWA/createLISrestart.F90 index 93de9464b..9351da778 100644 --- a/lis/utils/restartGenAFWA/createLISrestart.F90 +++ b/lis/utils/restartGenAFWA/createLISrestart.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/gausslat.F90 b/lis/utils/restartGenAFWA/gausslat.F90 index a68dce991..bf35a87cc 100644 --- a/lis/utils/restartGenAFWA/gausslat.F90 +++ b/lis/utils/restartGenAFWA/gausslat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/get_fieldpos.F90 b/lis/utils/restartGenAFWA/get_fieldpos.F90 index d0f46a929..df275c6de 100644 --- a/lis/utils/restartGenAFWA/get_fieldpos.F90 +++ b/lis/utils/restartGenAFWA/get_fieldpos.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/interp_stndata.F90 b/lis/utils/restartGenAFWA/interp_stndata.F90 index f932c36ce..4591816d4 100644 --- a/lis/utils/restartGenAFWA/interp_stndata.F90 +++ b/lis/utils/restartGenAFWA/interp_stndata.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/latlonTopolar.F90 b/lis/utils/restartGenAFWA/latlonTopolar.F90 index 55df36918..365662ce0 100644 --- a/lis/utils/restartGenAFWA/latlonTopolar.F90 +++ b/lis/utils/restartGenAFWA/latlonTopolar.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/lltops.F90 b/lis/utils/restartGenAFWA/lltops.F90 index 4f3661ab7..7812c9917 100644 --- a/lis/utils/restartGenAFWA/lltops.F90 +++ b/lis/utils/restartGenAFWA/lltops.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/map_utils.F90 b/lis/utils/restartGenAFWA/map_utils.F90 index a188ace6c..98e842f80 100644 --- a/lis/utils/restartGenAFWA/map_utils.F90 +++ b/lis/utils/restartGenAFWA/map_utils.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/neighbor_interp.F90 b/lis/utils/restartGenAFWA/neighbor_interp.F90 index 98f4dbf88..6d549a415 100644 --- a/lis/utils/restartGenAFWA/neighbor_interp.F90 +++ b/lis/utils/restartGenAFWA/neighbor_interp.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/neighbor_interp_input.F90 b/lis/utils/restartGenAFWA/neighbor_interp_input.F90 index 662e727e0..e94888036 100644 --- a/lis/utils/restartGenAFWA/neighbor_interp_input.F90 +++ b/lis/utils/restartGenAFWA/neighbor_interp_input.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/normalize_stnwts.F90 b/lis/utils/restartGenAFWA/normalize_stnwts.F90 index 0f8e5d480..d95252415 100644 --- a/lis/utils/restartGenAFWA/normalize_stnwts.F90 +++ b/lis/utils/restartGenAFWA/normalize_stnwts.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/polarToLatLon.F90 b/lis/utils/restartGenAFWA/polarToLatLon.F90 index 700249857..da44ae1b4 100644 --- a/lis/utils/restartGenAFWA/polarToLatLon.F90 +++ b/lis/utils/restartGenAFWA/polarToLatLon.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/polfixs.F90 b/lis/utils/restartGenAFWA/polfixs.F90 index 303b0358a..10fdcf36c 100644 --- a/lis/utils/restartGenAFWA/polfixs.F90 +++ b/lis/utils/restartGenAFWA/polfixs.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/restartGenAFWA/pstoll.F90 b/lis/utils/restartGenAFWA/pstoll.F90 index 0a8818363..165f0cd44 100644 --- a/lis/utils/restartGenAFWA/pstoll.F90 +++ b/lis/utils/restartGenAFWA/pstoll.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/ueinit_generator/generateUEinitFile.F90 b/lis/utils/ueinit_generator/generateUEinitFile.F90 index 9ee337c5b..d74b29995 100644 --- a/lis/utils/ueinit_generator/generateUEinitFile.F90 +++ b/lis/utils/ueinit_generator/generateUEinitFile.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/dump2lis_nsmax1.py b/lis/utils/usaf/dump2lis_nsmax1.py index 99a502188..de0d2255a 100755 --- a/lis/utils/usaf/dump2lis_nsmax1.py +++ b/lis/utils/usaf/dump2lis_nsmax1.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/dump2lis_nsmax3.py b/lis/utils/usaf/dump2lis_nsmax3.py index 52ec46b5f..e05d2abda 100755 --- a/lis/utils/usaf/dump2lis_nsmax3.py +++ b/lis/utils/usaf/dump2lis_nsmax3.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/autotune.py b/lis/utils/usaf/retune_bratseth/scripts/autotune.py index 6cf405b98..196c65037 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/autotune.py +++ b/lis/utils/usaf/retune_bratseth/scripts/autotune.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py b/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py index 2f6a3bfce..5b625f755 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py +++ b/lis/utils/usaf/retune_bratseth/scripts/create_blacklist.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/customize_lis_config.py b/lis/utils/usaf/retune_bratseth/scripts/customize_lis_config.py index 03af46bd6..8c961bfd7 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/customize_lis_config.py +++ b/lis/utils/usaf/retune_bratseth/scripts/customize_lis_config.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_nwp.py b/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_nwp.py index 50f72cb9d..a87c98ad3 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_nwp.py +++ b/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_nwp.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_sat.py b/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_sat.py index abcf23521..7d18cdda7 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_sat.py +++ b/lis/utils/usaf/retune_bratseth/scripts/customize_procoba_sat.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/fit_semivariogram.py b/lis/utils/usaf/retune_bratseth/scripts/fit_semivariogram.py index 67c917e2a..159db6a92 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/fit_semivariogram.py +++ b/lis/utils/usaf/retune_bratseth/scripts/fit_semivariogram.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/plot_semivariogram.py b/lis/utils/usaf/retune_bratseth/scripts/plot_semivariogram.py index 4e9be275b..3947ce259 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/plot_semivariogram.py +++ b/lis/utils/usaf/retune_bratseth/scripts/plot_semivariogram.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/rescale_sat_sigma2.py b/lis/utils/usaf/retune_bratseth/scripts/rescale_sat_sigma2.py index 761ef3913..76558c6e2 100755 --- a/lis/utils/usaf/retune_bratseth/scripts/rescale_sat_sigma2.py +++ b/lis/utils/usaf/retune_bratseth/scripts/rescale_sat_sigma2.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/scripts/semivar.py b/lis/utils/usaf/retune_bratseth/scripts/semivar.py index bfd04f853..eee964d95 100644 --- a/lis/utils/usaf/retune_bratseth/scripts/semivar.py +++ b/lis/utils/usaf/retune_bratseth/scripts/semivar.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/USAF_GridHashMod.F90 b/lis/utils/usaf/retune_bratseth/src/USAF_GridHashMod.F90 index 0ea13f5e8..9f10f67a1 100644 --- a/lis/utils/usaf/retune_bratseth/src/USAF_GridHashMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/USAF_GridHashMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/USAF_ReportsMod.F90 b/lis/utils/usaf/retune_bratseth/src/USAF_ReportsMod.F90 index 723880068..0da179057 100644 --- a/lis/utils/usaf/retune_bratseth/src/USAF_ReportsMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/USAF_ReportsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/USAF_StationsMod.F90 b/lis/utils/usaf/retune_bratseth/src/USAF_StationsMod.F90 index 50d5e77a9..34ea3e561 100644 --- a/lis/utils/usaf/retune_bratseth/src/USAF_StationsMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/USAF_StationsMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/USAF_sharedMod.F90 b/lis/utils/usaf/retune_bratseth/src/USAF_sharedMod.F90 index 9135a519d..71207116c 100644 --- a/lis/utils/usaf/retune_bratseth/src/USAF_sharedMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/USAF_sharedMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/future/USAF_StnOBDictMod.F90 b/lis/utils/usaf/retune_bratseth/src/future/USAF_StnOBDictMod.F90 index 1805c1924..d5be2990e 100644 --- a/lis/utils/usaf/retune_bratseth/src/future/USAF_StnOBDictMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/future/USAF_StnOBDictMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/future/USAF_readFilesMod.F90 b/lis/utils/usaf/retune_bratseth/src/future/USAF_readFilesMod.F90 index 1afda152c..e62c3f5df 100644 --- a/lis/utils/usaf/retune_bratseth/src/future/USAF_readFilesMod.F90 +++ b/lis/utils/usaf/retune_bratseth/src/future/USAF_readFilesMod.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/procOBA_NWP.F90 b/lis/utils/usaf/retune_bratseth/src/procOBA_NWP.F90 index cf721a749..ad430148f 100644 --- a/lis/utils/usaf/retune_bratseth/src/procOBA_NWP.F90 +++ b/lis/utils/usaf/retune_bratseth/src/procOBA_NWP.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/retune_bratseth/src/procOBA_Sat.F90 b/lis/utils/usaf/retune_bratseth/src/procOBA_Sat.F90 index 6d085647b..d081420fa 100644 --- a/lis/utils/usaf/retune_bratseth/src/procOBA_Sat.F90 +++ b/lis/utils/usaf/retune_bratseth/src/procOBA_Sat.F90 @@ -1,9 +1,9 @@ !-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- ! NASA Goddard Space Flight Center ! Land Information System Framework (LISF) -! Version 7.4 +! Version 7.5 ! -! Copyright (c) 2022 United States Government as represented by the +! Copyright (c) 2024 United States Government as represented by the ! Administrator of the National Aeronautics and Space Administration. ! All Rights Reserved. !-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/rose2lis.py b/lis/utils/usaf/rose2lis.py index 7133b234c..23af73cca 100755 --- a/lis/utils/usaf/rose2lis.py +++ b/lis/utils/usaf/rose2lis.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/global_usaf_forc/customize_lis_config.py b/lis/utils/usaf/s2s/global_usaf_forc/customize_lis_config.py index f98d20b08..422c57198 100755 --- a/lis/utils/usaf/s2s/global_usaf_forc/customize_lis_config.py +++ b/lis/utils/usaf/s2s/global_usaf_forc/customize_lis_config.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/global_usaf_forc/store_lis_output.py b/lis/utils/usaf/s2s/global_usaf_forc/store_lis_output.py index 3d4f52880..d8b62da33 100755 --- a/lis/utils/usaf/s2s/global_usaf_forc/store_lis_output.py +++ b/lis/utils/usaf/s2s/global_usaf_forc/store_lis_output.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/check_cfsv2_bcsd.py b/lis/utils/usaf/s2s/s2s_app/check_cfsv2_bcsd.py index 8b6e2713c..f7876ab95 100644 --- a/lis/utils/usaf/s2s/s2s_app/check_cfsv2_bcsd.py +++ b/lis/utils/usaf/s2s/s2s_app/check_cfsv2_bcsd.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/check_disaggr_bcsd.py b/lis/utils/usaf/s2s/s2s_app/check_disaggr_bcsd.py index c5e2da71c..fe8fbf44c 100644 --- a/lis/utils/usaf/s2s/s2s_app/check_disaggr_bcsd.py +++ b/lis/utils/usaf/s2s/s2s_app/check_disaggr_bcsd.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/check_nmme_bcsd.py b/lis/utils/usaf/s2s/s2s_app/check_nmme_bcsd.py index 885ed4ac3..2993426fd 100644 --- a/lis/utils/usaf/s2s/s2s_app/check_nmme_bcsd.py +++ b/lis/utils/usaf/s2s/s2s_app/check_nmme_bcsd.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/check_nmme_ncep.py b/lis/utils/usaf/s2s/s2s_app/check_nmme_ncep.py index 8a8f9bf97..4885c9da7 100644 --- a/lis/utils/usaf/s2s/s2s_app/check_nmme_ncep.py +++ b/lis/utils/usaf/s2s/s2s_app/check_nmme_ncep.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/nctool.py b/lis/utils/usaf/s2s/s2s_app/nctool.py index 57c0e542c..1525f28ae 100644 --- a/lis/utils/usaf/s2s/s2s_app/nctool.py +++ b/lis/utils/usaf/s2s/s2s_app/nctool.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/s2s_api.py b/lis/utils/usaf/s2s/s2s_app/s2s_api.py index 632b5677b..905f82a96 100644 --- a/lis/utils/usaf/s2s/s2s_app/s2s_api.py +++ b/lis/utils/usaf/s2s/s2s_app/s2s_api.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh index 94c24d9d6..480a70184 100644 --- a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh +++ b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh @@ -3,12 +3,12 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 -# -# Copyright (c) 2022 United States Government as represented by the +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. -# -------------------------END NOTICE -- DO NOT EDIT----------------------- +#-------------------------END NOTICE -- DO NOT EDIT----------------------- # source and load shared functions from s2s_run.sh source s2s_app/s2s_run.sh --source-only diff --git a/lis/utils/usaf/s2s/s2s_app/s2s_run.sh b/lis/utils/usaf/s2s/s2s_app/s2s_run.sh index 86eb46d4c..ee791f6d6 100755 --- a/lis/utils/usaf/s2s/s2s_app/s2s_run.sh +++ b/lis/utils/usaf/s2s/s2s_app/s2s_run.sh @@ -3,12 +3,12 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 -# -# Copyright (c) 2022 United States Government as represented by the +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. -# -------------------------END NOTICE -- DO NOT EDIT----------------------- +#-------------------------END NOTICE -- DO NOT EDIT----------------------- # # Purpose: GHI-S2S End-to-End (E2E) subsystem runtime script # diff --git a/lis/utils/usaf/s2s/s2s_app/verify_tiff.py b/lis/utils/usaf/s2s/s2s_app/verify_tiff.py index 8e5c20ca0..aac63f3b8 100644 --- a/lis/utils/usaf/s2s/s2s_app/verify_tiff.py +++ b/lis/utils/usaf/s2s/s2s_app/verify_tiff.py @@ -5,9 +5,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh index 28f3b2099..9f5f797f5 100755 --- a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh +++ b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh @@ -3,12 +3,12 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 -# -# Copyright (c) 2022 United States Government as represented by the +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. -# -------------------------END NOTICE -- DO NOT EDIT----------------------- +#-------------------------END NOTICE -- DO NOT EDIT----------------------- # Title: CFSv2 Operational Timeseries (Oper_TS) Download Script # diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/bcsd_function.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/bcsd_function.py index 629b223ae..c80aba421 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/bcsd_function.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/bcsd_function.py @@ -5,9 +5,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/convert_forecast_data_to_netcdf.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/convert_forecast_data_to_netcdf.py index 4a5c9743e..810f242a2 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/convert_forecast_data_to_netcdf.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/convert_forecast_data_to_netcdf.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_f.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_f.py index fd2b7bf08..a4778bbc0 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_f.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_f.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py index fca553721..7479ab97b 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/process_forecast_data.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/process_forecast_data.py index 0f535825b..190a868d8 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/process_forecast_data.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/process_forecast_data.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/check_preprocess_forecast_files.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/check_preprocess_forecast_files.py index 20a6c0b10..fb5e32244 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/check_preprocess_forecast_files.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/check_preprocess_forecast_files.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_01.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_01.py index 4b31b8e29..697fc6243 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_01.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_01.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_03.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_03.py index b6b9995ef..b098180d2 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_03.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_03.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_04.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_04.py index f22c5e5d8..d5d68dfb5 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_04.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_04.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_05.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_05.py index 9af39fd04..660120d42 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_05.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_05.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_06.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_06.py index 32a225787..6c873a69c 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_06.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_06.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_07.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_07.py index 0bd91c1f1..b00a7cc8e 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_07.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_07.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_08.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_08.py index 97e343a89..211d86476 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_08.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_08.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_09.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_09.py index 276779d90..6724114e8 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_09.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_09.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_10.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_10.py index 9647afd73..97979eda6 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_10.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_10.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_11.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_11.py index fc3ec4413..bf2cb14a5 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_11.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_11.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_12.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_12.py index 6cb802a3b..e56073165 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_12.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/forecast_task_12.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/ldt_ics/generate_ldtconfig_files_ensrst_nrt.py b/lis/utils/usaf/s2s/s2s_modules/ldt_ics/generate_ldtconfig_files_ensrst_nrt.py index b119275b4..482f7a84f 100644 --- a/lis/utils/usaf/s2s/s2s_modules/ldt_ics/generate_ldtconfig_files_ensrst_nrt.py +++ b/lis/utils/usaf/s2s/s2s_modules/ldt_ics/generate_ldtconfig_files_ensrst_nrt.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/lis_darun/generate_lisda_config_nrt.py b/lis/utils/usaf/s2s/s2s_modules/lis_darun/generate_lisda_config_nrt.py index 2bc46aa49..3481acb7e 100644 --- a/lis/utils/usaf/s2s/s2s_modules/lis_darun/generate_lisda_config_nrt.py +++ b/lis/utils/usaf/s2s/s2s_modules/lis_darun/generate_lisda_config_nrt.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/lis_fcst/generate_lis_config_scriptfiles_fcst.py b/lis/utils/usaf/s2s/s2s_modules/lis_fcst/generate_lis_config_scriptfiles_fcst.py index c9555a052..561d7bb1f 100644 --- a/lis/utils/usaf/s2s/s2s_modules/lis_fcst/generate_lis_config_scriptfiles_fcst.py +++ b/lis/utils/usaf/s2s/s2s_modules/lis_fcst/generate_lis_config_scriptfiles_fcst.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2smetric/convert_s2s_anom_cf.py b/lis/utils/usaf/s2s/s2s_modules/s2smetric/convert_s2s_anom_cf.py index 81fbeefcd..820168093 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2smetric/convert_s2s_anom_cf.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2smetric/convert_s2s_anom_cf.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2smetric/make_s2s_median_metric_geotiff.py b/lis/utils/usaf/s2s/s2s_modules/s2smetric/make_s2s_median_metric_geotiff.py index 20c3b0977..9f7066490 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2smetric/make_s2s_median_metric_geotiff.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2smetric/make_s2s_median_metric_geotiff.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2smetric/merge_s2s_anom_cf.py b/lis/utils/usaf/s2s/s2s_modules/s2smetric/merge_s2s_anom_cf.py index 464f24b08..62db7cb09 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2smetric/merge_s2s_anom_cf.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2smetric/merge_s2s_anom_cf.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_anom_verify.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_anom_verify.py index 8a2ee8be0..a90ffa6d5 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_anom_verify.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_anom_verify.py @@ -1,9 +1,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_hybas.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_hybas.py index 7525ccd58..d717d99ed 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_hybas.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_hybas.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_mena.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_mena.py index 8ad0d6657..e5386afa8 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_mena.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_mena.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_s2smetrics.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_s2smetrics.py index 14d1d2ea0..417844626 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_s2smetrics.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_s2smetrics.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_streamflow_anom.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_streamflow_anom.py index 9fed34f9c..3529abffb 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_streamflow_anom.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_streamflow_anom.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_utils.py b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_utils.py index d35e17a53..d4fb256bf 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_utils.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2splots/plot_utils.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2spost/daily_s2spost_nc.py b/lis/utils/usaf/s2s/s2s_modules/s2spost/daily_s2spost_nc.py index 7f8dc0e52..481d45535 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2spost/daily_s2spost_nc.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2spost/daily_s2spost_nc.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2spost/monthly_s2spost_nc.py b/lis/utils/usaf/s2s/s2s_modules/s2spost/monthly_s2spost_nc.py index 97be650d1..4bc67e4a1 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2spost/monthly_s2spost_nc.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2spost/monthly_s2spost_nc.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_1month.py b/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_1month.py index f503aee49..9324d20f1 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_1month.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_1month.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_9months.py b/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_9months.py index 81f3da990..3e85ed680 100644 --- a/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_9months.py +++ b/lis/utils/usaf/s2s/s2s_modules/s2spost/run_s2spost_9months.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_modules/shared/utils.py b/lis/utils/usaf/s2s/s2s_modules/shared/utils.py index aab68a57a..562a1bd62 100644 --- a/lis/utils/usaf/s2s/s2s_modules/shared/utils.py +++ b/lis/utils/usaf/s2s/s2s_modules/shared/utils.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/surf2lisnc_3_17km_4pt.py b/lis/utils/usaf/surf2lisnc_3_17km_4pt.py index 263fc635e..46f981dfd 100755 --- a/lis/utils/usaf/surf2lisnc_3_17km_4pt.py +++ b/lis/utils/usaf/surf2lisnc_3_17km_4pt.py @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 +# Version 7.5 # -# Copyright (c) 2022 United States Government as represented by the +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. #-------------------------END NOTICE -- DO NOT EDIT----------------------- From 33ac5c8ddedc858dc62226ba495747241b66dceb Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 4 Jan 2024 13:00:43 -0500 Subject: [PATCH 260/328] Delete backup file --- .../src/rapid_Vlat_30Apr2021.back | 337 ------------------ 1 file changed, 337 deletions(-) delete mode 100755 lis/routing/RAPID_router/src/rapid_Vlat_30Apr2021.back diff --git a/lis/routing/RAPID_router/src/rapid_Vlat_30Apr2021.back b/lis/routing/RAPID_router/src/rapid_Vlat_30Apr2021.back deleted file mode 100755 index 8beae689a..000000000 --- a/lis/routing/RAPID_router/src/rapid_Vlat_30Apr2021.back +++ /dev/null @@ -1,337 +0,0 @@ -!******************************************************************************* -!Subroutine - rapid_Vlat -!******************************************************************************* -subroutine rapid_Vlat(runoff_nc_file) - -!PURPOSE -!This coupler allows to convert runoff information from a land surface model -!to a volume of water entering RAPID river reaches. - -!Dec 17, 2020: Yeosang Yoon, Initial Implementation - -#include -use petscvec -use netcdf - -!use rapid_var, only : & -! rank,ierr,IS_nc_status,IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat, & -! IS_nc_id_var_time,IS_nc_id_var_time_bnds,IS_nc_id_var_crs, & -! IS_nc_id_var_lon,IS_nc_id_var_lat,IS_nc_id_var_Vlat_err, & -! IS_riv_tot,IS_riv_bas,IS_time,JS_time,ZS_TauR, & -! YV_title,YV_institution,YV_comment, & -! YV_time_units,ZS_crs_sma,ZS_crs_iflat, & -! ZV_riv_tot_lon,ZV_riv_tot_lat,IV_time,IM_time_bnds, & -! ZV_riv_tot_bQlat,ZV_riv_tot_vQlat,ZV_riv_tot_caQlat,ZS_dtUQ, & -! ZV_riv_tot_cdownQlat,IS_radius, & -! IV_nc_start,IV_nc_count, & -! IV_riv_loc1,IV_riv_index,ZV_read_riv_tot,ZV_Vlat, & -! Runoff_path,Weight_table_file - -use rapid_var, only : & - rank,ierr,IS_time,JS_time,IS_riv_bas, & - ZS_TauR,ZS_crs_sma,ZS_crs_iflat, & - IV_time,IM_time_bnds,IV_riv_loc1,IV_riv_index, & - ZV_read_riv_tot,ZV_Vlat,Runoff_path,weight_table_file - -implicit none - -!******************************************************************************* -!Declaration of variables -!******************************************************************************* -! Arguments -character(len=200), intent(in) :: runoff_nc_file -!character(len=256) :: m3_nc_file - -! Weight table file -integer, dimension(:), allocatable :: rivid ! ID of the each river reach -integer, dimension(:), allocatable :: npt ! -integer, dimension(:), allocatable :: idx_i,idx_j ! i,j index of the grid cell where the contributing catchment centroid -real, dimension(:), allocatable :: area_sqm ! area of its contributing catchment in m2 -real, dimension(:), allocatable :: lat, lon ! lat, lon of LSM - -!character(len=256) :: weight_table_file -character(len=200) :: buf -integer :: nreach -integer :: ncid, var_runsf, var_runsb ! variables for netcdf - -! Runoff data are in kg/m2 accumulated over a time step -real, dimension(:,:), allocatable :: runsf ! surface runoff -real, dimension(:,:), allocatable :: runsb ! subsurface runoff -integer :: nlon, nlat - - -integer :: nreach_new -integer :: col, row ! -real :: conversion_factor=0.001 !convert from kg/m^2 (i.e. mm) to m - -integer, dimension(:), allocatable :: rivid_new -real, dimension(:), allocatable :: m3_riv ! inflow data to RAPID river reaches are in m3 accumulated over a time step -real :: m3_riv_np - -integer :: eof, status -integer :: i,j,k -!integer :: dim_rivid, dim_time, dimids(2) ! variables for netcdf -!integer :: var_m3_riv, var_rivid ! variables for netcdf - -!******************************************************************************* -! Reads weight_table file -!******************************************************************************* -! check number of reach in wieght table file -open(45,file=weight_table_file,status='old',action='read') -read(45,'(A)',iostat=eof) buf ! read header in weight table -nreach=1; -do - read(45,*,iostat=eof) buf - if (eof/=0) exit - - nreach=nreach+1 -end do -nreach=nreach-1 ! adjust size -close(45) - -! allocate sizes -allocate(rivid(nreach)) -allocate(area_sqm(nreach)) -allocate(idx_i(nreach)) -allocate(idx_j(nreach)) -allocate(npt(nreach)) -allocate(lat(nreach)) -allocate(lon(nreach)) - -! read weight table file -open(45,file=weight_table_file,status='old',action='read') -read(45,'(A)',iostat=eof) buf ! read header in weight table - -nreach=1 -do - read(45,*,iostat=eof) rivid(nreach),area_sqm(nreach), & - idx_i(nreach),idx_j(nreach),npt(nreach),lon(nreach),lat(nreach) - if (eof/=0) exit - nreach=nreach+1 -end do -nreach=nreach-1 -close(45) - -!------------------------------------------------------------------------------- -!Read runoff file -!------------------------------------------------------------------------------- -! initialization -nlon=192 -nlat=372 - -allocate(runsf(nlon,nlat)) -allocate(runsb(nlon,nlat)) - -runsf(1:nlon,1:nlat)=0 -runsb(1:nlon,1:nlat)=0 - -! open the file. NF90_NOWRITE tells netCDF we want read-only access to the file -status=nf90_open(trim(runoff_nc_file), NF90_NOWRITE, ncid) - -! get the varid of the data variable, based on its name -status=nf90_inq_varid(ncid,'Qs_inst', var_runsf) -status=nf90_inq_varid(ncid,'Qsb_inst', var_runsb) -! read the data. -status=nf90_get_var(ncid, var_runsf, runsf) -status=nf90_get_var(ncid, var_runsb, runsb) -! close the file, freeing all resources. -status=nf90_close(ncid) - -!------------------------------------------------------------------------------- -! Obtain a new subset of data & Calculate water inflows -!------------------------------------------------------------------------------- -! initialization -j=1 -k=1 -allocate(m3_riv(IS_riv_bas)) -allocate(rivid_new(IS_riv_bas)) - -do i=1,nreach - m3_riv(k)=0; - - ! check if all npoints points correspond to the same streamID - if (npt(i) > 1) then - if (i > 1 .AND. (rivid(i-1) == rivid(i))) CYCLE - - do j=1,npt(i) - col=idx_i(i+j-1)+1 - row=idx_j(i+j-1)+1 - - !Set negative values to zero including fill values (i.e., -9999) - if (runsf(col,row)<0) runsf(col,row)=0 - if (runsb(col,row)<0) runsb(col,row)=0 - - ! combine data - m3_riv_np=(runsf(col,row) & - +runsb(col,row))*ZS_TauR & !kg m-2 s-1 -> kg m-2 - *area_sqm(i+j-1)*conversion_factor !kg m-2 (mm) -> m - m3_riv(k)=m3_riv(k)+m3_riv_np - - end do - rivid_new(k)=rivid(i) - k=k+1 - else - col=idx_i(i)+1 - row=idx_j(i)+1 - - !Set negative values to zero including fill values (i.e., -9999) - if (runsf(col,row)<0) runsf(col,col)=0 - if (runsb(col,row)<0) runsb(col,col)=0 - - m3_riv(k)=(runsf(col,row) & - +runsb(col,row))*ZS_TauR & !kg m-2 s-1 -> kg m-2 - *area_sqm(i)*conversion_factor !kg m-2 (mm) -> m - - rivid_new(k)=rivid(k) - k=k+1 - end if -end do - -nreach_new=k-1 - -!******************************************************************************* -! open Vlat_file (from rapid_open_Vlat_file.F90) -!******************************************************************************* - -!if (rank==0) then -! open(99,file=Vlat_file,status='old') -! close(99) -! IS_nc_status=NF90_OPEN(Vlat_file,NF90_NOWRITE,IS_nc_id_fil_Vlat) -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'m3_riv',IS_nc_id_var_Vlat) -! if (IS_nc_status<0) IS_nc_id_var_Vlat=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'time',IS_nc_id_var_time) -! if (IS_nc_status<0) IS_nc_id_var_time=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'time_bnds', \ -! IS_nc_id_var_time_bnds) -! if (IS_nc_status<0) IS_nc_id_var_time_bnds=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'lon',IS_nc_id_var_lon) -! if (IS_nc_status<0) IS_nc_id_var_lon=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'lat',IS_nc_id_var_lat) -! if (IS_nc_status<0) IS_nc_id_var_lat=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'crs',IS_nc_id_var_crs) -! if (IS_nc_status<0) IS_nc_id_var_crs=-9999 -! IS_nc_status=NF90_INQ_VARID(IS_nc_id_fil_Vlat,'m3_riv_err', \ -! IS_nc_id_var_Vlat_err) -! if (IS_nc_status<0) IS_nc_id_var_Vlat_err=-9999 - !A negative value for IS_nc_id_var_* is used if the variable doesn't exist, - !this is because the default value of "1" might match another existing - !variable. -!end if - -!******************************************************************************* -! set metadata for Vlat_file (from rapid_meta_Vlat_file.F90) -!******************************************************************************* -!Read global attributes -!if (rank==0) then -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,NF90_GLOBAL, \ -! "title", YV_title) -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,NF90_GLOBAL, \ -! "institution", YV_institution) -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,NF90_GLOBAL, \ -! "comment", YV_comment) -!end if - -!Read variable attributes -if (rank==0) then -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,IS_nc_id_var_time, \ -! "units", YV_time_units) -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,IS_nc_id_var_crs, \ -! "semi_major_axis", ZS_crs_sma) -! IS_nc_status=NF90_GET_ATT(IS_nc_id_fil_Vlat,IS_nc_id_var_crs, \ -! "inverse_flattening", ZS_crs_iflat) - - ZS_crs_sma=6378137.0 ! semi major axis of the spheroid - ZS_crs_iflat=298.257223563 ! inverse flattening of the spheroid -end if - -!Read space and time variable values -! TODO: re-review lon/lat, time, time_bnds variables -!if (rank==0) then -! if (IS_nc_id_var_lon>=0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_lon, \ -! ZV_riv_tot_lon,(/1/),(/IS_riv_tot/)) -! end if -! if (IS_nc_id_var_lat>=0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_lat, \ -! ZV_riv_tot_lat,(/1/),(/IS_riv_tot/)) -! end if -! if (IS_nc_id_var_time>=0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_time, \ -! IV_time,(/1/),(/IS_time/)) -! end if -! if (IS_nc_id_var_time_bnds>=0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_time_bnds, \ -! IM_time_bnds,(/1,1/),(/2,IS_time/)) -! end if -!end if - -!Read uncertainty quantification inputs, convert from volume to flow -! TODO: re-review later -!if (rank==0) then -! if (IS_nc_id_var_Vlat_err>=0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat_err, \ -! ZV_riv_tot_bQlat,(/1,1/),(/IS_riv_tot,1/)) -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat_err, \ -! ZV_riv_tot_vQlat,(/1,2/),(/IS_riv_tot,1/)) -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat_err, \ -! ZV_riv_tot_caQlat,(/1,3/),(/IS_riv_tot,1/)) -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat_err, \ -! ZV_riv_tot_cdownQlat,(/1,4/),(/IS_riv_tot,IS_radius/)) - -! ZV_riv_tot_bQlat=sign(sqrt(abs(ZV_riv_tot_bQlat)),ZV_riv_tot_bQlat)/ZS_dtUQ -! ZV_riv_tot_vQlat=ZV_riv_tot_vQlat/(ZS_dtUQ**2) -! ZV_riv_tot_caQlat=ZV_riv_tot_caQlat/(ZS_dtUQ**2) -! ZV_riv_tot_cdownQlat=ZV_riv_tot_cdownQlat/(ZS_dtUQ**2) -! end if -!end if - -!Check temporal consistency if metadata present -if (IV_time(1)/=-9999) then - do JS_time=1,IS_time-1 - if (IV_time(JS_time+1)-IV_time(JS_time)/=int(ZS_TauR)) then - !Checking that interval between values of the time variable is ZS_TauR - print '(a53)','Inconsistent time intervals in namelist and Vlat_file' - stop 99 - end if - end do -end if - -if (IM_time_bnds(1,1)/=-9999) then - do JS_time=1,IS_time-1 - if (IM_time_bnds(1,JS_time+1)-IM_time_bnds(1,JS_time)/=int(ZS_TauR)) then - !Checking that interval between values of the time_bnd variable is ZS_TauR - print '(a53)','Inconsistent time intervals in namelist and Vlat_file' - stop 99 - end if - end do - do JS_time=1,IS_time - if (IM_time_bnds(2,JS_time)-IM_time_bnds(1,JS_time)/=int(ZS_TauR)) then - !Checking that interval for each value of the time_bnd variable is ZS_TauR - print '(a53)','Inconsistent time intervals in namelist and Vlat_file' - stop 99 - end if - end do -end if - -!******************************************************************************* -! Read Vlat_file (from rapid_read_Vlat_file.F90) -!******************************************************************************* - -! read file -if (rank==0) then -! IS_nc_status=NF90_GET_VAR(IS_nc_id_fil_Vlat,IS_nc_id_var_Vlat, & -! ZV_read_riv_tot,IV_nc_start,IV_nc_count) - ZV_read_riv_tot=m3_riv(1:nreach_new) -end if - -! Set values in PETSc vector -if (rank==0) then - call VecSetValues(ZV_Vlat,IS_riv_bas,IV_riv_loc1, & - ZV_read_riv_tot(IV_riv_index),INSERT_VALUES,ierr) -end if - -! Assemble PETSc vector -call VecAssemblyBegin(ZV_Vlat,ierr) -call VecAssemblyEnd(ZV_Vlat,ierr) - -end subroutine rapid_Vlat From a2aac68cefbe9b9eff3ac1e293d58df3990f9a91 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 4 Jan 2024 13:13:59 -0500 Subject: [PATCH 261/328] Update copyright notice on LIS files for LISF 7.5.0 public release --- .../lis-mit/LIS-MIT-with-Noah-MP-V4-2021.xlsm | Bin 170073 -> 169303 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/lis/utils/lis-mit/LIS-MIT-with-Noah-MP-V4-2021.xlsm b/lis/utils/lis-mit/LIS-MIT-with-Noah-MP-V4-2021.xlsm index a6ee817b0fe19e3a067c3ccea65846482a7485c1..4fc7cf69ccceba5e0e8831a3a0d7f77512b1534d 100644 GIT binary patch delta 158925 zcmY&<19)UXvuJGFww+C~@y6!Hw(Vr%Y?6&_+qP}nw(Xbw?|t{(_f37L&y>3QbX9kq znx2(vn59yf>TGC$1~ClkFeng^FBA|EA`lRen-!z0t%Ie3t*s@4o3&NG>YB|S2a-4A zG=S)tLCJMZC_ZRUYDr)fM}os0&MdXDIYvAo-vF}b(=+6j-Gy*gn>a^2#?kGEqseg@ zV_NC2DlOa`qsV~BDC8t*`arFN=e556Gkqhv1XvB45yyAHApEDp$D8eM%L3g)$qpi* zXo{hr24~Sf`ruW?C&j5!$?7!P3b4W*B!!FV4AMO<6_O~gK9V#vWSb;LudG-WEogtE z&@5>fE--%G#cE{R!YHKiY7Fp!{#N*yohMLIfk$#wfO%W=H&CvzYK@hgbB7+<1cP2R zdzRYazs`XMJn{6*52z;SX<#?hIG5@TdJ&~)G zL{vLLrn?4U(*v0|XpD5b^M@wlH3vPvT2M=VHYYITI)7kRXyr@(m9#i_Bc{{cZ-y0a zI2=NR7HuuD#Zl9{1&JW>+ANL8pD z`AD|&F9aJu97B5Cof_prQWl_I=Vs`|cQZTv1&CO}wLg-%!GBG~p3u4ZTs`g*;jQ=U z{FENr{PEWiiXYBa)Q9on@ty6@E}AiSZC7vn!*9rO0y20%&_Hv`&*DwAc47pXQ#yPV zfNtI_vkt!f6A@k6)P|H-8;qg0h$2cE_P0k)HX)opYQXinUM^dJ6zm3!p_~;FO^8gc zV_FxkCMO1ObA+tb_9)MC{}D%}otiDp%wG!)?`+6Po@MeQ7hQMttn(Ru^|Z#?O&*&S z@xz}FA*wRg)9V+U8S8!PLrr7fYPZrL2ZPCrpoi$B^jke+@z<%cx`fReI zF_;u_!?R`Caf5N zPK2F6$w;>Pw=P1!V1N)WHI5H|4)r~B#UV+d!)(6hWUQeA0cE)pd+p4t@zN2hpFp?J4KHAqB zgv%}~B3>!En)4pTNBRA0CWU*jadod?rjiyZX?$_Lwvs%*xo#+{oM2o+E&PuvT~qzcOoxm|AoB&kd{=sz9X z8X}cv-n8H#@qas!g>Ol4oDY|4TeR+|OZq@w6ooL?CuL*yKRVpL2p_UG1tg938G;}x z>md?c2x6fC_{M%*N|h}uMHlUJr~8EY_fP(qcSX?jcDU*grzXH|h=7B1du}~~^t2lV zh$T6}KRGdS4ze`VJyKNy^1W(>U8%^raV$0bngHeYYuhxt*y>xtHa6M6CN1luS^Bc{ zL&p?rV+Y0ck2dryhAkhU>I5X(g&`cduP+)&WGe&uy>{u#)WU9RtwmWJk0RL&6*5`V0#Z{n?s8 z_%q8DQ6T`F&S?}zFId6D9bBH8TeX_A09;_t&HHF_Mv))=IdZW{QYr?Rxhr6CN?L48 zbFT$q?TL|jy4LX2_68r-9QgO31m7vRfPH;-LEBbjBI|5zCwx8B+a1F03F$5m*pWt0()&_(%nE%5 zw|pDnq)UlMkNQtxo{0I1pfs%7^vb;p&>c+jEVMJM?=B};wtXujX=Fm{V)uM)C%S5| zton-JIE>oyB+J)25E=%FgE5LQ>|@~;lJ6k3dRCSA*el1h1M)>}z$yO~s>v4gv1v5` z?F3jpJ46eHmGQCg{-1qkS-9*Q&@U@GXG=~P8yuYThQY(CjD!nYRYpm@kbhRitrf{Nqm69F{9=lBvF+oiL3v}5U*W>$W-0zR&qu5Q2uzp+&v<2uTeGM3q1%G`Vyc_B>lp7DNk)$;s!XEWoO{h z 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%0At@s&1FtE0D-uI?)Fs)o#QjJP2zwAIF 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

f~}@(k{1|jw^cWtb6O`XC~wz}Uj7nX=nf z9lZSFKVFwsOCwKn7e}$hQ^eM`iJyUj~^k2OrhS2EVk@vwMV5aO8=^HHV z9hoV+MeP)YC{<7QO7Nh@RKLQg!!omnU?^I1;r>|LHIEyEA1#G#7M`Zl->hJMw% z&4$-okp2)f^lo1Fr{7ycd_gm6tCT}=3JV%$cm4Cg+iLF@!y>t0;EUs5f9yL0+(8>_ z7R@?=LN!WJ0cfqnLMqmo1~Zos)T#eSKqLGKXw8QG^^zYl#XIngdLNZ_2mITuP-Tl% zEcmxBoPP^KTb5aK{e}^fPCa!+D+c`Qb zUn>|{HoA0_&O$B=IeDjDi+NRX+P)&Ob<|%5O~9c{8cKyS+*rMr^u}1cmnBMVqnHqL zZaKuTpae6%COM~G7eqL&r1O3BQ*{o}eN02nvaZ1!KGvGBH#U!WaPjQ7F1`0uXylo} zEA@kETzy<{2LBpKEMYf5L8+Ljup z@OJe4er#;)4{!(UjNK0RVYrXL-2rze++A>Y!+jL)AlxHxAA>stN9m5>_v3K)!TmYh zC*VE__t$Wrg8MYw18@(*{RP}#!u=K8VYr6`jHCE{6z(%{f1ic>oCqiQ!|;C|?s2#; zz&!zX4DLAG3Al&ho)qyB{oQAV7)TGUU*Ruk9=)QKb@El`&FQ@F7B5d}e2;aW?St;N za=yoU2%D_=0@Yu|S`%y6;?CUVwlg8I4ysS>>Tl@kUt>@BA%fbSwjJ2kJJ`FUaw87i zxZ{%i)I&ADe{iMfx{(uf@5~Z+J6oQrvc0Z}z1rLQp4a@#!?(F#*E)BHFLC|M6*;FJ zbk*lA|3>tjMjHv9b$*U%%VX!Y-j3FFy)SmaB=#3t{NJ@#u5nf5Ew4VO(J3MyX&GGe zIhWtRyyh+K&i4L}lK@(KPV-+&2agoGmxmq*dh?pJe+JjAQ0S2abF+7!cSeUP(i>tn zV{JCsCixK9@~4=w9n2-8*w}e=cm0_lik%H(qtaB|e;N>%)C;-EyC#8DyEO=(z0ygZK3Z9esyk;CLcxH`V zY}jWFf6r!=&&_-#lfyIP7P8^F)(uf2kzB-l^UNs1yI*ZqBdUiTnLh=zV&+?9Mp+<` zX9;ZR*>KFd!Ukn6V!oR36}BXs3)zv{ zDWEN8zRS%hlM>-Y>`2`d(EQ9-KTT*$*pb8((8`#vVG3w}Ca@`^vHoj}0*EmAo*ORe zf65Fd0%}x84@&NZbFvzC-hj`U>{iBTo|*f|NDibJQkXi1fGJbdGoQlak$9^%VIF2_ z^ufh}{Y4wuaGr@P2huyIm41maKIxuW99BKMvA~3eg3Yir^(>)`9Vplg(&K<5R?p5D zlbL+9%goa!l(7a?nR)(#*Ab7xkU8`Ee=B1XP%%mRt8-c)U$4L56O=ztF~jsVETN2L zg;UZW1I3;eypD3jfHwujQi_l=!U5gWNHHoqoj#aMnWCPBlyPs?q<9$0!6ReM>^gRO zu}R11&0C8m>=kPIBMPk37I3M*ZDnoB2#V(3>YXuco53Y)Y@&QNq83Za&02skf2LWB zkOI9;@$0afSrhN;ZOV{62e2pR8zxV)F9!Nl&rL5u8ey5?nB&^nz1Wn)zc&IK%v}V~LQN9v$j!Q0SR) zZL7CzJ+nnj*ywtbl+A}BLv2sde;UeUWZ|@W`02QrBWAZ#v>)dp$`l2ieHtl7FEjH% z_nuB3%EaZO>E&^SnTLORc_hpfU<}i#N777z`P-B!^w`_?a_K zAK@40+VE-3YxsRH8u@k6(9~@&Jmt8Pz7ltVhy4xwHr}6UYD0kaDUNkke^Z5e5rHzJ zc?r!X8#{DDI{Kg; z@*2KBmngMguKOgaZEQUYvRmNjUl^{2{|$(cAX9xQ5o(6%>GZ!*7H9itz9bNAvo%wR z21)WbHs%+hK?<|!IFm7Df9dF*hFlsHD6C%m8cPml42R=p%T^dy;j7d&A)SCv`YY+i)Fh^8a@q|iR`n@zda zMg5-*1!BH@g6X^N>5d%#mSpRCI)W4GPM9C0alvz>%Gtk6mcP1#J>rCtxv0KzPhT%0&RMuQ4ch_iN=P?AzqH$7FZT`Y8p!nS?8?7c zOWqdTKqu8`J^sM}e?Lo%xh({iGvr^xp!F>NwFxH#rSUJrj5YU+hy>CK8|Ik|b7tQ3 z(@Fd$A{`T}w^p_V_ekJcdCX>7*ao(SHL?`jJnb?p09jh~lgR+w4@!=Rd2R>mV*N9! zadu?t7BkJ?4wf(^hLu*-d=qNE5x>E=Q4a6h$p10ae-EZ^fAqXNe*G~F=-u%v7kiwh zEKn**n?_On^F%S}>$~IE1XMYV@hdu`@r!1JG~03DSA)xg%ZDp~bHcgc+;D|(MQ|Rt zVz^mwUXgY-e&@iIz|Dm#g}VT59^8BpXCZzU!CffcagjUo!;w6#46Yn*Dcmx+i{W7X z!!Cil6s`hpe}zc*PMAdee=5WO`ut_z7YA*OCIb!@ylsvB5OsaKy}820MoRLV9W)id z;o}-aY+t}F5pCP~sj=;M_IKnl4B_>5_YL`Wcb(l`VBc*kapvXEcG+k1X|K=zF~%;p zuP7y2E?Bn-JMec7IIjTp7GcC~VhlUY*iJU!WfAr;f16YB{$_Sdupt@?H#V|RpfOm} z6bSi)p+umDc>`Ez#Dg`dXhV=ClhJ+U;mRN@50+OY`Y?g(!c9Qfb}_)J)^)XGD?u;o z%=jDkw8JL1vaPSLDn&;p!FYP0Y7>ri#f)$hcEG^UF;hj?!!iHbu5JCW490eZs?MF^ zVC9KSfA_ZXf+e?Y_Or;Kf5WyLu&v|v(v5qo*h;oJWZ$wXb4yTTfgwkcUGoI5-&Y>A zZz&&~&uqaF-iPuBZ9}_REYVOM2}iITO2(_BfoL_0CIhvxSYv>NYZHl@P(0;L*7o;y z*Isng%iLN!ikZP{D0uh&toP7Iv){w_WWPraf8xE65h?^GK3hQnsotGC+j=^ZZT$o8 zMP4jiMFs<>uJU5d)qn#iGU+ev@uKAu9UcGK@5QP&)y7X}^ddBmZOZJ$WpI5khGshl zaC}TA)7v8=JUUDOH}oX=~;3CTy@v z40NufS~S5{ozBXfFs`SJ z-3uud;bAux68C=yUy87hNoV43EHM1BU%_8c1T${fO@y{VXzWwWz@t!>M!f9>tj zLCprJBJmaXO=2qozv`rCJ51bXiSTuFZ=m_01WkU>En-H&Ig~@6f-1a%BC*etEfFzHR5zzbAszZGG- zu+qVulJplO_ZsTq)@c7Dzf?W_uOM1CKVSrR7Xul!<-nmPH;L%f_SSJPB`UN4UCw)^lw%z>W-; z3|Lq9ihU*y_~`{=n?WzWf2JKEdD(09k9yr&vGbr6Cx1VP4x7iw{x5ymSrZ?6)J^)% zyjJ3g7zq}EMMwhGxBBv(zMlcHXLU?|Y=PMfUzwXjYEqDqo#R92tD$MI51)1)NI);Pwt; zEyObUy=_1Is(i(cy`IeNN2qRcR~B!|npe;#G&03U{W`n0^T5&%5=h$Z29W=DwR{0{ z*o+o&@-M_Girba9@GQJxsK(fzIe4kb?B#VVt)1b_?>8BIe-Ow$w9I(JDMoWj4X#Ms zX~iAJD-qB6YW^C|wDP;8c7taYXn;sG`9t)#BF(0=s%>h{SYHqpNGLZQgri_?~@ZEx${_p*lzzenO0wBqf z8z5Qdm6WU&_+Hw8{+v+;&$W8w zfA8gxQ+MI(F2w9cx+H!Fc-j2G1i{7T=?Q9~igiC|flXM3U=8~A^;hLcU&%2^7=5Q< zbE+1U_?=5-N^NZM8hHY zLTI}HG-i4XYKbs%Bh6w8=^Efm;$IZHf5LKn(JA+xi0e)WG)N;_3C!qJYlT&vULpDb z&FZz8E>3N%$S%1-3^;3G)u7xk9BEyXz!{_r@J0D=624mCGzM%#=m38L|A^Y-z-tok zr1|+{ak>Fqp_BJS>d#dB5dKwxO3d)8NqTSR6uq|+aEL!ZNyu>58vHu|eGA_De>n$` zoGOG`S3#3QJfs(VqM!4qiFnx5ZD7r#_JRWc6m9yafns(yh-cZE%0|zxYEA$ zo^^#!!J^FQfnm@}6WX5oQWUKp097OrLj6wffkZ7yd~d`Tofi_d&{z`XeUQS#2DQ`x z5AVbtNWH3eivE{Pu`}muE{w|be~%RN@~@N4hE}fxt`zFUd2kEh7QrpX;@pq$GP|jF zp?1@41N5+LOI|78Hce1WiFW~nO?lAZI50P${Hfh@p9@d9U|X^o<1dYv*NQ%~4ZpqU zJ0)nh%Q&Z~MbD}Qr|3lQ8XLRRK5?3{u^*ihxsVk?Ike4VVe(@1uBem-c35Fpb4rN-4pk|fdSxJQV=Xv zcclWX2Jh`idYL^p=Ga)7FuQ6da7ic^vr87|z+x69yEm(3aikk~LND1?0(E{|C1V^^ z+yd0$EKo6kI_1?t?U|^Oe>(Cn&#ENhZ*1)2Ih70{toy7E?ht`%YscI(t0g16WHlBg z`-($t$p{f48DZg}&4U(|jB-%57NEYC1u6pz|3H!LOP{u{S^f22yjr>N*x_X|{Dt=)TfMS6^~fjlhK}v}`OtnD z{_10QKXmtPO_4{>f5n3TRj}wH8UDMI8=risY(wPnozK27zv*W|8UC&3pR7Ij+f|G2 zdSC0me{^l6M~2fc4Gn{w^v~G-398?D8=(X);@Ydh63M0L5d{tC(4Dd`WSq(wRMS9f9r;(rq!v&)-8=Kn{ZKO z^D0W8XjvDJ7VpC1w}=jN)75+Z9ep)esyc<%E(M`@zH>t-?tV_s)mRk^7W68e$tFJl?6YfIAd;~c2Ja7i0>s)nf=tYueE>x(3I zGg3F;Bnw@?f3hHI=u|?#H1#Xtvxb9r0_gMGSfunXT3%jWWB}~X1&H2WxZBknDtt-*nB0)014in`HmC~Ku~fMbOgF+ z4QDHHX~u4}p-bauERp>9Zy~~Qa;XBzH3k*cfgu~wf6uVGIeiwA=|WAM$V57&=OAB_ zDj_2_HWdHnas#!Ie=$)TeI0(M(H1-AK}04R+iaE_j!_e?&ZKw#@MZ{?h;Kg%fBm9|F#7C z^-Gy=)qL_{YFavP0~*u(n|UUhKiKz?u0!DlP{p?GERf_n}QUOLET*Y?U|G03`)g!a9R6WW< z$$|0{SXwMDvklqb^HcAmKRQ)brmZ;2<{zyb?!?XS$R5DrXj3qR}# zA9K9vIqkpq4bSE)kG$mxzu^g=^@K0Qe-9h;*tah5ZaVO~CwZ7FEn$65AhcO;1$VRy|S?I$jYvQQVB#bk8;2XP>Hw{NRa2k;fKA@b{c&f4E|^ z+#yk$lm>rdCdKz^#V-pFHNZN+A% zv|5nia#JV8=avZq8BUoGSGaa{f5`aKz*|2GhSU(bkPPisZq`znn+wX+CgtYM^-5yf zW?>N3Tg9d4B-bJtJW12m!G{~f;Uft;$;nBwMe_L`e3xm%mT41M0F$J=36i)LNCR3R z%~_9klGJx7sVV18fJqW~lJ2*`;aYFV+Wdy>fb!ce()K}iU#2%qvBQpQe+8ZP!^S2! z7%}Rfu<+C$Zs20*$?Ijpf*&DaK0POguv1GuBDJF!3q*QG^bbwh8RFU~Gl@9tppdrJ zf`Yi#HfUyk-#I@@9D>Gke8JAGq&D9?gz0-r; z0|HqB(l$KHf^8LotpC9sCtfX3|sIZQ8h6DLGc$aJxr zkw$dSLfSQJ)f750%UJU)W9ek8;>jdVDaz8xk+4g|DB#&kL{nOsR0(EdmrPHOqgqNy zf{^EfsMb>Q8*Q|pC&ywcmzI!JnmoyTC6gRy_B3e(GJTQ}ydv*hfAc5H{wA+G%H$SJ zv2+sb$Szr-_$2d_`>~BBf@)7BBh4`iWf~m`lb7-3&NdXu#kXp(kc*UYwm>q1Y;r4m zAZs9~g*1D~t*ND@P;O58-PiK!YyIZy+?>XlZ;i*Pg;9VtRWF0j3noe3DR+aUl`)BX^x(QmgnLQcrZD~y2U-~YKo#Uos4~I?kt~`+SqdK!7*+ylBFbaNlt9{&uNy=wfpG*1 zYv?R}4RrxMe>|L{#}Pmx3Xq6|9906NGi%P(4RvL=L=%zPrcgW&J-O(0nd zU$VL;5{XwQl8NfbzA}%yp|^b(nS#}+SgX3Y8M{>Zqr}h=Hp#cJ{_Vc2DqeQ*?ZJBA zC7qu1$(ryD!2E?MU8fTYlRi2Dg&qo%zB~xq)PD>oe+}IvNUUA}&ixhScB>$!TLlSC z`76`O_<|^JmA~R>0)ytnWL{ZS+OjrCn89>XhN#pRJAuxYoQw9BrOAP z`Ia?$#iB;AoT@VMJ*40toTnWejo8O z@jy6cJVT0qRPmdqmq718%t@wQq4KRbRjWdXQSc$8#C6kQGs+`Cyv+g@D$Hd$Zct0#h zQHyUPbE6EoGe}h_^sM_5?L}DJNV^Lh@kGe`TCQ z$XH16OYE2F841bjNi~Y`$nP9=(ZVEZI<#3(q%0f1*kDV}2M!k}#fx;;LPlD)*IA$pOO}j^gS_&<)l5 zjqdk@oQD6EY|bT}4j~WcLUGGK)~(G&@F&km*(3l;>a*tv(JzsiIrfn7{p1lL6ro_5 zM$1XFG@IU*i1nkIB!7x*tmOO7oHQ33+1yA)Q|0@j;R&B8z zO_@xjA;{JaP@l$AxW+P1-FCR03%^M#LMnlb*uQ`a6u8#KN?#*ua+xJmsaPNl4e4S! z0ND!4Y*98k26sF@q{@NPnmV1C!!b)UT{yJL8($t%O)+(eChwA_Qo)Xb*_8o28 z({;BbQngKC>@f^9)>KyqLZMV+ptdPq69@)LcOR>cCZbLIJZ^omStmp=tlT1GeGfD#k8se_V@%>&havk#IN+ zOdvvP-Kx5>SRz(a6Nx7qYU53+BN5ETWL;S@nvBOA8e+8#;l|oV-QnA+6f$WHrW&e~ zP4Q$jl7h(sxkwTpJ?{54_u@{D#yvO+q9fh!U)|H$`vH&JkluvqZi&=H!VU3gFpwfl z0*Ot5n#O2^kQhwWe}+OpWMbdSEy>1}s>}zF`6fEr83=&tx}Yu;4AP+h0zf)o0 zzX6jGOB9#8mI4sBRA2%J0SW{Yu}5qK007PklRF|AmwsUa2Y=g&+b|G@?+bkgqx-~` zbJ$IYvvjvCT`0@a^l+`n<5)zpTuIKMrSIO6oY+ePC9JV^7*x+${secSkXW_Jv-ZDuyxfRVnBg`!F>6I7_? zxh5#V*lD@_ZcYlQV+4Qnh@mIgNH z5b=>Ww2xm>s$xWa49q^g9i8AqD>wvRTuh32IJW??f1}`Jv)ts>8oO@{CuvozG+kGh z>tC0jhr9fFCb`q=cj7QP{b0QNO;nmuC0B;tozq`ZzDKDyJ_-I$jB=tUT?l9Tq{?;U06=)&*5HDfD)Gc)U* za^H<@#K@sZ@bid-G;5{t$hITZHqjr;G2X@*tm$$*z$YvW6|#)4ZKYRaV-0a#_O`ct zV86x3zxwhjXDVuM`*N#2JOKb69srL&i7(|}hw&5M;tXJhppg{gS=I&PqQJVcWHB7#_gca-Ih3i!+Ea?yW1Dv z&+Q9mh9aMDDkQln*KpVa*-Rp=k*9ak?QStc`9+3Wc5o?PmQOAb=RVN^mifM7*kFNx zh&PIJqZ7o*xNplZGlTSwpktw1?*n9=kED5-fEwqXCi{;nS~ySEs@^y8QdA*;^?L?Y zhNm28=x>QS&`~7fw&ZeA!|_QZw72AP{#8hOH}Ut|eLam0kO2j!z;oIomH_~$pZ#ay zL2Q8-uml&^Iex;vr5AI)AMP?)@WTLa^-T&KGxCd#FOTNLFe|D0eu^B|mNy$Zb z8`fe4#%A0uJOplTuj|7*nC+Qg3Ns6RR0oh6G!(+0A(x)Fs}c}ulvJ(zil14Mf9+&t zKW$rO8&eN31Hev7`P?}-$r6RjCnrc;O#1RWtXkVxFuL5IG9?KE9>8v-qE17=+^?kU z*r}A&r5zpq=ScpzHf&&u5RbLGaEZjq#yE9t^AF27!S1V1+zkrdriq;gQi*8sFJ8lw z#+=Qq7EL59q-GrNSg#K2E$?o0SUA7ytME8~SSy?gOurYSQvK-rb@gtzb432@vd(wl z0ZgZVmu0jD${Jw!kW^ub>DiaZ?(}*1NBMU@fBPcp6?2URx1&2Ya=j&XUx{|xFcY>) zjLWhGA|f*l&(KLS0d3xkdo52Ndj^LV?e11nD!$z68AT_1Z_gW)ir zk7&Lxy6J^*Yj~LPRUITKV(}Tyyoe|UpUBVC$&um53sH|+m#^`~S)$6%%e{a2)o$g- zXiu#I4|5>9B=BZQ-i;*gcqxtQl7=g7_1zTb^QJc90S&)o+ufd;=3-VpX!y(b_um3= z*&h_i_EUXk=%u;uf3Esx7B{)K{(S(z{&%6LXB@`Qi^X?CdX~wP^Eq_K-uFG7hBn;_ z(-0HaUt0R|_O>oe%f_MQ4Ghq8c(l#NSmz{j0V0|118C9nKk7*c-MaVk8f7A60u632Q>1NJ@Tl2S9Y23zNY1PUEEfA#&`S<#!&KS7{@xXWd!6ljk_u z!5Z$T^FZWHPkKZC`wI9k`j8<-k99ox{;`1bX>3qvP)Iv=29^{7r;s_y8X9jlMyN#x zR=2TW=$0!Rp?m|n0W70^nJ|=ij)`CV42QwB<4K`BgCRc7}2FzeXM5JT+KS4`@g8FF%lg+3<^vgs|5f zBdCvn{+&xe$0JO#kFuq#rZhQ2V{;Wj59A-*rx zUU`ZJqJSB~z#9Z|y^tXG^+WiaD-z88iT01Hg2`Q8>k9JEuvpmPFy z36ZR=m5D8>jbM$a(EQ?o)xGVBSsKvPvR4NQ%2qsQI(ky8vOe9oiAEb+g}3v?h)e5M z2}#ppa+K&>t~npLecc~<)_a>I#)FK$Qa=65kUXef*lV2uhYuQE{oFYruxiKXf+Fj# zB2-_7_LaLuiK|+s{pIS;LXN0vsApJNJAKeq+>YO*Rod)}9%^?o7fB;ASGBeUQTO)# zDB<+JQfB>2hN0L&v_>Gz>$pLn`MH47RQ??z0=d=FQh-;oYI_a+Tfgd@1$ktT+R={R z(qi2&_9-eD4MA&PnLx*2WROCx%~(eXo5@$2q(wR>Hl9;QF15TaNAaghq{=Qw$wSjL zqy3G1l#3Zfn(lmc8H^M6WM=VQf`19Y!-z9*%L{y=+}-5VL%E^Lcb}Cx4(qv!N2lN6 z6~uC#SPH(6^M!of;1kc#htRC-d1(y2I11qNXxPrk4cH6Z#m=Mg^ z{_E`$FjhW@<|~DLt}{ zf~3jiNP0I}-@P2|MdUjwvUCgk?oS#aM@jI$=7Ym>ev=UaL1FbXLmfPfBDPx#Oopw) zFaDSJt#jHKp8mP5Vghe8R~1C4!Y=xQiKiSHtne& zf0*gLcih4L3={JFz5&t^Mt?d>pC+zxL>T2a#@Zv}nau4pL^I*DQ7Uu0rWi6)@mcBl z@HFT`|I(tPuQElEFXIQ8EI=0*+ms_#xJs?m&sEgU@A7=+VLOE-eJUJErq^+L=i&cIXm zkLJT{uh%W@u&eIcYu+BYaa(-|-G%+zQW>R$tIbgshrd#{Z?dH9 zN4zw?T*foP`d3VmQA8QDeySIlax#9hR}HhD`}HR}VAF)`kDfra(0XHRX?RlJCZACV zc;lB*Dz_7kn`YCxh(T6RXZ+03*BX*6&(fCi`;Mq(D2^$+rkVa9U0fj-E;qlKw+>uE zW$lx)PM*3_Yni((Qz$rhff}JNj+*SLG(wTxs3~e+w=8f#0LiHdHFtui;Lj)vQ(;4W zELUg*LN+d(Nb~d2kbxuLjL4MshwQ3}hpe5JonUf4l<1Cz^}wP^9cjBJHZOssW)sWz znTj>J6B+jN{1p{~V2!s~U%F{E@YMt=YB)QP4s}4FkyDRsO#GD^(R}gfqmE&nZhV=M z9;<8zy?42%ljHil-O(3QC3Z^pKtB_v%3 zT%&*d)XSvygmN(IGhU6hEh2F)qObJA2>O(+&|q7kyf0vZc{2`3H%B2oXkR=mV?>#Y zPodfW_iobWoWLi8mUvlF;~jxt%tgtgMy5xNa$&avg#WGc?Y6^fuP%Y7G9C1z)=tm! zDD3A*mQO0i(U@rLB81Zm)3Y0sSs=> z>k_H%cX;`|{1?5at*`CrS+W8JC9DLL2J>gg=Cv?C>>s2z-n#BU%(=Ppy0!&aKL_o+ ze|R+e<5S!cOnd$(0v>t!69jN;IABU1Dov@%n8Ecte!W zGMM%y=_ad=o_m01uGC(eM4{Ey&< zg=gNSrb`3Phv>xjdGI0oqptQxejdK$LD4thv-NUs=4^&5u3~xm8Mm84rUHVDAxX9$ z+snUqs=tVsb@%Yz!0!sje1{yGo@&cMl!doYskP`|ts#$QrVF}qyf-JhWzeJ_Wc+72g892qz=rBX*m=$dVi;tF_nNhPtGNV#Uk+L zpzLiPe?!^sb>W(FW>|JeOO&IKbj7mfC$5ux)%=s^S|@&3*m#s8d^#nEcCNvo?MTMM zR{^Yv)%Cf_(p8pwmdd?!sRMh@}W59S1cS^8{fm&CAr4ZibPU>)*!`Yp27twe*ywbFiJoHDLf?Dxr-KiX&D50hgvb z2BCeipxBrYuHR%Yy7tHv*ABL(#ZLzy;fPYc$4z1&edp&71G*$Pp?SrT!oCT46X@FQ zy2=aM+;Mnzm|Q@gAGB#fdf{CogipvxPj*=X?mf3Fk}^RP*yv|3ZGLALz@KY6^voF) zV{I|&8G+)87-2LSg&kic{tju8mdtf~yx#$GSQO+^?Sq6=42G@mCw0w}0VEHk6^~V;BKZ`!<*35eD=T@fMqP^YPhs z^Xdzr3#?TwC_cNhQ@8`B`ur$pXd%McnkQMY?#f%^WrW4%gT5aPQqg0UKco<5(f?HV zji1B(=xf6d33yNfZb8P_!t{pVRf7Pp2ckd&{gu-!mzkft1=#C9^Yux5_YC#uF0j_5 z$x{b9l(QMr)e8110B!L!2d5RP99Wr6fPy=mDeJvGqQyP08yWR%%RmjDMB1qZgTyjF ze+3Q;*k)PN=L~88G_JQZvtR1_CkVAtkX>dnq%0u+9 zlhvM_R>pL%f|?>i2z$dcmueF2xWd1e!4F!y2#pjn;E0<8i`r|h8UvpVn5LhxIg- zd_(Bu@DMc8FPGgM?0cxWkyw=%uT8>${>8YjNA$q!5&ZrDw6n*hC)c%JIVIhdg!aHmzhJh zJ5)}BK0bM6qqGEc6~bZFY)Ow|qCCqSW!icGI_%7u%b~P?Yc}s|f8uZ#mar-Hb`SMt z*`{nkov`UCwg6JaL6kV?bP&?g7RNLG9_=k%s?wYLx*x7HM6#vnuCE}yI(Y>2e;f&) z4#>PLuY1lQRrj#=1=yw?GeqYb7@lqQxK!B_yH+~`{`pUNCX zPXd~SFg0%Bh46;pEi<$#k%RXR!mB3j3Z7Uj8ZCS~ritPH*&?3%fz5+63q||DJGX~v znWa^U*lGVDT(I3w*2EzUz?>>VJZ+jX4y$o0!fHYj3aw>K??%{L4KB1~Z`C=GW2p$a z47@J;MJ5mP-hdl z?(#Lp;@FlCYt3PW{!$HlUW~U6^4&!H%?Q9Zyk!v5km%!s@QF9AAL~bIVBpv#OPY1UASlhF}N^_UfI zn23Bk8dY6%;!_oni)~GVpq+z(R$7cWIB^nR^_UavfxZDXvNkAxHxUjK@s+2js4;dD z5-WIa81nbsSjGCTjU~Q3}Q=g{o_>dRyR&vPn1Y6L4Fi&h!-Puw_ zs$8{KqVFgYG&&i#axU?M_Jz}4d_IL0+;Auxft^5v`IDr?Ur z|EFK+@V0#M%PPpg+AzurG!CoCkK*97;N_9di8U&&=Eb8zP2Q|+gR+jY0mJyN%uEx@ zC*W(xQ$BkP`?muh*h1uo(Fz4<*plrXe;oP8e2MkAc3e{+E;MrVm=~ns1~YAPPurBl zJ+-wHV{qIv{*rELMyb-^9|N`GxQqe+kz5^iI8C*d|C8pBeW;I2)$d4vo^E9D)26FFA$Wc#t#oDss|?9C z+|r{%)$IKprok?1paNGT+$`~jAo_eOYBDe&hg~1J2}4=k`ai|VBYN-rj$$k=Ei`HM z6oaRCDQa))(%wtH)wyiRz~~!j?jN;s!D0)Eq13lmFoYHuh%U9ONfX=TcPac@SG+#C zinTAEGL|NOwIQSvOl=RO7!9k)r?CIpG5wP=k2VY)mcp%hJNBofmP|7d!#A~%H#_p9 zA0~cbr8k$YDCA151C4WYRO^W;-O^Kyd7~r$-LE2UcG#x5Wsw$jUWC&0CVgr?9;()R z9rA{sjP?+8fm!$FmftLL)0@VXyyf|y;@WqTJNKhBpa_ncnzu?~4MH1c&+iTYKY=dxW z03X>=%j6QIUY00zx3}_XCYCWUk%%NCAxpEx4Z@94rHbRtfvR2^+&c}tn)ij{!S~^?ytjZa~%xGXm*i7 z)VhHdHvYM`(p$wDIRYxF94RzD^;4}yi>X(M`7YR6`lk36W^%;pZm?`*U&Sy)mGz+F zZ(0Zhge7iSwD=vp=Kb7Ce^D>UU=L*$K*=Q(Vk}RUtcpHkAic%~wyfW!(qM@;BPg9R zcEK-|=Li!EFiJG8%HLQsUtj{e%tgXfcM*7;NusfmXL&*FW)0!Q+BuE6by z5;Az)r&$%{wC~!$KB$MzQz^XFiJsU0W0+F^JxJXR87)5pU1?cNUt2BD{=U0xz7}`R zHaGb#gWhWFRQufwC*3p`84VU!)I#cqp7J6ZgbkTAX+(6(krDKdCr|h(8Mq1U%5g0c zz@A(_!8kD^q4K>H(+a+$`Jw2t?l*5ocF(s846tEJtyn4SXC9!#G?>^Ccb=^VlFBC) zw%BAImTXw%jf%z$uUi+@N5y`Xe1}9NNjxG9LZCK7W39p* zNJ#FT@9wX4t%Kl?pwCyWa})-y;6S!k1H+OY9h)JdB1e0704iK9pnk~wAm4wo$YxmN@{^2qFK_J*(y1V;od7C{{C5B*J`j_!4D<1D(zd~T?@J>eG)u7VgK zor@-KZEw+~ziKU_4z5j8P`|r|i!xD-y2N(l=5H<7=>Cxw?PDjw9-GG$RkxgQs<|d} zl%h%!ku`%BCH|;9m;IO|KhXa8qBRWH(D)-K_#3pPXW=QGuq7V2MgZ|g z!?~$N!<6cp7Xb+Z77hY%Lr0p~iNR^rPKtVSZca1hnP|u@>)WT``MLl0f{?9vXw-9% zaO~;c+TyR76*c^bZ%D(xMo1epn8(aIx;NEaIcWa%OLhH2OIn_duWyki~!&{AyBg z)5&7VXS+(J-sYaiPC9A!eBgeu*m!-o9<_1O^_yUCr*qUc(rF^UXCQas!dQM^zZ5iQ zTTVJ5(la1dg~srU#gP_+U++#Cs5mm6A&x)fFZB_&o=Kq7-A^s8QdR~*j}>Nw1dt8pt%5=G80M{|Mt{F< za~M0lytH^jG9Tld2#jNHvkB`%KWlWwbiYc?^eyIvvESLmO#n^Q#WmsWT|lDDH_e$G zTSEK@a`xS)JCYFL^qew%eBpO)6W@)+C&D9`8zu*GZ27ZRaYJ7Y`!4>BR=EudDcxi^ ztUcN4JdeRgKM(ZhZ5hqsm7*yrX{Ev0xrUv+I$2lS%j_&F9Yw4k2H4Cx$f%qx|K$6h zCt0sDvpyB95$!v!KKqmdJK==egSv_S20TE{lLISjz@NSqQ{mpxIM_0EH{s3qWVWh&N^*QSh6k2H=1n+~afDd`c%;>f{GB=pFCnfb_U`i1mS=4FMHp{a9lOE5ml zR{b7(CPsx6c^C#imam9^=JEwm642QMZBMU0Aj{%U#Nf)18xMdpD7rO~c{>ku1Jl)d z6J;}Yc!B(`Cw|vf6!!-`(%C6Js!CTNdE|4{;7ACr5B!iIc&vQ0(E206UOAAHdgal$ zIx?i29xL~}aMiYbZ>wB+kUp_l)qb>~EdJ5YHh*(8ZWhdum{R3fHKYr9{_!an1(N!N znui66M=H0m1k2x_tRBMdj!%DHW-ZA+$kv-j0$-wGKM#Lm(trX02-P>m0GUu=I!?$` znZ6~=TYQxl)Dv)P(GqSV@~O|AhB<_;JVE1MOTJ9PKYsmnUZ3U6{+d{2$*b|q<6qqEoQx1R)J*V!I9-UlB=IO6 zXU|7x#rQfguNWq-R2CeU{A|aoa*L>O@LXO7IX~M!P+FL4nVA9i*Mm4hs zTwh8mui_}BVDDR>={IV_NYF#j*h?LQX4aHs8?km$C1KS1w_oLg_oJz`NoT6JBwaf% zf>}ok(gtrN%-6`*PSs>b35E#_eDxg&s?@Ltt)4^ujpEUNl7R;4Hyht^T=CDz#9#{I zs8sb|C~n9!-RqZ)b~A4ZJQL@07^+IobNG`nLC~w!ZY$g0)GhSKUSmu!@1rTdgx4D! zj^4Ik(l2{263SP^ByKi)WD^L%r1kJPU=%90F(VG~4^#jk1i_gI6rx$Y$;p@}1^_bs z000VP!ppxu5qJr*Or(g|L?9_m`PUx&2V}-n1Kxk4k{J65I%I5|EWfqdsyY51C`r)d~P0DgV#MP!RDk2}n;fIPJkWjR^qUv;8L@ zhs+~iLYyo*0zDZ>NP|jJ?sW$Q0O*lK)c=PG01#F|;K6}BXcgPJs|Xo5kPPUkj?jk# z*=Y1fiO?JFk#pJ}9q{!3wV|;>B*THyKr~ClG#n^Q`|n(_|FnbJ3YZ|rM1qh;07+^8 zo!RoAuol~Y!H~%==!g#pAQvz+0#SniGSU3+x?h;q$u? delta 159711 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∾8 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

UzMM>Nmp83_daCs+ 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%0A5b8a&mtm)tcM4DG}EhX7*vCFw$ga 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

AXh98N-<12W2YV~Qg3X3+vZj*izqUNVq( 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 Date: Thu, 4 Jan 2024 13:14:46 -0500 Subject: [PATCH 262/328] Add copyright notice on LIS files for LISF 7.5.0 public release --- lis/metforcing/usaf/USAF_GagesMod.F90 | 9 +++++++++ lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 9 +++++++++ lis/metforcing/usaf/USAF_getpcpobs.F90 | 9 +++++++++ lis/routing/RAPID_router/src/rapid_Vlat.F90 | 9 +++++++++ 4 files changed, 36 insertions(+) diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index c926e8916..f3df49a9e 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! MODULE: USAF_GagesMod ! diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index cf2f362df..7c069421e 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ! MODULE: USAF_PreobsReaderMod ! diff --git a/lis/metforcing/usaf/USAF_getpcpobs.F90 b/lis/metforcing/usaf/USAF_getpcpobs.F90 index 3a9679aa9..cf702b306 100644 --- a/lis/metforcing/usaf/USAF_getpcpobs.F90 +++ b/lis/metforcing/usaf/USAF_getpcpobs.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- ! ROUTINE: USAF_getpcpcobs ! ! REVISION HISTORY: diff --git a/lis/routing/RAPID_router/src/rapid_Vlat.F90 b/lis/routing/RAPID_router/src/rapid_Vlat.F90 index 5c2903711..33359df9a 100755 --- a/lis/routing/RAPID_router/src/rapid_Vlat.F90 +++ b/lis/routing/RAPID_router/src/rapid_Vlat.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- !******************************************************************************* !Subroutine - rapid_Vlat !******************************************************************************* From 3497c58b83bcac32f5cc020aec4d0a82ddaf28a2 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 4 Jan 2024 13:30:51 -0500 Subject: [PATCH 263/328] Add WRF Public Domain Notice for geogrid files --- ldt/LICENSES/geogrid-WRF_WPS_License.docx | Bin 0 -> 13510 bytes 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 ldt/LICENSES/geogrid-WRF_WPS_License.docx diff --git a/ldt/LICENSES/geogrid-WRF_WPS_License.docx b/ldt/LICENSES/geogrid-WRF_WPS_License.docx new file mode 100644 index 0000000000000000000000000000000000000000..5d1138e5a1dd0ff595efbc5db346a04e0f77e5c2 GIT binary patch literal 13510 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 literal 0 HcmV?d00001 From 843a5073974ffdb7928f38606a2d0bfdb8da38f4 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 4 Jan 2024 13:35:47 -0500 Subject: [PATCH 264/328] Add copyright notice on LDT files for LISF 7.5.0 public release --- ldt/USAFSI/ztif_frac_slice.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/ldt/USAFSI/ztif_frac_slice.c b/ldt/USAFSI/ztif_frac_slice.c index 598c63677..5f4b9c0a1 100644 --- a/ldt/USAFSI/ztif_frac_slice.c +++ b/ldt/USAFSI/ztif_frac_slice.c @@ -1,3 +1,12 @@ +//-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +// NASA Goddard Space Flight Center +// Land Information System Framework (LISF) +// Version 7.5 +// +// Copyright (c) 2024 United States Government as represented by the +// Administrator of the National Aeronautics and Space Administration. +// All Rights Reserved. +//-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LDT_misc.h" #include "ftn_drv.h" From 0cc84aeaaf1c53cae3494c7c7546ce8ae32e227b Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 4 Jan 2024 13:36:04 -0500 Subject: [PATCH 265/328] Add copyright notice on LVT files for LISF 7.5.0 public release --- .../usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py index 4d2e12b45..2c7d3c6e2 100755 --- a/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py +++ b/lvt/utils/usaf/nafpa/calc_gfsgalwem_biasratios_multiyear.py @@ -1,5 +1,15 @@ #!/usr/bin/env python3 +#-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +# NASA Goddard Space Flight Center +# Land Information System Framework (LISF) +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the +# Administrator of the National Aeronautics and Space Administration. +# All Rights Reserved. +#-------------------------END NOTICE -- DO NOT EDIT----------------------- + """ SCRIPT: calc_gfsgalwem_biasratios_multiyear.py From 95b0159076bf2a916b75b4f6ff9f65851364227c Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 4 Jan 2024 14:42:20 -0500 Subject: [PATCH 266/328] Added inquire statement to identify missing GRIB file. This avoids ECCODES/GRIB_API writing error messages to stdout/stderr, which may lead to runtime problems. --- lis/metforcing/galwem/read_galwem.F90 | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/lis/metforcing/galwem/read_galwem.F90 b/lis/metforcing/galwem/read_galwem.F90 index 229c180c7..9772347c2 100644 --- a/lis/metforcing/galwem/read_galwem.F90 +++ b/lis/metforcing/galwem/read_galwem.F90 @@ -59,8 +59,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) real :: vwind(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous meridional wind interpolated to 10 metres[m/s] real :: ps(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous Surface Pressure [Pa] real :: prectot(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Total precipitation [kg/m^2/s] - integer, intent(out) :: rc + logical :: found_inq ! Initialize return code to "no error". We will change it below if ! necessary. @@ -70,6 +70,17 @@ subroutine read_galwem(n, findex, order, gribfile, rc) ! the first file only, as all data will be of the same type. ! (GALWEM) because the search script ensures that it is. ! + + ! EMK...Before using ECCODES/GRIB_API, see if the GRIB file exists + ! using a simple inquire statement. This avoids ECCODES/GRIB_API + ! writing error messages to stdout/stderr, which may lead to runtime + ! problems. + inquire(file=trim(gribfile),exist=found_inq) + if (.not. found_inq) then + write(LIS_logunit,*)'[ERR] Cannot find file '//trim(gribfile) + call LIS_endrun() + end if + #if (defined USE_GRIBAPI) call grib_open_file(ftn,trim(gribfile),'r',ierr) From 462cfc4126ce80e8bfa40016b9ca595b5a17eb90 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 4 Jan 2024 17:15:07 -0500 Subject: [PATCH 267/328] Start of adding fault tolerance to LIS GALWEM reader. Not done yet. --- lis/metforcing/galwem/get_galwem.F90 | 188 ++++++++++++++++++++++++++- 1 file changed, 187 insertions(+), 1 deletion(-) diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index a029b5109..c8c438971 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -55,6 +55,10 @@ subroutine get_galwem(n, findex) integer :: fcsthr_intv integer :: fcst_hour integer :: openfile + integer :: filecount + logical, save :: use_prior_galwem_run + integer :: cur_fcsthr, next_fcsthr + integer :: ierr ! GALWEM cycles every 6 hours; each cycle provide up to 168 hours (7 days) forecast for GALWEM-17km; ! each cycle provide up to 240 hours (10 days) forecast for GALWEM-25deg; @@ -78,13 +82,85 @@ subroutine get_galwem(n, findex) '[INFO] LIS run has reached end time, will not read more GALWEM' return end if - + openfile=0 if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then !beginning of run LIS_rc%rstflag(n) = 0 endif + !EMK...Perform audit of available GALWEM-GD GRIB files for current fcst + !run. + if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then + use_prior_galwem_run = .false. + call run_audit(n, LIS_rc%syr, LIS_rc%smo, LIS_rc%sda, LIS_rc%shr, & + 0, filecount) + if (filecount == 0) then !Roll back to prior GALWEM run + yr1 = LIS_rc%syr + mo1 = LIS_rc%smo + da1 = LIS_rc%sda + hr1 = LIS_rc%shr + mn1 = 0 + ss1 = 0 + ts1 = -43200 + call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + call run_audit(n, yr1, mo1, da1, hr1, & + 12, filecount) + if (filecount == 0) then + write(LIS_logunit,*)"[ERR] No GALWEM files found!" + call LIS_endrun() + else + use_prior_galwem_run = .true. + galwem_struc(n)%init_yr = yr1 + galwem_struc(n)%init_mo = mo1 + galwem_struc(n)%init_da = da1 + galwem_struc(n)%init_hr = hr1 + end if + end if + end if + write(LIS_logunit,*) '[INFO] use_prior_galwem_run = ', & + use_prior_galwem_run + + ! Get the bookends at the start of the run + if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then + + ! Bookend-time record 1 + yr1 = LIS_rc%syr + mo1 = LIS_rc%smo + da1 = LIS_rc%sda + hr1 = LIS_rc%shr + mn1 = 0 + ss1 = 0 + ts1 = 0 + if (use_prior_galwem_run) ts1 = -43200 + call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) + + ! Find Bookend-time record 2 + cur_fcsthr = 0 + if (use_prior_galwem_run) cur_fcsthr = 12 + call find_next_fcsthr(n, galwem_struc(n)%init_yr, & + galwem_struc(n)%init_mo, & + galwem_struc(n)%init_da, & + galwem_struc(n)%init_hr, & + cur_fcsthr, next_fcsthr, ierr) + if (ierr .ne. 0) then + write(LIS_logunit,*) '[ERR] Cannot find next GALWEM GRIB file!' + call LIS_endrun() + end if + yr2 = LIS_rc%syr + mo2 = LIS_rc%smo + da2 = LIS_rc%sda + hr2 = LIS_rc%shr + mn2 = 0 + ss2 = 0 + ts2 = next_fcsthr * 3600 + if (use_prior_galwem_run) ts2 = ts2 - 43200 + call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) + + openfile = 1 + end if + call LIS_endrun() ! EMK TEST + ! First timestep of run if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then ! Bookend-time record 1 @@ -276,4 +352,114 @@ subroutine getGALWEMfilename(n,rootdir,yr,mo,da,hr,fc_hr,filename) trim(fname) // ftime // '_CY.' // chr // '_FH.' // fchr // '_DF.GR2' end subroutine getGALWEMfilename +! Run audit on GRIB files with specified start date and time. +subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) + + ! Imports + use galwem_forcingMod, only: galwem_struc + use LIS_constantsMod, only: LIS_CONST_PATH_LEN + use LIS_logMod, only: LIS_logunit, LIS_endrun + use LIS_timeMgrMod, only: LIS_tick + + ! Defaults + implicit none + + ! Arguments + integer, intent(in) :: n + integer, intent(in) :: yr + integer, intent(in) :: mo + integer, intent(in) :: da + integer, intent(in) :: hr + integer, intent(in) :: first_fcsthr + integer, intent(out) :: filecount + + ! Locals + integer, parameter :: MAX_FCSTHRS = 240 + character(len=LIS_CONST_PATH_LEN) :: fname + integer :: fcsthr, delta + logical :: found_inq + integer :: i + + ! Loop through list of forecast hours, and see how many files exist + delta = 1 + filecount = 0 + do i = 0, MAX_FCSTHRS + fcsthr = first_fcsthr + (i * delta) + call getGALWEMfilename(n, galwem_struc(n)%odir, yr, mo, da, hr, & + fcsthr, fname) + inquire(file=trim(fname), exist=found_inq) + if (found_inq) then + write(LIS_logunit,*)'[INFO] Found ', trim(fname) + filecount = filecount + 1 + else + if (i == 0) then + write(LIS_logunit,*) & + '[WARN] Cannot find GALWEM GRIB file for LIS start date' + write(LIS_logunit,*) & + '[WARN] Will need to use earlier GALWEM run for forcing' + filecount = 0 + exit + end if + end if + end do + + if (filecount > 0) then + write(LIS_logunit,*)'[INFO] Found ', filecount, ' files' + end if + !yr1 = yr + !mo1 = mo + !da1 = da + !hr1 = hr + !mn1 = 0 + !ss1 = 0 + !ts1 = 0 + !call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) + +end subroutine run_audit + +! Find next GALWEM grib file given current selected time and +! forecast hour +subroutine find_next_fcsthr(n, yr, mo, da, hr, cur_fcsthr, & + next_fcsthr, ierr) + + ! Imports + use galwem_forcingMod, only: galwem_struc + use LIS_constantsMod, only: LIS_CONST_PATH_LEN + use LIS_logMod, only: LIS_logunit, LIS_endrun + + ! Defaults + implicit none + ! Arguments + integer, intent(in) :: n + integer, intent(in) :: yr + integer, intent(in) :: mo + integer, intent(in) :: da + integer, intent(in) :: hr + integer, intent(in) :: cur_fcsthr + integer, intent(out) :: next_fcsthr + integer, intent(out) :: ierr + + ! Locals + integer, parameter :: MAX_FCSTHRS = 240 + character(len=LIS_CONST_PATH_LEN) :: fname + integer :: fcsthr, delta + logical :: found_inq + integer :: i + + ! Loop through list of forecast hours, and see how many files exist + ierr = 1 + delta = 1 + do i = 1, MAX_FCSTHRS + fcsthr = cur_fcsthr + (i * delta) + call getGALWEMfilename(n, galwem_struc(n)%odir, yr, mo, da, hr, & + fcsthr, fname) + inquire(file=trim(fname), exist=found_inq) + if (found_inq) then + next_fcsthr = fcsthr + ierr = 0 + exit + end if + end do + +end subroutine find_next_fcsthr From 2d8baa09f46e15d6c78bc177c8a6f76e5a184efe Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 5 Jan 2024 12:25:19 -0500 Subject: [PATCH 268/328] First full cut of fault-tolerant GALWEM reader. More testing and code clean up needed. --- lis/metforcing/galwem/get_galwem.F90 | 405 +++++++++++++++++---------- 1 file changed, 262 insertions(+), 143 deletions(-) diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index c8c438971..1730b25db 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -57,7 +57,7 @@ subroutine get_galwem(n, findex) integer :: openfile integer :: filecount logical, save :: use_prior_galwem_run - integer :: cur_fcsthr, next_fcsthr + integer :: first_fcsthr, next_fcsthr integer :: ierr ! GALWEM cycles every 6 hours; each cycle provide up to 168 hours (7 days) forecast for GALWEM-17km; @@ -95,7 +95,7 @@ subroutine get_galwem(n, findex) use_prior_galwem_run = .false. call run_audit(n, LIS_rc%syr, LIS_rc%smo, LIS_rc%sda, LIS_rc%shr, & 0, filecount) - if (filecount == 0) then !Roll back to prior GALWEM run + if (filecount < 2) then !Roll back to prior GALWEM run yr1 = LIS_rc%syr mo1 = LIS_rc%smo da1 = LIS_rc%sda @@ -106,7 +106,7 @@ subroutine get_galwem(n, findex) call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) call run_audit(n, yr1, mo1, da1, hr1, & 12, filecount) - if (filecount == 0) then + if (filecount < 2) then write(LIS_logunit,*)"[ERR] No GALWEM files found!" call LIS_endrun() else @@ -118,8 +118,13 @@ subroutine get_galwem(n, findex) end if end if end if - write(LIS_logunit,*) '[INFO] use_prior_galwem_run = ', & - use_prior_galwem_run + !write(LIS_logunit,*) '[INFO] use_prior_galwem_run = ', & + ! use_prior_galwem_run + if (use_prior_galwem_run) then + write(LIS_logunit,*) & + '[WARN] LIS run may terminate early since a prior ' // & + 'GALWEM run is being used for forcing' + end if ! Get the bookends at the start of the run if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then @@ -136,17 +141,20 @@ subroutine get_galwem(n, findex) call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) ! Find Bookend-time record 2 - cur_fcsthr = 0 - if (use_prior_galwem_run) cur_fcsthr = 12 + first_fcsthr = 0 + if (use_prior_galwem_run) first_fcsthr = 12 call find_next_fcsthr(n, galwem_struc(n)%init_yr, & galwem_struc(n)%init_mo, & galwem_struc(n)%init_da, & galwem_struc(n)%init_hr, & - cur_fcsthr, next_fcsthr, ierr) + first_fcsthr, next_fcsthr, ierr) if (ierr .ne. 0) then write(LIS_logunit,*) '[ERR] Cannot find next GALWEM GRIB file!' + write(LIS_logunit,*) '[ERR] LIS run with terminate...' + flush(LIS_logunit) call LIS_endrun() end if + galwem_struc(n)%fcst_hour = next_fcsthr yr2 = LIS_rc%syr mo2 = LIS_rc%smo da2 = LIS_rc%sda @@ -159,152 +167,263 @@ subroutine get_galwem(n, findex) openfile = 1 end if - call LIS_endrun() ! EMK TEST - ! First timestep of run - if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then - ! Bookend-time record 1 - yr1 = LIS_rc%syr - mo1=LIS_rc%smo - da1=LIS_rc%sda - hr1=LIS_rc%shr - mn1=0 - ss1=0 - ts1=0 - call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) - - ! Bookend-time record 2 - yr2=LIS_rc%syr - mo2=LIS_rc%smo - da2=LIS_rc%sda - hr2=LIS_rc%shr - mn2=0 - ss2=0 - ts2=3600 ! Advance 1 hour - call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) - - !movetime = 1 - openfile=1 - - !write(LIS_logunit,*)'EMK: time1,yr1,mo1,da1,hr1,ts1 = ', & - ! time1,yr1,mo1,da1,hr1,ts1 - !write(LIS_logunit,*)'EMK: time2,yr2,mo2,da2,hr2,ts2 = ', & - ! time2,yr2,mo2,da2,hr2,ts2 + ! ! First timestep of run + ! if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then + ! ! Bookend-time record 1 + ! yr1 = LIS_rc%syr + ! mo1=LIS_rc%smo + ! da1=LIS_rc%sda + ! hr1=LIS_rc%shr + ! mn1=0 + ! ss1=0 + ! ts1=0 + ! call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + + ! ! Bookend-time record 2 + ! yr2=LIS_rc%syr + ! mo2=LIS_rc%smo + ! da2=LIS_rc%sda + ! hr2=LIS_rc%shr + ! mn2=0 + ! ss2=0 + ! ts2=3600 ! Advance 1 hour + ! call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + + ! !movetime = 1 + ! openfile=1 + + ! !write(LIS_logunit,*)'EMK: time1,yr1,mo1,da1,hr1,ts1 = ', & + ! ! time1,yr1,mo1,da1,hr1,ts1 + ! !write(LIS_logunit,*)'EMK: time2,yr2,mo2,da2,hr2,ts2 = ', & + ! ! time2,yr2,mo2,da2,hr2,ts2 + + ! endif + + ! ! Determine valid times when forecasts are available to be read in: + ! ! EMK...Revised based on sample forecast runs for 20230523. + ! if(galwem_struc(n)%fcst_hour < 42) then + ! fcsthr_intv = 1 + ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) + ! elseif(galwem_struc(n)%fcst_hour >= 42 .and. & + ! galwem_struc(n)%fcst_hour < 168) then + ! fcsthr_intv = 3 + ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) + ! else + ! fcsthr_intv = 6 + ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) + ! endif + + ! If this is the beginning of the LIS run, read the two bookends + if (openfile == 1) then + + ferror = 0 + order = 1 + call getGALWEMfilename(n, galwem_struc(n)%odir, & + galwem_struc(n)%init_yr, & + galwem_struc(n)%init_mo, & + galwem_struc(n)%init_da, & + galwem_struc(n)%init_hr, & + first_fcsthr, fname) - endif + write(LIS_logunit,*) '[INFO] Getting GALWEM forecast file1 ... ', & + trim(fname) + call read_galwem(n, findex, order, fname, ferror) + if (ferror .ge. 1) galwem_struc(n)%fcsttime1 = time1 - ! Determine valid times when forecasts are available to be read in: - ! EMK...Revised based on sample forecast runs for 20230523. - if(galwem_struc(n)%fcst_hour < 42) then - fcsthr_intv = 1 - valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - elseif(galwem_struc(n)%fcst_hour >= 42 .and. & - galwem_struc(n)%fcst_hour < 168) then - fcsthr_intv = 3 - valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - else - fcsthr_intv = 6 - valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - endif + ferror = 0 + order = 2 + call getGALWEMfilename(n, galwem_struc(n)%odir, & + galwem_struc(n)%init_yr, & + galwem_struc(n)%init_mo, & + galwem_struc(n)%init_da, & + galwem_struc(n)%init_hr, & + galwem_struc(n)%fcst_hour, fname) - if((valid_hour==LIS_rc%hr .and. LIS_rc%mn==0) .or. & - openfile == 1) then + write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ', & + trim(fname) + call read_galwem(n, findex, order, fname, ferror) + if (ferror .ge. 1) galwem_struc(n)%fcsttime2 = time2 - ! Forecast hour condition within each file: - if(galwem_struc(n)%fcst_hour < 42) then - galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv - elseif(galwem_struc(n)%fcst_hour >= 42) then - galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv - endif + else if (LIS_rc%mn==0 .and. & + LIS_rc%tscount(n) .ne. 1) then - ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-17km): - if(galwem_struc(n)%resol == 17) then - if(galwem_struc(n)%fcst_hour > 168 ) then - write(LIS_logunit,*) & - "[INFO] GALWEM Forecast hour has exceeded the grib file's final" - write(LIS_logunit,*) & - " forecast hour (record). Run will end here for now ... " - call LIS_endrun - endif - endif - ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-25deg): - if(galwem_struc(n)%resol == 25) then - if(galwem_struc(n)%fcst_hour > 240 ) then - write(LIS_logunit,*) & - "[INFO] GALWEM Forecast hour has exceeded the grib file's final" - write(LIS_logunit,*) & - " forecast hour (record). Run will end here for now ... " - call LIS_endrun - endif - endif - - ! Update bookend-time record 2: - if(LIS_rc%tscount(n).ne.1) then - galwem_struc(n)%fcsttime1=galwem_struc(n)%fcsttime2 - galwem_struc(n)%metdata1=galwem_struc(n)%metdata2 - - yr2=LIS_rc%syr - mo2=LIS_rc%smo - da2=LIS_rc%sda - hr2=LIS_rc%shr - mn2=0 - ss2=0 - ts2=3600 * galwem_struc(n)%fcst_hour - call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) - endif - - ! Read in file contents: - if(LIS_rc%tscount(n) == 1) then ! Read in first two book-ends - - !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_yr = ', & - ! galwem_struc(n)%init_yr - !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_mo = ', & - ! galwem_struc(n)%init_mo - !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_da = ', & - ! galwem_struc(n)%init_da - !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_hr = ', & - ! galwem_struc(n)%init_hr - !write(LIS_logunit,*)'EMK: galwem_struc(n)%fcst_hour = ', & - ! galwem_struc(n)%fcst_hour - - ferror=0 - order=1 - call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - 0,fname) - - write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file1 ... ',trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if(ferror.ge.1) galwem_struc(n)%fcsttime1=time1 - - ferror=0 - order=2 - call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - galwem_struc(n)%fcst_hour,fname) - - write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 - else - ferror=0 - order=2 - call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - galwem_struc(n)%fcst_hour,fname) - - write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 - endif - endif - openfile=0 + ! See if we need to update the bookends + yr1 = LIS_rc%yr + mo1 = LIS_rc%mo + da1 = LIS_rc%da + hr1 = LIS_rc%hr + mn1 = 0 + ss1 = 0 + ts1 = 0 + call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) + + yr2 = galwem_struc(n)%init_yr + mo2 = galwem_struc(n)%init_mo + da2 = galwem_struc(n)%init_da + hr2 = galwem_struc(n)%init_hr + mn2 = 0 + ss2 = 0 + ts2 = 3600 * galwem_struc(n)%fcst_hour + call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) + + !write(LIS_logunit,*)'EMK: time1: ', time1 + !write(LIS_logunit,*)'EMK: time2: ', time2 + + if (time2 .le. time1) then + + ! Update the bookends + call find_next_fcsthr(n, galwem_struc(n)%init_yr, & + galwem_struc(n)%init_mo, & + galwem_struc(n)%init_da, & + galwem_struc(n)%init_hr, & + galwem_struc(n)%fcst_hour, next_fcsthr, ierr) + if (ierr .ne. 0) then + write(LIS_logunit,*) '[ERR] Cannot find next GALWEM GRIB file!' + write(LIS_logunit,*) '[ERR] LIS will terminate early' + flush(LIS_logunit) + call LIS_endrun() + end if + yr2 = galwem_struc(n)%init_yr + mo2 = galwem_struc(n)%init_mo + da2 = galwem_struc(n)%init_da + hr2 = galwem_struc(n)%init_hr + mn2 = 0 + ss2 = 0 + ts2 = 3600 * next_fcsthr + call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, & + ts2) + + ! Update the bookends + galwem_struc(n)%fcsttime1 = galwem_struc(n)%fcsttime2 + galwem_struc(n)%metdata1 = galwem_struc(n)%metdata2 + + galwem_struc(n)%fcst_hour = next_fcsthr + + ferror = 0 + order = 2 + call getGALWEMfilename(n, galwem_struc(n)%odir, & + galwem_struc(n)%init_yr, & + galwem_struc(n)%init_mo, & + galwem_struc(n)%init_da, & + galwem_struc(n)%init_hr, & + galwem_struc(n)%fcst_hour, fname) + + write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ', & + trim(fname) + call read_galwem(n, findex, order, fname, ferror) + if (ferror .ge. 1) galwem_struc(n)%fcsttime2 = time2 + + end if + end if + openfile = 0 !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime1 = ", & ! galwem_struc(n)%fcsttime1 !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime2 = ", & ! galwem_struc(n)%fcsttime2 + !call LIS_endrun() ! EMK TEST + + + ! if((valid_hour==LIS_rc%hr .and. LIS_rc%mn==0) .or. & + ! openfile == 1) then + + ! ! Forecast hour condition within each file: + ! if(galwem_struc(n)%fcst_hour < 42) then + ! galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv + ! elseif(galwem_struc(n)%fcst_hour >= 42) then + ! galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv + ! endif + + ! ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-17km): + ! if(galwem_struc(n)%resol == 17) then + ! if(galwem_struc(n)%fcst_hour > 168 ) then + ! write(LIS_logunit,*) & + ! "[INFO] GALWEM Forecast hour has exceeded the grib file's final" + ! write(LIS_logunit,*) & + ! " forecast hour (record). Run will end here for now ... " + ! call LIS_endrun + ! endif + ! endif + ! ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-25deg): + ! if(galwem_struc(n)%resol == 25) then + ! if(galwem_struc(n)%fcst_hour > 240 ) then + ! write(LIS_logunit,*) & + ! "[INFO] GALWEM Forecast hour has exceeded the grib file's final" + ! write(LIS_logunit,*) & + ! " forecast hour (record). Run will end here for now ... " + ! call LIS_endrun + ! endif + ! endif + + ! ! Update bookend-time record 2: + ! if(LIS_rc%tscount(n).ne.1) then + ! galwem_struc(n)%fcsttime1=galwem_struc(n)%fcsttime2 + ! galwem_struc(n)%metdata1=galwem_struc(n)%metdata2 + + ! yr2=LIS_rc%syr + ! mo2=LIS_rc%smo + ! da2=LIS_rc%sda + ! hr2=LIS_rc%shr + ! mn2=0 + ! ss2=0 + ! ts2=3600 * galwem_struc(n)%fcst_hour + ! call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + ! endif + + ! ! Read in file contents: + ! if(LIS_rc%tscount(n) == 1) then ! Read in first two book-ends + + ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_yr = ', & + ! ! galwem_struc(n)%init_yr + ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_mo = ', & + ! ! galwem_struc(n)%init_mo + ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_da = ', & + ! ! galwem_struc(n)%init_da + ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_hr = ', & + ! ! galwem_struc(n)%init_hr + ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%fcst_hour = ', & + ! ! galwem_struc(n)%fcst_hour + + ! ferror=0 + ! order=1 + ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& + ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& + ! 0,fname) + + ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file1 ... ',trim(fname) + ! call read_galwem(n, findex, order, fname, ferror) + ! if(ferror.ge.1) galwem_struc(n)%fcsttime1=time1 + + ! ferror=0 + ! order=2 + ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& + ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& + ! galwem_struc(n)%fcst_hour,fname) + + ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) + ! call read_galwem(n, findex, order, fname, ferror) + ! if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 + ! else + ! ferror=0 + ! order=2 + ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& + ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& + ! galwem_struc(n)%fcst_hour,fname) + + ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) + ! call read_galwem(n, findex, order, fname, ferror) + ! if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 + ! endif + ! endif + ! openfile=0 + + ! !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime1 = ", & + ! ! galwem_struc(n)%fcsttime1 + ! !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime2 = ", & + ! ! galwem_struc(n)%fcsttime2 + end subroutine get_galwem !BOP @@ -389,7 +508,7 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) fcsthr, fname) inquire(file=trim(fname), exist=found_inq) if (found_inq) then - write(LIS_logunit,*)'[INFO] Found ', trim(fname) + !write(LIS_logunit,*)'[INFO] Found ', trim(fname) filecount = filecount + 1 else if (i == 0) then From 57c659d10836a7039b8e0a5cdc4ebc07bdda351d Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 8 Jan 2024 17:00:55 -0500 Subject: [PATCH 269/328] LIS will now terminate early after dumping files if GALWEM file is missing. EXCEPTION: LIS will terminate immediately if, on the initial time step, less than 2 GALWEM GRIB files can be found (that's not enough to bookend any part of the simulation). --- lis/core/LIS_coreMod.F90 | 18 ++++++++++++++++-- lis/metforcing/galwem/get_galwem.F90 | 24 ++++++++++++++---------- 2 files changed, 30 insertions(+), 12 deletions(-) diff --git a/lis/core/LIS_coreMod.F90 b/lis/core/LIS_coreMod.F90 index 80e551c6f..ec6ce6317 100644 --- a/lis/core/LIS_coreMod.F90 +++ b/lis/core/LIS_coreMod.F90 @@ -462,10 +462,14 @@ end subroutine LIS_ticktime ! \label{LIS_endofrun} ! ! !INTERFACE: - function LIS_endofrun() result(finish) + function LIS_endofrun(override_end_time) result(finish) -! !ARGUMENTS: + use LIS_logMod, only: LIS_logunit + + ! !ARGUMENTS: + logical, optional, intent(in) :: override_end_time logical :: finish + ! !DESCRIPTION: ! This function checks to see if the runtime clock has reached the ! specified stop time of the simulation. @@ -483,9 +487,19 @@ function LIS_endofrun() result(finish) ! \end{description} !EOP integer :: ierr + logical, save :: force_end = .false. ! EMK + ! EMK: Allows a metforcing reader to override + if (present(override_end_time)) then + force_end = override_end_time + end if if(LIS_masterproc) then finish = LIS_is_last_step(LIS_rc) + ! EMK: Allows a metforcing reader to override + if (force_end) then + finish = .true. + write(LIS_logunit,*)'[INFO] LIS will terminate early!' + end if endif #if (defined SPMD) call MPI_BCAST(finish, 1, MPI_LOGICAL, 0, & diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index 1730b25db..fb37455fd 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -59,7 +59,8 @@ subroutine get_galwem(n, findex) logical, save :: use_prior_galwem_run integer :: first_fcsthr, next_fcsthr integer :: ierr - + logical :: lrc + ! GALWEM cycles every 6 hours; each cycle provide up to 168 hours (7 days) forecast for GALWEM-17km; ! each cycle provide up to 240 hours (10 days) forecast for GALWEM-25deg; ! <=42 (every 1-hour); > 42 (every 3-hour) @@ -107,7 +108,8 @@ subroutine get_galwem(n, findex) call run_audit(n, yr1, mo1, da1, hr1, & 12, filecount) if (filecount < 2) then - write(LIS_logunit,*)"[ERR] No GALWEM files found!" + write(LIS_logunit,*) & + "[ERR] No GALWEM files found, LIS will be halted!" call LIS_endrun() else use_prior_galwem_run = .true. @@ -120,11 +122,11 @@ subroutine get_galwem(n, findex) end if !write(LIS_logunit,*) '[INFO] use_prior_galwem_run = ', & ! use_prior_galwem_run - if (use_prior_galwem_run) then - write(LIS_logunit,*) & - '[WARN] LIS run may terminate early since a prior ' // & - 'GALWEM run is being used for forcing' - end if + !if (use_prior_galwem_run) then + ! write(LIS_logunit,*) & + ! '[WARN] LIS run may terminate early since a prior ' // & + ! 'GALWEM run is being used for forcing' + !end if ! Get the bookends at the start of the run if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then @@ -279,10 +281,12 @@ subroutine get_galwem(n, findex) galwem_struc(n)%init_hr, & galwem_struc(n)%fcst_hour, next_fcsthr, ierr) if (ierr .ne. 0) then - write(LIS_logunit,*) '[ERR] Cannot find next GALWEM GRIB file!' - write(LIS_logunit,*) '[ERR] LIS will terminate early' + write(LIS_logunit,*) & + '[WARN] Cannot find next GALWEM GRIB file!' flush(LIS_logunit) - call LIS_endrun() + !call LIS_endrun() + lrc = LIS_endofrun(.true.) ! Force LIS_endofrun to return .true. + return end if yr2 = galwem_struc(n)%init_yr mo2 = galwem_struc(n)%init_mo From ec1a9b9aa3234ce5c8cc12ed249fb152799c700c Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 9 Jan 2024 09:05:13 -0500 Subject: [PATCH 270/328] Add new run-time configuration options to smos_nrt_nn_l2sm testcase --- lis/testcases/dataassim/smos_nrt_nn_l2sm/lis.config | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lis/testcases/dataassim/smos_nrt_nn_l2sm/lis.config b/lis/testcases/dataassim/smos_nrt_nn_l2sm/lis.config index 735d1126b..3853d8ffb 100644 --- a/lis/testcases/dataassim/smos_nrt_nn_l2sm/lis.config +++ b/lis/testcases/dataassim/smos_nrt_nn_l2sm/lis.config @@ -190,7 +190,7 @@ AGRMET GALWEM SPD10M background error scale length (m): 100000. AGRMET GALWEM SPD10M background error variance: 0.35 AGRMET GALWEM SPD10M station observation error variance: 2.52 -AGRMET GALWEM nominal resolution (km): 17 # 17 or 10; for now, just use 17 +AGRMET GALWEM nominal resolution (km): 17 # 17 or 10; for now, just use 17 # 10-km AGRMET GFS Precip background error scale length (m): 75000. @@ -235,6 +235,8 @@ AGRMET skip superstatQC : 0 AGRMET WWMCA GRIB1 read option: 0 AGRMET PPT Background bias correction option: 0 +AGRMET precip obs file format: 1 +AGRMET sfc obs file format: 1 #-----------------------LAND SURFACE MODELS-------------------------- Noah.3.9 model timestep: 15mn Noah.3.9 restart output interval: 1mo From 73e87bad6ca42794f3444a47a69c22490768bb6a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 9 Jan 2024 12:51:44 -0500 Subject: [PATCH 271/328] Removed dead code and updated some comments. --- lis/metforcing/galwem/get_galwem.F90 | 180 +-------------------------- 1 file changed, 6 insertions(+), 174 deletions(-) diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index fb37455fd..ef0a5dfa2 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -21,6 +21,10 @@ ! 00Z, to correct time intervals between GALWEM-GD files, ! and to stop searching for (nonexistent) GALWEM-GD file ! when LIS reaches it's end time. +! 09 Jan 2024: Eric Kemp. Reworked code to be fault tolerant, to roll +! back to an earlier GALWEM run if necessary, and to better +! ensure LIS outputs history files before an early +! termination. ! !INTERFACE: subroutine get_galwem(n, findex) ! !USES: @@ -60,7 +64,7 @@ subroutine get_galwem(n, findex) integer :: first_fcsthr, next_fcsthr integer :: ierr logical :: lrc - + ! GALWEM cycles every 6 hours; each cycle provide up to 168 hours (7 days) forecast for GALWEM-17km; ! each cycle provide up to 240 hours (10 days) forecast for GALWEM-25deg; ! <=42 (every 1-hour); > 42 (every 3-hour) @@ -120,13 +124,6 @@ subroutine get_galwem(n, findex) end if end if end if - !write(LIS_logunit,*) '[INFO] use_prior_galwem_run = ', & - ! use_prior_galwem_run - !if (use_prior_galwem_run) then - ! write(LIS_logunit,*) & - ! '[WARN] LIS run may terminate early since a prior ' // & - ! 'GALWEM run is being used for forcing' - !end if ! Get the bookends at the start of the run if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then @@ -170,52 +167,6 @@ subroutine get_galwem(n, findex) openfile = 1 end if - ! ! First timestep of run - ! if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then - ! ! Bookend-time record 1 - ! yr1 = LIS_rc%syr - ! mo1=LIS_rc%smo - ! da1=LIS_rc%sda - ! hr1=LIS_rc%shr - ! mn1=0 - ! ss1=0 - ! ts1=0 - ! call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) - - ! ! Bookend-time record 2 - ! yr2=LIS_rc%syr - ! mo2=LIS_rc%smo - ! da2=LIS_rc%sda - ! hr2=LIS_rc%shr - ! mn2=0 - ! ss2=0 - ! ts2=3600 ! Advance 1 hour - ! call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) - - ! !movetime = 1 - ! openfile=1 - - ! !write(LIS_logunit,*)'EMK: time1,yr1,mo1,da1,hr1,ts1 = ', & - ! ! time1,yr1,mo1,da1,hr1,ts1 - ! !write(LIS_logunit,*)'EMK: time2,yr2,mo2,da2,hr2,ts2 = ', & - ! ! time2,yr2,mo2,da2,hr2,ts2 - - ! endif - - ! ! Determine valid times when forecasts are available to be read in: - ! ! EMK...Revised based on sample forecast runs for 20230523. - ! if(galwem_struc(n)%fcst_hour < 42) then - ! fcsthr_intv = 1 - ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - ! elseif(galwem_struc(n)%fcst_hour >= 42 .and. & - ! galwem_struc(n)%fcst_hour < 168) then - ! fcsthr_intv = 3 - ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - ! else - ! fcsthr_intv = 6 - ! valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - ! endif - ! If this is the beginning of the LIS run, read the two bookends if (openfile == 1) then @@ -269,9 +220,6 @@ subroutine get_galwem(n, findex) ts2 = 3600 * galwem_struc(n)%fcst_hour call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) - !write(LIS_logunit,*)'EMK: time1: ', time1 - !write(LIS_logunit,*)'EMK: time2: ', time2 - if (time2 .le. time1) then ! Update the bookends @@ -284,7 +232,6 @@ subroutine get_galwem(n, findex) write(LIS_logunit,*) & '[WARN] Cannot find next GALWEM GRIB file!' flush(LIS_logunit) - !call LIS_endrun() lrc = LIS_endofrun(.true.) ! Force LIS_endofrun to return .true. return end if @@ -322,112 +269,6 @@ subroutine get_galwem(n, findex) end if openfile = 0 - !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime1 = ", & - ! galwem_struc(n)%fcsttime1 - !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime2 = ", & - ! galwem_struc(n)%fcsttime2 - - !call LIS_endrun() ! EMK TEST - - - ! if((valid_hour==LIS_rc%hr .and. LIS_rc%mn==0) .or. & - ! openfile == 1) then - - ! ! Forecast hour condition within each file: - ! if(galwem_struc(n)%fcst_hour < 42) then - ! galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv - ! elseif(galwem_struc(n)%fcst_hour >= 42) then - ! galwem_struc(n)%fcst_hour = galwem_struc(n)%fcst_hour + fcsthr_intv - ! endif - - ! ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-17km): - ! if(galwem_struc(n)%resol == 17) then - ! if(galwem_struc(n)%fcst_hour > 168 ) then - ! write(LIS_logunit,*) & - ! "[INFO] GALWEM Forecast hour has exceeded the grib file's final" - ! write(LIS_logunit,*) & - ! " forecast hour (record). Run will end here for now ... " - ! call LIS_endrun - ! endif - ! endif - ! ! Check if local forecast hour exceeds max grib file forecast hour (GALWEM-25deg): - ! if(galwem_struc(n)%resol == 25) then - ! if(galwem_struc(n)%fcst_hour > 240 ) then - ! write(LIS_logunit,*) & - ! "[INFO] GALWEM Forecast hour has exceeded the grib file's final" - ! write(LIS_logunit,*) & - ! " forecast hour (record). Run will end here for now ... " - ! call LIS_endrun - ! endif - ! endif - - ! ! Update bookend-time record 2: - ! if(LIS_rc%tscount(n).ne.1) then - ! galwem_struc(n)%fcsttime1=galwem_struc(n)%fcsttime2 - ! galwem_struc(n)%metdata1=galwem_struc(n)%metdata2 - - ! yr2=LIS_rc%syr - ! mo2=LIS_rc%smo - ! da2=LIS_rc%sda - ! hr2=LIS_rc%shr - ! mn2=0 - ! ss2=0 - ! ts2=3600 * galwem_struc(n)%fcst_hour - ! call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) - ! endif - - ! ! Read in file contents: - ! if(LIS_rc%tscount(n) == 1) then ! Read in first two book-ends - - ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_yr = ', & - ! ! galwem_struc(n)%init_yr - ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_mo = ', & - ! ! galwem_struc(n)%init_mo - ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_da = ', & - ! ! galwem_struc(n)%init_da - ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%init_hr = ', & - ! ! galwem_struc(n)%init_hr - ! !write(LIS_logunit,*)'EMK: galwem_struc(n)%fcst_hour = ', & - ! ! galwem_struc(n)%fcst_hour - - ! ferror=0 - ! order=1 - ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - ! 0,fname) - - ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file1 ... ',trim(fname) - ! call read_galwem(n, findex, order, fname, ferror) - ! if(ferror.ge.1) galwem_struc(n)%fcsttime1=time1 - - ! ferror=0 - ! order=2 - ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - ! galwem_struc(n)%fcst_hour,fname) - - ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) - ! call read_galwem(n, findex, order, fname, ferror) - ! if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 - ! else - ! ferror=0 - ! order=2 - ! call getGALWEMfilename(n,galwem_struc(n)%odir,galwem_struc(n)%init_yr,& - ! galwem_struc(n)%init_mo,galwem_struc(n)%init_da,galwem_struc(n)%init_hr,& - ! galwem_struc(n)%fcst_hour,fname) - - ! write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ',trim(fname) - ! call read_galwem(n, findex, order, fname, ferror) - ! if(ferror.ge.1) galwem_struc(n)%fcsttime2=time2 - ! endif - ! endif - ! openfile=0 - - ! !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime1 = ", & - ! ! galwem_struc(n)%fcsttime1 - ! !write(LIS_logunit,*)"EMK: galwem_struc(n)%fcsttime2 = ", & - ! ! galwem_struc(n)%fcsttime2 - end subroutine get_galwem !BOP @@ -475,7 +316,7 @@ subroutine getGALWEMfilename(n,rootdir,yr,mo,da,hr,fc_hr,filename) trim(fname) // ftime // '_CY.' // chr // '_FH.' // fchr // '_DF.GR2' end subroutine getGALWEMfilename -! Run audit on GRIB files with specified start date and time. +! Run audit on GALWEM GRIB files with specified start date and time. subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) ! Imports @@ -512,7 +353,6 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) fcsthr, fname) inquire(file=trim(fname), exist=found_inq) if (found_inq) then - !write(LIS_logunit,*)'[INFO] Found ', trim(fname) filecount = filecount + 1 else if (i == 0) then @@ -529,14 +369,6 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) if (filecount > 0) then write(LIS_logunit,*)'[INFO] Found ', filecount, ' files' end if - !yr1 = yr - !mo1 = mo - !da1 = da - !hr1 = hr - !mn1 = 0 - !ss1 = 0 - !ts1 = 0 - !call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) end subroutine run_audit From 95a3516944ad1853736f77071bd9881787410917 Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Tue, 9 Jan 2024 14:30:13 -0500 Subject: [PATCH 272/328] add MOGREPS-G forecast reader --- lis/make/default.cfg | 5 +- .../mogreps_g/finalize_mogrepsg.F90 | 30 + lis/metforcing/mogreps_g/get_mogrepsg.F90 | 230 +++++ .../mogreps_g/mogrepsg_forcingMod.F90 | 327 +++++++ lis/metforcing/mogreps_g/read_mogrepsg.F90 | 851 ++++++++++++++++++ lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 | 62 ++ lis/metforcing/mogreps_g/reset_mogrepsg.F90 | 38 + .../mogreps_g/timeinterp_mogrepsg.F90 | 301 +++++++ lis/plugins/LIS_metforcing_pluginMod.F90 | 20 +- lis/plugins/LIS_pluginIndices.F90 | 1 + 10 files changed, 1863 insertions(+), 2 deletions(-) create mode 100644 lis/metforcing/mogreps_g/finalize_mogrepsg.F90 create mode 100644 lis/metforcing/mogreps_g/get_mogrepsg.F90 create mode 100644 lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 create mode 100644 lis/metforcing/mogreps_g/read_mogrepsg.F90 create mode 100644 lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 create mode 100644 lis/metforcing/mogreps_g/reset_mogrepsg.F90 create mode 100644 lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 diff --git a/lis/make/default.cfg b/lis/make/default.cfg index ee4345171..82530a264 100644 --- a/lis/make/default.cfg +++ b/lis/make/default.cfg @@ -472,7 +472,10 @@ enabled: True macro: MF_GALWEM_GE_FORECAST path: metforcing/galwem_ge - +[MOGREPS-G forecast] +enabled: True +macro: MF_MOGREPS_G_FORECAST +path: metforcing/mogreps_g #}}} diff --git a/lis/metforcing/mogreps_g/finalize_mogrepsg.F90 b/lis/metforcing/mogreps_g/finalize_mogrepsg.F90 new file mode 100644 index 000000000..85c51ea0a --- /dev/null +++ b/lis/metforcing/mogreps_g/finalize_mogrepsg.F90 @@ -0,0 +1,30 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! !MODULE: finalize_mogrepsg +! \label{finalize_mogrepsg} +! +! !REVISION HISTORY: +! 26 Jan 2023; Yeosang Yoon, Initial Code +! +! !INTERFACE: +subroutine finalize_mogrepsg +! !USES: + use mogrepsg_forcingMod, only : mogrepsg_struc +! +! !DESCRIPTION: +! Routine to cleanup allocated structures for MOGREPS-G forcing. +! +!EOP + implicit none + + deallocate(mogrepsg_struc) + +end subroutine finalize_mogrepsg diff --git a/lis/metforcing/mogreps_g/get_mogrepsg.F90 b/lis/metforcing/mogreps_g/get_mogrepsg.F90 new file mode 100644 index 000000000..31a206b91 --- /dev/null +++ b/lis/metforcing/mogreps_g/get_mogrepsg.F90 @@ -0,0 +1,230 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: get_mogrepsg +! \label{get_mogrepsg} +! +! +! !REVISION HISTORY: +! 26 Jan 2023: Yeosang Yoon, initial code +! 13 Mar 2023: Yeosang Yoon, update codes to fit new format +! +! !INTERFACE: +subroutine get_mogrepsg(n, findex) +! !USES: + use LIS_coreMod + use LIS_timeMgrMod + use LIS_logMod + use LIS_metforcingMod + use mogrepsg_forcingMod + use LIS_constantsMod, only: LIS_CONST_PATH_LEN + + implicit none + +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex +! +! +! !DESCRIPTION: +! Opens, reads, and interpolates MOGREPS-G forecast forcing. +! +! At the beginning of a simulation, the code reads the most recent +! past data (nearest 3-hour interval), and the nearest future data. +! These two datasets are used to temporally interpolate the data to +! the current model timestep. + +!EOP + integer :: order, ferror, m, t + character(len=LIS_CONST_PATH_LEN) :: fname + integer :: yr1, mo1, da1, hr1, mn1, ss1, doy1 + integer :: yr2, mo2, da2, hr2, mn2, ss2, doy2 + real*8 :: time1, time2 + real :: gmt1, gmt2 + real :: ts1, ts2 + integer :: fc_hr + + integer :: hr_int1, hr_int2 + integer :: valid_hour + integer :: fcsthr_intv + integer :: fcst_hour + integer :: openfile + + ! MOGREPS-G cycles every 6 hours; ecch cycle provide up to 192 hours (8 days; 3-hour interval) forecast + if(LIS_rc%ts.gt.10800) then + write(LIS_logunit,*) '[WARN] The model timestep is > forcing data timestep ...' + write(LIS_logunit,*) '[WARN] LIS does not support this mode currently.' + call LIS_endrun() + endif + + openfile=0 + + if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then !beginning of run + LIS_rc%rstflag(n) = 0 + endif + + ! First timestep of run + if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then + ! Bookend-time record 1 + yr1 = LIS_rc%yr + mo1=LIS_rc%mo + da1=LIS_rc%da + hr1=LIS_rc%hr + mn1=0 + ss1=0 + ts1=0 + call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + + ! Bookend-time record 2 + yr2=LIS_rc%yr !next hour + mo2=LIS_rc%mo + da2=LIS_rc%da + hr2=3 + mn2=0 + ss2=0 + ts2=0 + call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + openfile=1 + endif + + ! 3 hourly interval + fcsthr_intv = 3 + valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) + + if((valid_hour==LIS_rc%hr .and. LIS_rc%mn==0) .or. & + openfile == 1) then + + ! Forecast hour condition within each file: + mogrepsg_struc(n)%fcst_hour = mogrepsg_struc(n)%fcst_hour + fcsthr_intv + + ! Check if local forecast hour exceeds max grib file forecast hour: + if(mogrepsg_struc(n)%fcst_hour > 195 ) then + write(LIS_logunit,*) & + "[INFO] MOGREPS-G Forecast hour has exceeded the grib file's final" + write(LIS_logunit,*) & + ' forecast hour (record). Run will end here for now ... ' + call LIS_endrun + endif + + ! Update bookend-time record 2: + if(LIS_rc%tscount(n).ne.1) then + mogrepsg_struc(n)%fcsttime1=mogrepsg_struc(n)%fcsttime2 + mogrepsg_struc(n)%metdata1=mogrepsg_struc(n)%metdata2 + + yr2=LIS_rc%yr + mo2=LIS_rc%mo + da2=LIS_rc%da + hr2=valid_hour + mn2=fcsthr_intv*60 ! Backward looking + ss2=0 + ts2=0 + call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + endif + + do m=1,mogrepsg_struc(n)%max_ens_members + + ! Read in file contents: + if(LIS_rc%tscount(n) == 1) then ! Read in first two book-ends + ferror=0 + order=1 + call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& + mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& + 0,m,fname) + + write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file1 ... ',trim(fname) + call read_mogrepsg(n, m, findex, order, fname, ferror) + if(ferror.ge.1) mogrepsg_struc(n)%fcsttime1=time1 + + ferror=0 + order=2 + call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& + mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& + mogrepsg_struc(n)%fcst_hour,m,fname) + + write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file2 ... ',trim(fname) + call read_mogrepsg(n, m, findex, order, fname, ferror) + if(ferror.ge.1) mogrepsg_struc(n)%fcsttime2=time2 + + !only for T+0 due to mssing LW varaible + mogrepsg_struc(n)%metdata1(4,m,:) = mogrepsg_struc(n)%metdata2(4,m,:) + else + ferror=0 + order=2 + ! met forcings except for pcp + call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& + mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& + mogrepsg_struc(n)%fcst_hour,m,fname) + + write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file2 ... ',trim(fname) + call read_mogrepsg(n, m, findex, order, fname, ferror) + if(ferror.ge.1) mogrepsg_struc(n)%fcsttime2=time2 + + !only for T+141 due to mssing LW varaible + if(mogrepsg_struc(n)%fcst_hour == 141) then + mogrepsg_struc(n)%metdata2(4,m,:) = mogrepsg_struc(n)%metdata1(4,m,:) + endif + endif + enddo + endif + openfile=0 + +end subroutine get_mogrepsg + +!BOP +! +! !ROUTINE: get_mogrepsg_filename +! \label{get_mogrepsg_filename} +! +! !INTERFACE: +subroutine get_mogrepsg_filename(rootdir,yr,mo,da,hr,fc_hr,ens_id,filename) + + use LIS_logMod, only: LIS_logunit, LIS_endrun + implicit none +! !ARGUMENTS: + character(len=*), intent(in) :: rootdir + integer, intent(in) :: yr,mo,da,hr + integer, intent(in) :: fc_hr + integer, intent(in) :: ens_id + character(len=*), intent(out) :: filename +! +! !DESCRIPTION: +! This subroutine puts together MOGREPS-G file name for +! operational products +!EOP + character(8) :: ftime + character(2) :: chr + character(3) :: fchr + character(2) :: ens + + character(len=36) :: fname + + write (UNIT=chr, FMT='(i2.2)') hr ! cycle 00/06/12/18 + write (UNIT=fchr, FMT='(i3.3)') fc_hr ! forecast time + write (UNIT=ftime, FMT='(i4, i2.2, i2.2)') yr, mo, da + + fname = 'prods_op_mogreps-g_' + + !00/12z cycle memebers 00,01-17 + !06/18z cycle memebers 00,18-34 + if ((hr == 0) .or. (hr == 12)) then + write (UNIT=ens, FMT='(i2.2)') ens_id-1 ! start 00, 01 - 17 + else + if (ens_id == 1) then + write (UNIT=ens, FMT='(i2.2)') ens_id-1 ! start 00 + else + write (UNIT=ens, FMT='(i2.2)') ens_id+16 ! start 18-34 + endif + endif + + filename = trim(rootdir)//'/'//ftime//chr//'/'//trim(fname) & + //ftime//'_'//chr//'_'//ens//'_'//fchr//'.grib2' +end subroutine get_mogrepsg_filename + diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 new file mode 100644 index 000000000..70445c340 --- /dev/null +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -0,0 +1,327 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +module mogrepsg_forcingMod +!BOP +! !MODULE: mogrepsg_forcingMod + +! !DESCRIPTION: +! This module contains variables and data structures that are used +! for the implementation of MOGREPS-G 8-day forecast data used as forcing +! within LIS. + +! REVISION HISTORY: +! 26 Jan 2023; Yeosang Yoon; Initial Specification + +! !USES: + use LIS_constantsMod, only : LIS_CONST_PATH_LEN + + implicit none + + PRIVATE +!----------------------------------------------------------------------------- +! !PUBLIC MEMBER FUNCTIONS: +!----------------------------------------------------------------------------- + public :: init_mogrepsg !defines the native resolution of the input data +!----------------------------------------------------------------------------- +! !PUBLIC TYPES: +!----------------------------------------------------------------------------- + public :: mogrepsg_struc + + type, public :: mogrepsg_type_dec + real :: ts + integer :: nc, nr, vector_len + real*8 :: fcsttime1,fcsttime2 + character(len=LIS_CONST_PATH_LEN) :: odir !MOGREPS-G forecast forcing Directory + character*20 :: runmode + integer :: max_ens_members + + integer, allocatable :: gindex(:,:) + + integer :: mi + + integer, allocatable :: n111(:) + integer, allocatable :: n121(:) + integer, allocatable :: n211(:) + integer, allocatable :: n221(:) + real, allocatable :: w111(:),w121(:) + real, allocatable :: w211(:),w221(:) + + integer, allocatable :: n112(:,:) + integer, allocatable :: n122(:,:) + integer, allocatable :: n212(:,:) + integer, allocatable :: n222(:,:) + real, allocatable :: w112(:,:),w122(:,:) + real, allocatable :: w212(:,:),w222(:,:) + + integer, allocatable :: n113(:) + + integer :: findtime1, findtime2 + integer :: fcst_hour + integer :: init_yr, init_mo, init_da, init_hr + real, allocatable :: metdata1(:,:,:) + real, allocatable :: metdata2(:,:,:) + + integer :: nmodels + + ! only for v-wind due to difference resolution + integer :: nrv + integer, allocatable :: nv111(:) + integer, allocatable :: nv121(:) + integer, allocatable :: nv211(:) + integer, allocatable :: nv221(:) + real, allocatable :: wv111(:),wv121(:) + real, allocatable :: wv211(:),wv221(:) + + integer, allocatable :: nv112(:,:) + integer, allocatable :: nv122(:,:) + integer, allocatable :: nv212(:,:) + integer, allocatable :: nv222(:,:) + real, allocatable :: wv112(:,:),wv122(:,:) + real, allocatable :: wv212(:,:),wv222(:,:) + + integer, allocatable :: nv113(:) + + end type mogrepsg_type_dec + + type(mogrepsg_type_dec), allocatable :: mogrepsg_struc(:) +!EOP +contains + +!BOP +! +! !ROUTINE: init_mogrepsg +! \label{init_mogrepsg} +! +! !INTERFACE: + subroutine init_mogrepsg(findex) +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_timeMgrMod, only : LIS_update_timestep + use LIS_logMod, only : LIS_logunit, LIS_endrun + + implicit none +! !USES: + integer, intent(in) :: findex +! +! !DESCRIPTION: +! Defines the native resolution of the input forcing for MOGREPS-G +! data. The grid description arrays are based on the decoding +! schemes used by NCEP and followed in the LIS interpolation +! schemes (see Section~\ref{interp}). +! +!EOP + + integer :: n + real :: gridDesci(LIS_rc%nnest,50) + real :: gridDesci_v(LIS_rc%nnest,50) ! v-wind + + write(LIS_logunit,*) "[INFO] Initializing the MOGREPS-G forecast inputs " + + ! Forecast mode -- NOT Available at this time for this forcing reader: + if( LIS_rc%forecastMode.eq.1 ) then + write(LIS_logunit,*) '[ERR] Currently the MOGREPS-G forecast forcing reader' + write(LIS_logunit,*) '[ERR] is not set up to run in forecast mode.' + write(LIS_logunit,*) '[ERR] LIS forecast run-time ending.' + call LIS_endrun() + endif + + allocate(mogrepsg_struc(LIS_rc%nnest)) + call readcrd_mogrepsg() + + do n=1, LIS_rc%nnest + mogrepsg_struc(n)%ts = 3600*3 !check + call LIS_update_timestep(LIS_rc, n, mogrepsg_struc(n)%ts) + enddo + + do n=1, LIS_rc%nnest + mogrepsg_struc(:)%nc = 1280 ! mogreps-g + mogrepsg_struc(:)%nr = 960 + mogrepsg_struc(:)%nrv = 961 ! v-wind + enddo + + ! 8 - key met field + LIS_rc%met_nf(findex) = 8 + + do n=1,LIS_rc%nnest + + ! Check if starting hour of LIS run matches 00/06/12/18 UTC: + if((LIS_rc%shr .ne. 0) .and. (LIS_rc%shr .ne. 6) .and. & + (LIS_rc%shr .ne. 12) .and. (LIS_rc%shr .ne. 18)) then + write(LIS_logunit,*) "[ERR] GALWEM forecast type begins" + write(LIS_logunit,*) "[ERR] at 00/12Z for a forecast window, so the " + write(LIS_logunit,*) "[ERR] 'Starting hour:' should be set to 0/12 in" + write(LIS_logunit,*) "[ERR] your lis.config file.." + call LIS_endrun() + endif + + ! Allocate and initialize MOGREPS-G metforcing data structures: + LIS_rc%met_nensem(findex) = mogrepsg_struc(n)%max_ens_members + + allocate(mogrepsg_struc(n)%metdata1(LIS_rc%met_nf(findex),& + mogrepsg_struc(n)%max_ens_members,LIS_rc%ngrid(n))) + allocate(mogrepsg_struc(n)%metdata2(LIS_rc%met_nf(findex),& + mogrepsg_struc(n)%max_ens_members,LIS_rc%ngrid(n))) + + ! Initialize the forecast initial date-time and grib record: + mogrepsg_struc(n)%init_yr = LIS_rc%syr + mogrepsg_struc(n)%init_mo = LIS_rc%smo + mogrepsg_struc(n)%init_da = LIS_rc%sda + mogrepsg_struc(n)%init_hr = LIS_rc%shr + + mogrepsg_struc(n)%fcst_hour = 0 + mogrepsg_struc(n)%metdata1 = 0 + mogrepsg_struc(n)%metdata2 = 0 + gridDesci = 0 + + gridDesci(n,1) = 0 + gridDesci(n,2) = mogrepsg_struc(n)%nc !gnc + gridDesci(n,3) = mogrepsg_struc(n)%nr !gnr + gridDesci(n,4) = -89.906250 !lat(1,1) + gridDesci(n,5) = -179.859375 !lon(1,1) + gridDesci(n,6) = 128 + gridDesci(n,7) = 89.906250 !lat(gnc,gnr) + gridDesci(n,8) = 179.859375 !lon(gnc,gnr) + gridDesci(n,9) = 0.28125 !dx + gridDesci(n,10) = 0.18750 !dy + gridDesci(n,20) = 0 !for 0 to 360? + + mogrepsg_struc(n)%mi = mogrepsg_struc(n)%nc*mogrepsg_struc(n)%nr + mogrepsg_struc(n)%fcsttime1 = 3000.0 + mogrepsg_struc(n)%fcsttime2 = 0.0 + + ! v-wind + gridDesci_v(n,1) = 0 + gridDesci_v(n,2) = mogrepsg_struc(n)%nc !gnc + gridDesci_v(n,3) = mogrepsg_struc(n)%nrv !gnr + gridDesci_v(n,4) = -90.000000 !lat(1,1) + gridDesci_v(n,5) = -179.859375 !lon(1,1) + gridDesci_v(n,6) = 128 + gridDesci_v(n,7) = 90.000000 !lat(gnc,gnr) + gridDesci_v(n,8) = 179.859375 !lon(gnc,gnr) + gridDesci_v(n,9) = 0.28125 !dx + gridDesci_v(n,10) = 0.18750 !dy + gridDesci(n,20) = 0 !for 0 to 360? + enddo + + do n=1,LIS_rc%nnest + !Setting up weights for Interpolation + if(trim(LIS_rc%met_interp(findex)).eq."bilinear") then + allocate(mogrepsg_struc(n)%n111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call bilinear_interp_input(n,gridDesci(n,:),& + mogrepsg_struc(n)%n111,mogrepsg_struc(n)%n121,& + mogrepsg_struc(n)%n211,mogrepsg_struc(n)%n221,& + mogrepsg_struc(n)%w111,mogrepsg_struc(n)%w121,& + mogrepsg_struc(n)%w211,mogrepsg_struc(n)%w221) + + elseif(trim(LIS_rc%met_interp(findex)).eq."budget-bilinear") then + allocate(mogrepsg_struc(n)%n111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%n221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%w221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call bilinear_interp_input(n,gridDesci(n,:),& + mogrepsg_struc(n)%n111,mogrepsg_struc(n)%n121,& + mogrepsg_struc(n)%n211,mogrepsg_struc(n)%n221,& + mogrepsg_struc(n)%w111,mogrepsg_struc(n)%w121,& + mogrepsg_struc(n)%w211,mogrepsg_struc(n)%w221) + + allocate(mogrepsg_struc(n)%n112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%n122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%n212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%n222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%w112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%w122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%w212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%w222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + + call conserv_interp_input(n,gridDesci(n,:),& + mogrepsg_struc(n)%n112,mogrepsg_struc(n)%n122,& + mogrepsg_struc(n)%n212,mogrepsg_struc(n)%n222,& + mogrepsg_struc(n)%w112,mogrepsg_struc(n)%w122,& + mogrepsg_struc(n)%w212,mogrepsg_struc(n)%w222) + elseif(trim(LIS_rc%met_interp(findex)).eq."neighbor") then + allocate(mogrepsg_struc(n)%n113(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call neighbor_interp_input(n,gridDesci(n,:),& + mogrepsg_struc(n)%n113) + endif + + ! v-wind + !Setting up weights for Interpolation + if(trim(LIS_rc%met_interp(findex)).eq."bilinear") then + allocate(mogrepsg_struc(n)%nv111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call bilinear_interp_input(n,gridDesci_v(n,:),& + mogrepsg_struc(n)%nv111,mogrepsg_struc(n)%nv121,& + mogrepsg_struc(n)%nv211,mogrepsg_struc(n)%nv221,& + mogrepsg_struc(n)%wv111,mogrepsg_struc(n)%wv121,& + mogrepsg_struc(n)%wv211,mogrepsg_struc(n)%wv221) + + elseif(trim(LIS_rc%met_interp(findex)).eq."budget-bilinear") then + allocate(mogrepsg_struc(n)%nv111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%nv221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv111(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv121(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv211(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + allocate(mogrepsg_struc(n)%wv221(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call bilinear_interp_input(n,gridDesci_v(n,:),& + mogrepsg_struc(n)%nv111,mogrepsg_struc(n)%nv121,& + mogrepsg_struc(n)%nv211,mogrepsg_struc(n)%nv221,& + mogrepsg_struc(n)%wv111,mogrepsg_struc(n)%wv121,& + mogrepsg_struc(n)%wv211,mogrepsg_struc(n)%wv221) + + allocate(mogrepsg_struc(n)%nv112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%nv122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%nv212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%nv222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%wv112(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%wv122(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%wv212(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + allocate(mogrepsg_struc(n)%wv222(LIS_rc%lnc(n)*LIS_rc%lnr(n),25)) + + call conserv_interp_input(n,gridDesci_v(n,:),& + mogrepsg_struc(n)%nv112,mogrepsg_struc(n)%nv122,& + mogrepsg_struc(n)%nv212,mogrepsg_struc(n)%nv222,& + mogrepsg_struc(n)%wv112,mogrepsg_struc(n)%wv122,& + mogrepsg_struc(n)%wv212,mogrepsg_struc(n)%wv222) + + elseif(trim(LIS_rc%met_interp(findex)).eq."neighbor") then + allocate(mogrepsg_struc(n)%nv113(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + call neighbor_interp_input(n,gridDesci_v(n,:),& + mogrepsg_struc(n)%nv113) + endif + enddo + + end subroutine init_mogrepsg +end module mogrepsg_forcingMod diff --git a/lis/metforcing/mogreps_g/read_mogrepsg.F90 b/lis/metforcing/mogreps_g/read_mogrepsg.F90 new file mode 100644 index 000000000..31db01ed8 --- /dev/null +++ b/lis/metforcing/mogreps_g/read_mogrepsg.F90 @@ -0,0 +1,851 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: read_mogrepsg +! \label{read_mogrepsg} +! +! !REVISION HISTORY: +! 26 Jan 2023: Yeosang Yoon, initial code +! 13 Mar 2023: Yeosang Yoon, update code to fit new format (precpitation) +! +! !INTERFACE: +subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) + +! !USES: + use LIS_coreMod + use LIS_logMod + use mogrepsg_forcingMod, only : mogrepsg_struc + +#if (defined USE_GRIBAPI) + use grib_api +#endif + + implicit none + +!ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: m ! number of ensembles + integer, intent(in) :: findex ! forcing index + integer, intent(in) :: order + character(len=*), intent(in) :: gribfile + +!DESCRIPTION: +! For the given time, reads the forcing data from the +! MOGREPS-G file, transforms into LIS forcing +! parameters and interpolates to the LIS domain. +! +! The arguments are: +! \begin{description} +! \item[n] +! index of the nest +! \item[findex] +! index of the forcing +! \item[order] +! flag indicating which data to be read (order=1, read the previous +! hourly instance, order=2, read the next hourly instance) +! \item[gribfile] +! name of the file to be read +! \item[rc] +! return error flag (0-fail, 1-success) +! \end{description} +! +! The routines invoked are: +! \begin{description} +! \item[interp\_mogrepsg](\ref{interp_mogrepsg}) \newline +! Performs spatial interpolation of GALEM-GE forecast data to the LIS grid +! \end{description} + +!EOP + integer :: ftn, igrib, ierr + integer :: center + character*100 :: gtype + integer :: file_julhr + integer :: yr1, mo1, da1, hr1 + character*255 :: message ( 20 ) + integer :: iginfo ( 40 ) + real :: gridres_dlat, gridres_dlon + integer :: ifguess, jfguess + integer :: dataDate, dataTime + integer :: fc_hr + + real :: tair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Temperature interpolated to 2 metres [K] + real :: qair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Relative humidity interpolated to 2 metres[kg/kg] + real :: swdown(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Downward shortwave flux at the ground [W/m^2] + real :: lwdown(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Downward longwave radiation at the ground [W/m^2] + real :: uwind(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous zonal wind interpolated to 10 metres [m/s] + real :: vwind(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous meridional wind interpolated to 10 metres[m/s] + real :: ps(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous Surface Pressure [Pa] + real :: prectot(LIS_rc%lnc(n),LIS_rc%lnr(n)) ! Total precipitation [kg/m^2] + + integer, intent(out) :: rc + + ! Initialize return code to "no error". We will change it below if + ! necessary. + rc = 0 + +#if (defined USE_GRIBAPI) + + call grib_open_file(ftn,trim(gribfile),'r',ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] Failed to open - '//trim(gribfile) + call LIS_endrun() + end if + + ! Read in the first grib record, unpack the header and extract + ! section 1 and section 2 information. + call grib_new_from_file(ftn,igrib,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] failed to read - '//trim(gribfile) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'centre',center,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grib_get: ' // & + 'centre in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'gridType',gtype,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: ' // & + 'gridtype in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + if(trim(gtype).ne."regular_ll") then + write(LIS_logunit,*)'[ERR] MOGREPS-G file not on lat/lon grid!' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'Ni',iginfo(1),ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: Ni read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'Nj',iginfo(2),ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: Nj in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'jDirectionIncrementInDegrees',gridres_dlat,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: ' // & + 'jDirectionIncrementInDegrees ' // & + 'in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + ! EMK...Added dlon + call grib_get(igrib, 'iDirectionIncrementInDegrees', gridres_dlon, ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: ' // & + 'iDirectionIncrementInDegrees ' // & + 'in read_mogrepsg' + call grib_release(igrib, ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'dataDate',dataDate,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: ' // & + 'dataDate in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + call grib_get(igrib,'dataTime',dataTime,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[ERR] in grid_get: ' // & + 'dataTime in read_mogrepsg' + call grib_release(igrib,ierr) + call grib_close_file(ftn) + call LIS_endrun() + endif + + ! Here we tentatively have a file we can use. Close it for now, and + ! prepare to pull the appropriate variables. + call grib_release(igrib,ierr) + call grib_close_file(ftn) + + ifguess = iginfo(1) + jfguess = iginfo(2) + + call fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, & + tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) + + call assign_processed_mogrepsgforc(n, m, order, 1, tair) + call assign_processed_mogrepsgforc(n, m, order, 2, qair) + call assign_processed_mogrepsgforc(n, m, order, 3, swdown) + call assign_processed_mogrepsgforc(n, m, order, 4, lwdown) + call assign_processed_mogrepsgforc(n, m, order, 5, uwind) + call assign_processed_mogrepsgforc(n, m, order, 6, vwind) + call assign_processed_mogrepsgforc(n, m, order, 7, ps) + call assign_processed_mogrepsgforc(n, m, order, 8, prectot) + +#endif + +end subroutine read_mogrepsg + +subroutine fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, & + tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) + +! !USES: + use LIS_coreMod, only : LIS_rc + use LIS_logMod, only : LIS_logunit, LIS_abort, LIS_alert, LIS_verify + +#if (defined USE_GRIBAPI) + use grib_api +#endif + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex ! Forcing index + integer, intent(in) :: order + character(len=*), intent(in) :: gribfile + integer, intent(in) :: ifguess + integer, intent(in) :: jfguess + real, intent(out) :: tair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Temperature interpolated to 2 metres [K] + real, intent(out) :: qair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Relative humidity interpolated to 2 metres[kg/kg] + real, intent(out) :: swdown(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Downward shortwave flux at the ground [W/m^2] + real, intent(out) :: lwdown(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Downward longwave radiation at the ground [W/m^2] + real, intent(out) :: uwind(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous zonal wind interpolated to 10 metres [m/s] + real, intent(out) :: vwind(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous meridional wind interpolated to 10 metres[m/s] + real, intent(out) :: ps(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous Surface Pressure [Pa] + real, intent(out) :: prectot(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Total precipitation [kg/m^2] + + integer, intent(out) :: rc +! +! !DESCRIPTION: +! +! To read MOGREPS-G data in GRIB-2 format. +! +!EOP + character*9 :: cstat + character*255 :: message ( 20 ) + character(len=7) :: grib_msg + character(len=7) :: check_mogrepsg_message + integer :: count_tair, count_qair + integer :: count_swdown, count_lwdown + integer :: count_uwind, count_vwind + integer :: count_ps, count_prectot + integer :: ierr + integer :: istat1 + integer :: igrib + integer :: ftn + integer :: kk, nvars + integer :: param_disc_val, param_cat_val, & + param_num_val, surface_val, level_val + real, allocatable :: dum1d ( : ) + real, allocatable :: dumv1d ( : ) ! v-wind + + real, allocatable :: fg_tair ( : , : ) + real, allocatable :: fg_qair ( : , : ) + real, allocatable :: fg_swdown ( : , : ) + real, allocatable :: fg_lwdown ( : , : ) + real, allocatable :: fg_uwind ( : , : ) + real, allocatable :: fg_vwind ( : , : ) + real, allocatable :: fg_ps ( : , : ) + real, allocatable :: fg_prectot ( : , : ) + + logical :: found_inq + + rc = 1 ! Initialize as "no error" + + ! EMK...Before using ECCODES/GRIB_API, see if the GRIB file exists + ! using a simple inquire statement. This avoids ECCODES/GRIB_API + ! writing error messages to stdout/stderr, which may lead to runtime + ! problems. + inquire(file=trim(gribfile),exist=found_inq) + if (.not. found_inq) then + write(LIS_logunit,*) '[WARN] Cannot find file '//trim(gribfile) + rc = 0 + return + end if + +#if (defined USE_GRIBAPI) + + ! If a problem occurs here, we can just return immediately since no + ! memory has been allocated yet. + call grib_open_file(ftn,trim(gribfile),'r',ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[WARN] Failed to open - '//trim(gribfile) + rc = 0 + return + end if + + allocate ( fg_tair (ifguess, jfguess) ) + allocate ( fg_qair (ifguess, jfguess) ) + allocate ( fg_swdown (ifguess, jfguess) ) + allocate ( fg_lwdown (ifguess, jfguess) ) + allocate ( fg_uwind (ifguess, jfguess) ) ! nr=960 + allocate ( fg_vwind (ifguess, jfguess+1) ) ! v-wind, nr=961 + allocate ( fg_ps (ifguess, jfguess) ) + allocate ( fg_prectot (ifguess, jfguess) ) + + allocate ( dum1d (ifguess*jfguess) ) + allocate ( dumv1d (ifguess*(jfguess+1)) ) ! v-wind + + ! Initalization + fg_tair = LIS_rc%udef + fg_qair = LIS_rc%udef + fg_swdown = LIS_rc%udef + fg_lwdown = LIS_rc%udef + fg_uwind = LIS_rc%udef + fg_vwind = LIS_rc%udef + fg_ps = LIS_rc%udef + fg_prectot = LIS_rc%udef + dum1d = LIS_rc%udef + + tair = LIS_rc%udef + qair = LIS_rc%udef + swdown = LIS_rc%udef + lwdown = LIS_rc%udef + uwind = LIS_rc%udef + vwind = LIS_rc%udef + ps = LIS_rc%udef + prectot = LIS_rc%udef + + ! From this point, we must deallocate memory before returning. + ! Unfortunately this means using a GOTO statement if a problem is + ! encountered, but such is life. + count_tair = 0 + count_qair = 0 + count_swdown = 0 + count_lwdown = 0 + count_uwind = 0 + count_vwind = 0 + count_ps = 0 + count_prectot = 0 + + call grib_count_in_file(ftn,nvars,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[WARN] in grib_count_in_file in ' // & + 'fldbld_read_mogrepsg' + goto 100 + end if + + ! Tentatively loop through every field in GRIB file looking for the variables + ! we want. The code below will exit the loop early if a problem is found *or* + ! once all the required variables are found and read in. + do kk=1,nvars + + call grib_new_from_file(ftn,igrib,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[WARN] failed to read - '//trim(gribfile) + goto 100 + end if + + call grib_get(igrib,'discipline',param_disc_val,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) '[WARN] in grib_get: parameterNumber in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + call grib_get(igrib,'parameterCategory',param_cat_val,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) & + '[WARN] in grib_get: parameterCategory in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + call grib_get(igrib,'parameterNumber',param_num_val,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) & + '[WARN] in grib_get: parameterNumber in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + call grib_get(igrib,'typeOfFirstFixedSurface',surface_val,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) & + '[WARN] in grib_get: level in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + call grib_get(igrib,'level',level_val,ierr) + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) & + '[WARN] in grib_get: level in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + ! We have enough information to determine what GRIB parameter this is. + grib_msg = check_mogrepsg_message(param_disc_val, & + param_cat_val, param_num_val, surface_val, level_val) + + ! Skip this field if GRIB parameter is not required. + if (grib_msg == 'none') then + call grib_release(igrib,ierr) + if (ierr .ne. 0) then + write(LIS_logunit,*)'[WARN], in grib_release: in ' //& + 'fldbld_read_mogrepsg' + goto 100 + end if + cycle ! Not a message we are interested in. + end if + + if (grib_msg == 'v10') then + call grib_get(igrib,'values',dumv1d,ierr) + else + call grib_get(igrib,'values',dum1d,ierr) + endif + + if ( ierr .ne. 0 ) then + write(LIS_logunit,*) & + '[WARN] in grib_get: values for '//grib_msg// ' in ' // & + 'fldbld_read_mogrepsg' + call grib_release(igrib,ierr) + goto 100 + end if + + select case (grib_msg) + case('t2') ! 2-m temperature + fg_tair = reshape(dum1d, (/ifguess,jfguess/)) + count_tair = count_tair + 1 + case ('q2') ! 2-m relative humidity + fg_qair = reshape(dum1d, (/ifguess,jfguess/)) + count_qair = count_qair + 1 + case ('swdown') ! downward shortwave + fg_swdown = reshape(dum1d, (/ifguess,jfguess/)) + count_swdown = count_swdown + 1 + case ('lwdown') ! downward longwave radiation + fg_lwdown = reshape(dum1d, (/ifguess,jfguess/)) + count_lwdown = count_lwdown + 1 + case ('u10') ! 10m u-wind + fg_uwind = reshape(dum1d, (/ifguess,jfguess/)) + count_uwind = count_uwind + 1 + case('v10') ! 10m v-wind + fg_vwind = reshape(dumv1d, (/ifguess,jfguess+1/)) + count_vwind = count_vwind + 1 + case('ps') ! surface pressure + fg_ps = reshape(dum1d, (/ifguess,jfguess/)) + count_ps = count_ps + 1 + case('prectot') ! accumulated total precipitation + fg_prectot = reshape(dum1d, (/ifguess,jfguess/)) + count_prectot = count_prectot + 1 + + case default ! Internal error, we shouldn't be here + write(LIS_logunit,*)'[WARN] Unknown grib_message ',grib_msg + write(LIS_logunit,*)'Aborting...' + flush(LIS_logunit) + write(cstat,'(i9)',iostat=istat1) ierr + message(1) = 'Program: LIS' + message(2) = ' Subroutine: fldbld_read_mogrepsg.' + message(3) = ' Error reading first guess file:' + message(4) = ' ' // trim(gribfile) + if( istat1 .eq. 0 )then + message(5) = ' Status = ' // trim(cstat) + endif + call LIS_abort( message) + end select + + ! Finished with this field + call grib_release(igrib,ierr) + if (ierr .ne. 0) then + write(LIS_logunit,*)'[WARN], in grib_release: in ' //& + 'fldbld_read_mogrepsg' + goto 100 + end if + + ! Jump out of loop early if we have everything + if ( (count_tair .eq. 1) .and. (count_qair .eq. 1) .and. & + (count_swdown .eq. 1 ) .and. (count_lwdown .eq. 1) .and. & + (count_uwind .eq. 1) .and. (count_vwind .eq. 1) .and. & + (count_ps .eq. 1) .and. (count_prectot .eq. 1)) then + exit + end if + enddo ! Loop through all GRIB file fields + + ! Interpolate the fields to the LIS grid + ! tair + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_tair, tair) + ! qair + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_qair, qair) + ! swdown + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_swdown, swdown) + ! lwdown + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_lwdown, lwdown) + ! uwind + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_uwind, uwind) + ! vwind + call interp_mogrepsg_vwind(n, findex, ifguess, jfguess+1, .false., fg_vwind, vwind) + ! ps + call interp_mogrepsg(n, findex, ifguess, jfguess, .false., fg_ps, ps) + ! prectot + call interp_mogrepsg(n, findex, ifguess, jfguess, .true., fg_prectot, prectot) + + ! At this point, we have everything. Close the file and return. + call grib_close_file(ftn) + rc = 1 + return + + ! Jump down here to clean up memory before returning after finding a + ! problem. + 100 continue + call grib_close_file(ftn) + + deallocate ( dum1d ) + deallocate ( dumv1d ) + deallocate ( fg_tair ) + deallocate ( fg_qair ) + deallocate ( fg_swdown ) + deallocate ( fg_lwdown ) + deallocate ( fg_uwind ) + deallocate ( fg_vwind ) + deallocate ( fg_ps ) + deallocate ( fg_prectot ) + + rc = 0 +#endif + +end subroutine fldbld_read_mogrepsg + +function check_mogrepsg_message(param_disc_val, & + param_cat_val, param_num_val, surface_val, level_val) +! !USES: +! none + + implicit none +! !ARGUMENTS: + integer, intent(in) :: param_disc_val, param_cat_val, & + param_num_val, surface_val, level_val + character(len=7) :: check_mogrepsg_message +!EOP + + if ( param_disc_val == 0 .and. & + param_cat_val == 0 .and. & + param_num_val == 0 .and. & + surface_val == 103 )then + check_mogrepsg_message = 't2' ! Temperature interpolated to 2 metres [K] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 1 .and. & + param_num_val == 0 .and. & + surface_val == 103 ) then + check_mogrepsg_message = 'q2' ! Specific humidity interpolated to 2 metres [kg/kg] + elseif ( param_disc_val == 255 .and. & + param_cat_val == 255 .and. & + param_num_val == 255 .and. & + surface_val == 1 ) then + check_mogrepsg_message = 'swdown' ! Downward shortwave flux at the ground [W/m^2] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 5 .and. & + param_num_val == 3 .and. & + surface_val == 1 ) then + check_mogrepsg_message = 'lwdown' ! Downward longwave radiation at the ground [W/m^2] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 2 .and. & + param_num_val == 2 .and. & + surface_val == 103 .and. & + level_val == 10) then + check_mogrepsg_message = 'u10' ! Instantaneous zonal wind interpolated to 10 metres [m/s] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 2 .and. & + param_num_val == 3 .and. & + surface_val == 103 .and. & + level_val == 10) then + check_mogrepsg_message = 'v10' ! Instantaneous meridional wind interpolated to 10 metres[m/s] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 3 .and. & + param_num_val == 1 ) then + check_mogrepsg_message = 'ps' ! Instantaneous Surface Pressure [Pa] + elseif ( param_disc_val == 0 .and. & + param_cat_val == 1 .and. & + param_num_val == 49 .and. & + surface_val == 1 ) then + check_mogrepsg_message = 'prectot' ! Total precipitation [kg/m2] + else + check_mogrepsg_message = 'none' + endif +end function check_mogrepsg_message + +subroutine interp_mogrepsg(n, findex, ifguess, jfguess, pcp_flag, input, output) + +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_logMod, only : LIS_logunit, LIS_endrun + use mogrepsg_forcingMod, only : mogrepsg_struc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex + integer, intent(in) :: ifguess + integer, intent(in) :: jfguess + logical, intent(in) :: pcp_flag + real, intent(in) :: input ( ifguess,jfguess ) + real, intent(out) :: output ( LIS_rc%lnc(n),LIS_rc%lnr(n) ) +! +! !DESCRIPTION: +! +! This routine interpolates the MOGREPS-G data to the LIS grid. + +!EOP + + integer :: mi, mo + integer :: k + integer :: i,j + integer :: iret + integer :: midway + character(len=50) :: method + real, allocatable, dimension(:,:) :: var + logical*1, allocatable, dimension(:) :: lb + logical*1, allocatable, dimension(:) :: lo + + allocate(var(ifguess,jfguess)) + allocate(lb(ifguess*jfguess)) + allocate(lo(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + mi = ifguess * jfguess + mo = LIS_rc%lnc(n)*LIS_rc%lnr(n) + lb = .true. + lo = .true. + output = LIS_rc%udef + + ! translate from (0,360) to (-180,180). + midway = ifguess/2 + do j = 1, jfguess + do i = 1, ifguess + if ( (i+midway) < ifguess ) then + var(i,j) = input((i+midway),j) + else + var(i,j) = input((i-midway+1),j) + endif + enddo + enddo + + ! Interpolate to LIS grid + select case( LIS_rc%met_interp(findex) ) + + case( "bilinear" ) + call bilinear_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat,LIS_domain(n)%lon, & + mogrepsg_struc(n)%w111,mogrepsg_struc(n)%w121, & + mogrepsg_struc(n)%w211,mogrepsg_struc(n)%w221, & + mogrepsg_struc(n)%n111,mogrepsg_struc(n)%n121, & + mogrepsg_struc(n)%n211,mogrepsg_struc(n)%n221,LIS_rc%udef,iret) + + case( "budget-bilinear" ) + if (pcp_flag) then + call conserv_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%w112,mogrepsg_struc(n)%w122, & + mogrepsg_struc(n)%w212,mogrepsg_struc(n)%w222, & + mogrepsg_struc(n)%n112,mogrepsg_struc(n)%n122, & + mogrepsg_struc(n)%n212,mogrepsg_struc(n)%n222,LIS_rc%udef,iret) + else + call bilinear_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%w111,mogrepsg_struc(n)%w121, & + mogrepsg_struc(n)%w211,mogrepsg_struc(n)%w221, & + mogrepsg_struc(n)%n111,mogrepsg_struc(n)%n121, & + mogrepsg_struc(n)%n211,mogrepsg_struc(n)%n221,LIS_rc%udef,iret) + endif + + case( "neighbor" ) + call neighbor_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%n113,LIS_rc%udef,iret) + + case DEFAULT + write(LIS_logunit,*) 'ERR: Unexpected interpolation method' + write(LIS_logunit,*) ' in interp_mogrepsg_first_guess' + write(LIS_logunit,*) ' ', trim(LIS_rc%met_interp(findex)) + call LIS_endrun() + end select + + deallocate(var) + deallocate(lb) + deallocate(lo) + +end subroutine interp_mogrepsg + +subroutine interp_mogrepsg_vwind(n, findex, ifguess, jfguess, pcp_flag, input, output) + +! !USES: + use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_logMod, only : LIS_logunit, LIS_endrun + use mogrepsg_forcingMod, only : mogrepsg_struc + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex + integer, intent(in) :: ifguess + integer, intent(in) :: jfguess + logical, intent(in) :: pcp_flag + real, intent(in) :: input ( ifguess,jfguess ) + real, intent(out) :: output ( LIS_rc%lnc(n),LIS_rc%lnr(n) ) +! +! !DESCRIPTION: +! +! This routine interpolates the MOGREPS-G data to the LIS grid. + +!EOP + + integer :: mi, mo + integer :: k + integer :: i,j + integer :: iret + integer :: midway + character(len=50) :: method + real, allocatable, dimension(:,:) :: var + logical*1, allocatable, dimension(:) :: lb + logical*1, allocatable, dimension(:) :: lo + + allocate(var(ifguess,jfguess)) + allocate(lb(ifguess*jfguess)) + allocate(lo(LIS_rc%lnc(n)*LIS_rc%lnr(n))) + + mi = ifguess * jfguess + mo = LIS_rc%lnc(n)*LIS_rc%lnr(n) + lb = .true. + lo = .true. + output = LIS_rc%udef + + ! translate from (0,360) to (-180,180). + midway = ifguess/2 + do j = 1, jfguess + do i = 1, ifguess + if ( (i+midway) < ifguess ) then + var(i,j) = input((i+midway),j) + else + var(i,j) = input((i-midway+1),j) + endif + enddo + enddo + + ! Interpolate to LIS grid + select case( LIS_rc%met_interp(findex) ) + + case( "bilinear" ) + call bilinear_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat,LIS_domain(n)%lon, & + mogrepsg_struc(n)%wv111,mogrepsg_struc(n)%wv121, & + mogrepsg_struc(n)%wv211,mogrepsg_struc(n)%wv221, & + mogrepsg_struc(n)%nv111,mogrepsg_struc(n)%nv121, & + mogrepsg_struc(n)%nv211,mogrepsg_struc(n)%nv221,LIS_rc%udef,iret) + + case( "budget-bilinear" ) + if (pcp_flag) then + call conserv_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%wv112,mogrepsg_struc(n)%wv122, & + mogrepsg_struc(n)%wv212,mogrepsg_struc(n)%wv222, & + mogrepsg_struc(n)%nv112,mogrepsg_struc(n)%nv122, & + mogrepsg_struc(n)%nv212,mogrepsg_struc(n)%nv222,LIS_rc%udef,iret) + else + call bilinear_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%wv111,mogrepsg_struc(n)%wv121, & + mogrepsg_struc(n)%wv211,mogrepsg_struc(n)%wv221, & + mogrepsg_struc(n)%nv111,mogrepsg_struc(n)%nv121, & + mogrepsg_struc(n)%nv211,mogrepsg_struc(n)%nv221,LIS_rc%udef,iret) + endif + + case( "neighbor" ) + call neighbor_interp(LIS_rc%gridDesc(n,:),lb, & + var,lo,output,mi,mo, & + LIS_domain(n)%lat, LIS_domain(n)%lon, & + mogrepsg_struc(n)%nv113,LIS_rc%udef,iret) + + case DEFAULT + write(LIS_logunit,*) 'ERR: Unexpected interpolation method' + write(LIS_logunit,*) ' in interp_mogrepsg_first_guess' + write(LIS_logunit,*) ' ', trim(LIS_rc%met_interp(findex)) + call LIS_endrun() + end select + + deallocate(var) + deallocate(lb) + deallocate(lo) + +end subroutine interp_mogrepsg_vwind + +!BOP +! +! !ROUTINE: assign_processed_mogrepsgforc +! \label{assign_processed_mogrepsgforc} +! +! !INTERFACE: +subroutine assign_processed_mogrepsgforc(n,m,order,var_index,mogrepsgforc) +! !USES: + use LIS_coreMod + use mogrepsg_forcingMod, only : mogrepsg_struc +! +! !DESCRIPTION: +! This routine assigns the interpolated MOGREPS-G forcing data +! to the module data structures to be used later for +! time interpolation +! +!EOP + implicit none + + integer, intent(in) :: n + integer, intent(in) :: m + integer, intent(in) :: order + integer, intent(in) :: var_index + real, intent(in) :: mogrepsgforc(LIS_rc%lnc(n),LIS_rc%lnr(n)) + + integer :: c,r + + do r=1,LIS_rc%lnr(n) + do c=1,LIS_rc%lnc(n) + if(LIS_domain(n)%gindex(c,r).ne.-1) then + if(order.eq.1) then + mogrepsg_struc(n)%metdata1(var_index,m,& + LIS_domain(n)%gindex(c,r)) = & + mogrepsgforc(c,r) + elseif(order.eq.2) then + mogrepsg_struc(n)%metdata2(var_index,m,& + LIS_domain(n)%gindex(c,r)) = & + mogrepsgforc(c,r) + endif + endif + enddo + enddo +end subroutine assign_processed_mogrepsgforc diff --git a/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 new file mode 100644 index 000000000..07777f8f6 --- /dev/null +++ b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 @@ -0,0 +1,62 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +!BOP +! +! !ROUTINE: readcrd_mogrepsg +! \label{readcrd_mogrepsg} +! +! !REVISION HISTORY: +! 26 Jan 2023; Yeosang Yoon, Initial Code +! +! !INTERFACE: +subroutine readcrd_mogrepsg() +! !USES: + use LIS_logMod + use LIS_coreMod + use mogrepsg_forcingMod, only : mogrepsg_struc + use ESMF +! +! !DESCRIPTION: +! +! This routine reads the options specific to MOGREPS-G forecast forcing from +! the LIS configuration file. +! +!EOP + + implicit none + + integer :: n,rc + + call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast forcing directory:",rc=rc) + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%odir,rc=rc) + call LIS_verify(rc,'MOGREPS-G forecast forcing directory: not defined') + enddo + + call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast run mode:",rc=rc) + call LIS_verify(rc, 'MOGREPS-G forecast run mode: not defined ') + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%runmode,rc=rc) + enddo + + call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast number of ensemble members:",rc=rc) + call LIS_verify(rc, 'MOGREPS-G forecast number of ensemble members: not defined') + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%max_ens_members,rc=rc) + enddo + + do n=1,LIS_rc%nnest + write(LIS_logunit,*) '[INFO] Using MOGREPS-G forecast forcing' + write(LIS_logunit,*) '[INFO] MOGREPS-G forecast forcing directory: ', trim(mogrepsg_struc(n)%odir) + write(LIS_logunit,*) '[INFO] MOGREPS-G forecast run mode: ',mogrepsg_struc(n)%runmode + write(LIS_logunit,*) '[INFO] MOGREPS-G forecast number of ensemble members:',& + mogrepsg_struc(n)%max_ens_members + enddo +end subroutine readcrd_mogrepsg diff --git a/lis/metforcing/mogreps_g/reset_mogrepsg.F90 b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 new file mode 100644 index 000000000..e7db3ba4e --- /dev/null +++ b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 @@ -0,0 +1,38 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! !MODULE: reset_mogrepsg +! \label{reset_mogrepsg} +! +! !REVISION HISTORY: +! 26 Jan 2023; Yeosang Yoon, Initial Code +! +! !INTERFACE: +subroutine reset_mogrepsg() +! !USES: + use LIS_coreMod, only : LIS_rc + use mogrepsg_forcingMod, only : mogrepsg_struc +! +! !DESCRIPTION: +! Routine to reset GALWEM-GE forcing related memory allocations. +! +!EOP + implicit none + + integer :: n + integer :: findex + + do n=1,LIS_rc%nnest + mogrepsg_struc(n)%fcsttime1 = 3000.0 + mogrepsg_struc(n)%fcsttime2 = 0.0 + enddo + +end subroutine reset_mogrepsg diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 new file mode 100644 index 000000000..7ad237b80 --- /dev/null +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -0,0 +1,301 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! !ROUTINE: timeinterp_mogrepsg +! \label{timeinterp_mogrepsg} +! +! !REVISION HISTORY: +! +! 26 Jan 2023: Yeosang Yoon, Initial specification +! +! !INTERFACE: +subroutine timeinterp_mogrepsg(n,findex) +! !USES: + use ESMF + use LIS_coreMod + use LIS_constantsMod + use LIS_metforcingMod + use LIS_FORC_AttributesMod + use LIS_timeMgrMod + use LIS_logMod + use mogrepsg_forcingMod + use LIS_forecastMod + + implicit none +! !ARGUMENTS: + integer, intent(in) :: n + integer, intent(in) :: findex +! +! !DESCRIPTION: +! Temporally interpolates the forcing data to the current model +! timestep. Downward shortwave radiation is interpolated using a +! zenith-angled based approach. Precipitation and longwave radiation +! are not temporally interpolated, and the previous 3 hourly value +! is used. All other variables are linearly interpolated between +! the 3 hourly blocks. +! +! The routines invoked are: +! \begin{description} +! \item[LIS\_time2date](\ref{LIS_time2date}) \newline +! converts the time to a date format +! \item[LIS\_tick](\ref{LIS_tick}) \newline +! advances or retracts time by the specified amount +! \item[zterp](\ref{zterp}) \newline +! zenith-angle based interpolation +! \end{description} +!EOP + integer :: zdoy + real :: zw1, zw2 + real :: czm, cze, czb + real :: wt1, wt2, swt1, swt2 + real :: gmt1, gmt2 + integer :: t,index1 + integer :: bdoy,byr,bmo,bda,bhr,bmn + real*8 :: btime,newtime1,newtime2 + real :: tempgmt1,tempgmt2,tempbts + integer :: tempbdoy,tempbyr,tempbmo,tempbda,tempbhr,tempbmn,tempbss + integer :: status + type(ESMF_Field) :: tmpField,q2Field,uField,vField,swdField,lwdField + type(ESMF_Field) :: psurfField,pcpField + real,pointer :: tmp(:),q2(:),uwind(:),vwind(:) + real,pointer :: swd(:),lwd(:),psurf(:),pcp(:) + real :: pcp_tmp + integer :: mfactor, m, k, tid, fcsthr_intv +! ________________________________________ + + btime=mogrepsg_struc(n)%fcsttime1 + call LIS_time2date(btime,bdoy,gmt1,byr,bmo,bda,bhr,bmn) + + tempbdoy=bdoy + tempgmt1=gmt1 + tempbyr=byr + tempbmo=bmo + tempbda=bda + tempbhr=bhr + if (tempbhr.eq.24) tempbhr=0 + tempbmn=bmn + tempbss=0 + tempbts=0 + call LIS_tick(newtime1,tempbdoy,tempgmt1,& + tempbyr,tempbmo,tempbda,tempbhr,tempbmn, & + tempbss,tempbts) + + btime=mogrepsg_struc(n)%fcsttime2 + call LIS_time2date(btime,bdoy,gmt2,byr,bmo,bda,bhr,bmn) + + tempbdoy=bdoy + tempgmt2=gmt2 + tempbyr=byr + tempbmo=bmo + tempbda=bda + tempbhr=bhr + if (tempbhr.eq.24) tempbhr=0 + tempbmn=bmn + tempbss=0 + tempbts=0 + call LIS_tick(newtime2,tempbdoy,tempgmt2,& + tempbyr,tempbmo,tempbda,tempbhr,tempbmn,& + tempbss,tempbts) + + !Interpolate Data in Time + wt1=(mogrepsg_struc(n)%fcsttime2-LIS_rc%time)/ & + (mogrepsg_struc(n)%fcsttime2-mogrepsg_struc(n)%fcsttime1) + wt2=1.0-wt1 + swt1=(newtime2-LIS_rc%time)/(newtime2-newtime1) + swt2=1.0-swt1 + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Tair%varname(1),tmpField,& + rc=status) + call LIS_verify(status, 'Error: Enable Tair in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Qair%varname(1),q2Field,& + rc=status) + call LIS_verify(status, 'Error: Enable Qair in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_SWdown%varname(1),swdField,& + rc=status) + call LIS_verify(status, 'Error: Enable SWdown in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_LWdown%varname(1),lwdField,& + rc=status) + call LIS_verify(status, 'Error: Enable LWdown in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Wind_E%varname(1),uField,& + rc=status) + call LIS_verify(status, 'Error: Enable Wind_E in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Wind_N%varname(1),vField,& + rc=status) + call LIS_verify(status, 'Error: Enable Wind_N in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Psurf%varname(1),psurfField,& + rc=status) + call LIS_verify(status, 'Error: Enable Psurf in the forcing variables list') + + call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Rainf%varname(1),pcpField,& + rc=status) + call LIS_verify(status, 'Error: Enable Rainf in the forcing variables list') + + + call ESMF_FieldGet(tmpField,localDE=0,farrayPtr=tmp,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(q2Field,localDE=0,farrayPtr=q2,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(swdField,localDE=0,farrayPtr=swd,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(lwdField,localDE=0,farrayPtr=lwd,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(uField,localDE=0,farrayPtr=uwind,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(vField,localDE=0,farrayPtr=vwind,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(psurfField,localDE=0,farrayPtr=psurf,rc=status) + call LIS_verify(status) + + call ESMF_FieldGet(pcpField,localDE=0,farrayPtr=pcp,rc=status) + call LIS_verify(status) + + ! Metforcing ensemble member count factor + mfactor = LIS_rc%nensem(n)/mogrepsg_struc(n)%max_ens_members + + ! Downward shortwave radiation (average): + do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) + do m=1,mogrepsg_struc(n)%max_ens_members + do k=1,mfactor + tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + index1 = LIS_domain(n)%tile(tid)%index + zdoy=LIS_rc%doy + + ! Compute and apply zenith angle weights + call zterp(1,LIS_domain(n)%grid(index1)%lat,& + LIS_domain(n)%grid(index1)%lon,& + gmt1,gmt2,LIS_rc%gmt,zdoy,zw1,zw2,czb,cze,czm,LIS_rc) + + if(mogrepsg_struc(n)%metdata1(3,m,index1).ne.LIS_rc%udef.and.& + mogrepsg_struc(n)%metdata2(3,m,index1).ne.LIS_rc%udef) then + swd(tid) = mogrepsg_struc(n)%metdata1(3,m,index1)*zw1+& + mogrepsg_struc(n)%metdata2(3,m,index1)*zw2 + !swd(tid) = zw1 * mogrepsg_struc(n)%metdata2(3,m,index1) + + ! In cases of small cos(zenith) angles, use linear weighting to avoid overly large weights + if((swd(tid).gt.mogrepsg_struc(n)%metdata1(3,m,index1).and. & + swd(tid).gt.mogrepsg_struc(n)%metdata2(3,m,index1)).and. & + (czb.lt.0.1.or.cze.lt.0.1))then + swd(tid) = mogrepsg_struc(n)%metdata1(3,m,index1)*swt1+ & + mogrepsg_struc(n)%metdata2(3,m,index1)*swt2 + endif + + if (swd(t).gt.LIS_CONST_SOLAR) then + write(unit=LIS_logunit,fmt=*)'[WARN] sw radiation too high!!' + write(unit=LIS_logunit,fmt=*)'[WARN] it is',swd(t) + write(unit=LIS_logunit,fmt=*)'[WARN] mogrepsgdata1=',& + mogrepsg_struc(n)%metdata1(3,m,index1) + write(unit=LIS_logunit,fmt=*)'[WARN] mogrepsgdata2=',& + mogrepsg_struc(n)%metdata2(3,m,index1) + write(unit=LIS_logunit,fmt=*)'[WARN] zw1=',zw1,'zw2=',zw2 + swd(t) = LIS_CONST_SOLAR + write(unit=LIS_logunit,fmt=*)'[WARN] forcing set to ',swd(t) + endif + endif + + if ((swd(t).ne.LIS_rc%udef).and.(swd(t).lt.0)) then + if (swd(t).gt.-0.00001) then + swd(t) = 0.0 + else + write(LIS_logunit,*) '[ERR] timeinterp_mogrepsg -- Stopping because ', & + 'forcing not udef but lt 0,' + write(LIS_logunit,*)'[ERR] timeinterp_mogrepsg -- ', & + t,swd(t),mogrepsg_struc(n)%metdata2(3,m,index1), & + ' (',LIS_localPet,')' + call LIS_endrun + endif + endif + enddo + enddo + enddo + +!----------------------------------------------------------------------- +! precip variable Block Interpolation +!----------------------------------------------------------------------- + ! Total precipitation field (accumulated): + do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) + do m=1,mogrepsg_struc(n)%max_ens_members + do k=1,mfactor + tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + index1 = LIS_domain(n)%tile(tid)%index + + if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then + ! account for the accum fields + pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/(3600*3) + if(pcp(tid).lt.0) then + pcp(tid) = 0.0 + endif + endif + enddo + enddo + enddo + +!----------------------------------------------------------------------- +! Linearly interpolate everything else +!----------------------------------------------------------------------- + do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) + do m=1,mogrepsg_struc(n)%max_ens_members + do k=1,mfactor + tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + index1 = LIS_domain(n)%tile(tid)%index + + ! 2-meter air temp + if((mogrepsg_struc(n)%metdata1(1,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(1,m,index1).ne.LIS_rc%udef)) then + tmp(tid) = mogrepsg_struc(n)%metdata1(1,m,index1)*wt1 + & + mogrepsg_struc(n)%metdata2(1,m,index1)*wt2 + endif + ! Specific humidity + if((mogrepsg_struc(n)%metdata1(2,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(2,m,index1).ne.LIS_rc%udef)) then + q2(tid) = mogrepsg_struc(n)%metdata1(2,m,index1)*wt1 + & + mogrepsg_struc(n)%metdata2(2,m,index1)*wt2 + endif + ! Downward longwave field + if((mogrepsg_struc(n)%metdata1(4,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(4,m,index1).ne.LIS_rc%udef)) then + lwd(tid) = mogrepsg_struc(n)%metdata1(4,m,index1)*wt1 + & + mogrepsg_struc(n)%metdata2(4,m,index1)*wt2 + endif + ! U-wind component + if((mogrepsg_struc(n)%metdata1(5,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(5,m,index1).ne.LIS_rc%udef)) then + uwind(tid) = mogrepsg_struc(n)%metdata1(5,m,index1)*wt1+& + mogrepsg_struc(n)%metdata2(5,m,index1)*wt2 + endif + ! V-wind component + if((mogrepsg_struc(n)%metdata1(6,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(6,m,index1).ne.LIS_rc%udef)) then + vwind(tid) = mogrepsg_struc(n)%metdata1(6,m,index1)*wt1 + & + mogrepsg_struc(n)%metdata2(6,m,index1)*wt2 + endif + ! Surface pressure field + if((mogrepsg_struc(n)%metdata1(7,m,index1).ne.LIS_rc%udef).and.& + (mogrepsg_struc(n)%metdata2(7,m,index1).ne.LIS_rc%udef)) then + psurf(tid) = mogrepsg_struc(n)%metdata1(7,m,index1)*wt1 + & + mogrepsg_struc(n)%metdata2(7,m,index1)*wt2 + endif + enddo + enddo + enddo + +end subroutine timeinterp_mogrepsg diff --git a/lis/plugins/LIS_metforcing_pluginMod.F90 b/lis/plugins/LIS_metforcing_pluginMod.F90 index 0d2c148d3..1d8cc979f 100644 --- a/lis/plugins/LIS_metforcing_pluginMod.F90 +++ b/lis/plugins/LIS_metforcing_pluginMod.F90 @@ -304,6 +304,10 @@ subroutine LIS_metforcing_plugin use galwemge_forcingMod #endif +#if ( defined MF_MOGREPS_G_FORECAST ) + use mogrepsg_forcingMod +#endif + #if ( defined MF_MET_TEMPLATE ) external get_metForcTemplate external timeinterp_metForcTemplate @@ -656,7 +660,12 @@ subroutine LIS_metforcing_plugin external reset_galwemge #endif - +#if ( defined MF_MOGREPS_G_FORECAST ) + external get_mogrepsg + external timeinterp_mogrepsg + external finalize_mogrepsg + external reset_mogrepsg +#endif #if ( defined MF_MET_TEMPLATE ) ! - Meteorological Forcing Template: @@ -1181,6 +1190,15 @@ subroutine LIS_metforcing_plugin call registerresetmetforc(trim(LIS_galwemgeId)//char(0),reset_galwemge) #endif +#if ( defined MF_MOGREPS_G_FORECAST) + call registerinitmetforc(trim(LIS_mogrepsgId)//char(0),init_mogrepsg) + call registerretrievemetforc(trim(LIS_mogrepsgId)//char(0),get_mogrepsg) + call registertimeinterpmetforc(trim(LIS_mogrepsgId)//char(0), & + timeinterp_mogrepsg) + call registerfinalmetforc(trim(LIS_mogrepsgId)//char(0),finalize_mogrepsg) + call registerresetmetforc(trim(LIS_mogrepsgId)//char(0),reset_mogrepsg) +#endif + end subroutine LIS_metforcing_plugin end module LIS_metforcing_pluginMod diff --git a/lis/plugins/LIS_pluginIndices.F90 b/lis/plugins/LIS_pluginIndices.F90 index 78752007f..02ecddea7 100644 --- a/lis/plugins/LIS_pluginIndices.F90 +++ b/lis/plugins/LIS_pluginIndices.F90 @@ -175,6 +175,7 @@ module LIS_pluginIndices character*50, public, parameter :: LIS_gddpId = "GDDP" character*50, public, parameter :: LIS_galwemId = "GALWEM forecast" character*50, public, parameter :: LIS_galwemgeId = "GALWEM-GE forecast" + character*50, public, parameter :: LIS_mogrepsgId = "MOGREPS-G forecast" !------------------------------------------------------------------------- ! land surface parameters From 56e03c3440a24c4f794075032bc70fca7f72b38a Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Wed, 10 Jan 2024 09:59:27 -0500 Subject: [PATCH 273/328] update 'lis.config.adoc' --- lis/configs/lis.config.adoc | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 72d6cf6f0..140b254bb 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -6511,8 +6511,26 @@ of the GALWEM-GE forecast forcing data. GALWEM-GE forecast forcing directory: ./GALWEM_GE GALWEM-GE forecast run mode: forecast # forecast | analysis GALWEM-GE forecast number of ensemble members: 21 +.... + +[[sssec_mogrepsgforecast,MOGREPS-G forecast]] +==== MOGREPS-G Forecast +`MOGREPS-G forecast forcing directory:` specifies the location +of the MOGREPS-G forecast forcing files. + +`MOGREPS-G forecast run mode:` specifies the run mode related +to the MOGREPS-G dataset, which can either be forecast or analysis +run mode. Currently, only the forecast mode is supported. +`MOGREPS-G forecast number of ensemble members:` specifies the number of ensembles +of the MOGREPS-G forecast forcing data. + +.Example _lis.config_ entry +.... +MOGREPS-G forecast forcing directory: ./MOGREPS-G +MOGREPS-G forecast run mode: forecast # forecast | analysis +MOGREPS-G forecast number of ensemble members: 18 .... [[ssec_lsm,Land surface models]] From b41002b22a04a3eddc5996393ccc38f7b4517313 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 10 Jan 2024 13:55:52 -0500 Subject: [PATCH 274/328] Add copyright notice on LDT files for LISF 7.5.0 public release --- ldt/SMAP_E_OPL/DATADOMAIN.F90 | 9 +++++++++ ldt/SMAP_E_OPL/FUNCTIONS.F90 | 9 +++++++++ ldt/SMAP_E_OPL/TOOLSUBS.F90 | 9 +++++++++ ldt/SMAP_E_OPL/VARIABLES.F90 | 9 +++++++++ ldt/SMAP_E_OPL/algo_vpol_m.F90 | 9 +++++++++ ldt/SMAP_E_OPL/invdist_temp2smap.F90 | 9 +++++++++ ldt/SMAP_E_OPL/mironov.f90 | 9 +++++++++ ldt/SMAP_E_OPL/varsio_m.F90 | 9 +++++++++ 8 files changed, 72 insertions(+) diff --git a/ldt/SMAP_E_OPL/DATADOMAIN.F90 b/ldt/SMAP_E_OPL/DATADOMAIN.F90 index 3fb9e9a24..bd21fdc53 100644 --- a/ldt/SMAP_E_OPL/DATADOMAIN.F90 +++ b/ldt/SMAP_E_OPL/DATADOMAIN.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE DATADOMAIN USE VARIABLES IMPLICIT NONE diff --git a/ldt/SMAP_E_OPL/FUNCTIONS.F90 b/ldt/SMAP_E_OPL/FUNCTIONS.F90 index bd1e93708..c7ffbc8b1 100644 --- a/ldt/SMAP_E_OPL/FUNCTIONS.F90 +++ b/ldt/SMAP_E_OPL/FUNCTIONS.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE FUNCTIONS CONTAINS diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 2a31460f8..ef34d2326 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- !=============================i========================================== ! MODULE, TOOLSUBS P.W.LIU, 09/12/18 ! Contains subroutines that are necessry for downscaling program diff --git a/ldt/SMAP_E_OPL/VARIABLES.F90 b/ldt/SMAP_E_OPL/VARIABLES.F90 index 0238e13a7..2058361b7 100644 --- a/ldt/SMAP_E_OPL/VARIABLES.F90 +++ b/ldt/SMAP_E_OPL/VARIABLES.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE VARIABLES IMPLICIT NONE diff --git a/ldt/SMAP_E_OPL/algo_vpol_m.F90 b/ldt/SMAP_E_OPL/algo_vpol_m.F90 index 6f28f96e6..106cd690e 100644 --- a/ldt/SMAP_E_OPL/algo_vpol_m.F90 +++ b/ldt/SMAP_E_OPL/algo_vpol_m.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE algo_vpol_m IMPLICIT NONE diff --git a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 index b7283fd46..6758abe03 100644 --- a/ldt/SMAP_E_OPL/invdist_temp2smap.F90 +++ b/ldt/SMAP_E_OPL/invdist_temp2smap.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- !======================================================================= ! MODULE, invdist_temp2smap P.W.LIU, 01/11/2022 ! SUBROUTINE TO RESAMPLE SOIL TEMPERATURE FROM NOAH 39 ON ARFS GRID TO diff --git a/ldt/SMAP_E_OPL/mironov.f90 b/ldt/SMAP_E_OPL/mironov.f90 index bfbe86885..fd116441f 100644 --- a/ldt/SMAP_E_OPL/mironov.f90 +++ b/ldt/SMAP_E_OPL/mironov.f90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE mironov_m IMPLICIT NONE diff --git a/ldt/SMAP_E_OPL/varsio_m.F90 b/ldt/SMAP_E_OPL/varsio_m.F90 index c22333e45..39c1de103 100644 --- a/ldt/SMAP_E_OPL/varsio_m.F90 +++ b/ldt/SMAP_E_OPL/varsio_m.F90 @@ -1,3 +1,12 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.5 +! +! Copyright (c) 2024 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- MODULE varsio_m IMPLICIT NONE REAL*8, PARAMETER :: RE_KM = 6371.228, PI = acos(-1.0), d2r = PI/180.0 From 35632e80256bcdb36ae494f7da64ecd7f9ba9af4 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 10 Jan 2024 15:12:01 -0500 Subject: [PATCH 275/328] Update LDT Users Guide for LISF 7.5.0 public release --- docs/LDT_users_guide/LDT_users_guide.adoc | 18 +++++++++--------- docs/LDT_users_guide/build.adoc | 6 +++++- docs/LDT_users_guide/intro.adoc | 16 +++++++++++++++- docs/LDT_users_guide/revision_table.adoc | 1 + docs/LIS_users_guide/LIS_users_guide.adoc | 8 ++++---- 5 files changed, 34 insertions(+), 15 deletions(-) diff --git a/docs/LDT_users_guide/LDT_users_guide.adoc b/docs/LDT_users_guide/LDT_users_guide.adoc index 141b1a403..4352114ed 100644 --- a/docs/LDT_users_guide/LDT_users_guide.adoc +++ b/docs/LDT_users_guide/LDT_users_guide.adoc @@ -1,6 +1,6 @@ -= Land Data Toolkit (LDT): LDT {lisfrevision} Users`' Guide -:revnumber: 2.4 -:revdate: 03 Oct 2023 += Land Data Toolkit (LDT): LDT {lisfrevision} Users Guide +:revnumber: 3.0 +:revdate: 10 Jan 2024 :doctype: book :sectnums: :toc: @@ -10,23 +10,23 @@ :stem: latexmath :data-uri: :devonly: -:lisfrevision: 7.4 +:lisfrevision: 7.5 :lisfurl: https://lis.gsfc.nasa.gov :nasalisf: https://github.com/NASA-LIS/LISF :githuburl: https://github.com :nasalisfpages: https://nasa-lis.github.io/LISF/ :apachelicense: https://www.apache.org/licenses/LICENSE-2.0 -:ldttarball: LISF_public_release_7.4.0.tar.gz +:ldttarball: LISF_public_release_7.5.0.tar.gz :emdash: — :endash: – :vertellipsis: ⋮ -// Set :devonly: when compiling the developers' version of the Users' Guide. -// Set :devonly!: when compiling the public version of the Users' Guide. +// Set :devonly: when compiling the developers version of the Users Guide. +// Set :devonly!: when compiling the public version of the Users Guide. // -// The ifdef::devonly[] command allows one to include text for the developers' -// version of the Users' Guide. +// The ifdef::devonly[] command allows one to include text for the developers +// version of the Users Guide. // Usage: // ifdef::devonly[] // line one diff --git a/docs/LDT_users_guide/build.adoc b/docs/LDT_users_guide/build.adoc index 0995c7649..f8fdb558e 100644 --- a/docs/LDT_users_guide/build.adoc +++ b/docs/LDT_users_guide/build.adoc @@ -89,13 +89,17 @@ This script will prompt the user with a series of questions regarding support to | `LDT_OPENJPEG` | path to openJPEG library | required | `LDT_ECCODES` | path to ecCodes library | required | `LDT_NETCDF` | path to NetCDF library | required -| `LDT_HDF4` | path to HDF4 library | optional +| `LDT_HDF4` | path to HDF4 library | optional (required to use HDFEOS2) | `LDT_HDF5` | path to HDF5 library | optional | `LDT_HDFEOS` | path to HDFEOS2 library | optional | `LDT_GDAL` | path to GDAL library | optional | `LDT_FORTRANGIS` | path to FortranGIS library | optional (required to use GDAL) | `LDT_LIBGEOTIFF` | path to GeoTIFF library | optional | `LDT_JPEG` | path to JPEG library | optional (use system libjpeg by default) +| `LDT_LIBTIFF` | path to TIFF library | optional (use system libtiff by default) +| `LDT_LIBJBIG` | path to JBIG library | optional (use system libjbig by default) +| `LDT_LIBLZMA` | path to LZMA library | optional (use system liblzma by default) +| `LDT_RPC` | path to RPC library | optional (use system RPC library by default) |=== //{cpp} is C++ diff --git a/docs/LDT_users_guide/intro.adoc b/docs/LDT_users_guide/intro.adoc index 8f19e8d36..fc13561c8 100644 --- a/docs/LDT_users_guide/intro.adoc +++ b/docs/LDT_users_guide/intro.adoc @@ -2,7 +2,7 @@ [[sec-intro]] == Introduction -This is the Users`' Guide for the Land surface Data Toolkit (LDT). This document describes how to download and install the LDT software. It also describes LDT`'s run-time configuration options (the _ldt.config_ file). +This is the Users Guide for the Land surface Data Toolkit (LDT). This document describes how to download and install the LDT software. It also describes LDT`'s run-time configuration options (the _ldt.config_ file). This document consists of 7 sections, described as follows: @@ -31,6 +31,20 @@ This document consists of 7 sections, described as follows: //\attention{See \file{RELEASE\_NOTES} found in the \file{source.tar.gz} file for more //details. (See Section~\ref{sec:obtain-src}.)} +==== Version 7.5 + +. Includes new runmode +* Operation Enhanced (9-km) SMAP soil moisture (SMAP_E_OPL) +. Supports additional data assimilation observations +* CDFS green vegetation fraction (CDFS_GVF) +* GEOS-FP effective soil temperature (GEOS_FP_TEFFobs) +* Precipitation output from a LIS run (LISlsmPrecipobs) +* Soil temperature output from a LIS run (LISlsmTEFFobs) +* Operational 9-km enhanced SMAP soil moisture retrieval (SMAP_E_OPLsm) +* VIIRS green vegetation fraction (VIIRS_GVF) +. Supports additional parameters +* SnowModel parameters + ==== Version 7.4 . Includes new runmode diff --git a/docs/LDT_users_guide/revision_table.adoc b/docs/LDT_users_guide/revision_table.adoc index d8827e180..fa9bbc46e 100644 --- a/docs/LDT_users_guide/revision_table.adoc +++ b/docs/LDT_users_guide/revision_table.adoc @@ -2,6 +2,7 @@ |==== | Revision | Summary of Changes | Date +| 3.0 | LISF Public 7.5.0 release | Jan 10, 2024 | 2.4 | LISF Public 7.4.3 release | Oct 03, 2023 | 2.3 | LISF 557WW 7.5.9 release | Jul 05, 2023 | 2.2 | LISF 557WW 7.5.8 release | Jun 30, 2023 diff --git a/docs/LIS_users_guide/LIS_users_guide.adoc b/docs/LIS_users_guide/LIS_users_guide.adoc index 0a53e6f1a..c3eaaf36b 100644 --- a/docs/LIS_users_guide/LIS_users_guide.adoc +++ b/docs/LIS_users_guide/LIS_users_guide.adoc @@ -1,4 +1,4 @@ -= Land Information System (LIS): LIS {lisfrevision} Users`' Guide += Land Information System (LIS): LIS {lisfrevision} Users Guide :revnumber: 2.5 :revdate: 05 Jul 2023 :doctype: book @@ -23,11 +23,11 @@ :vertellipsis: ⋮ -// Set :devonly: when compiling the developers' version of the Users' Guide. -// Set :devonly!: when compiling the public version of the Users' Guide. +// Set :devonly: when compiling the developers' version of the Users Guide. +// Set :devonly!: when compiling the public version of the Users Guide. // // The ifdef::devonly[] command allows one to include text for the developers' -// version of the Users' Guide. +// version of the Users Guide. // Usage: // ifdef::devonly[] // line one From a4bf7ff13f182258be787984e5f1b70d889e8a0f Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 10 Jan 2024 15:42:29 -0500 Subject: [PATCH 276/328] Update LVT Users Guide for LISF 7.5.0 public release --- docs/LVT_users_guide/LVT_users_guide.adoc | 10 +++++----- docs/LVT_users_guide/build.adoc | 3 ++- docs/LVT_users_guide/intro.adoc | 13 ++++++++----- docs/LVT_users_guide/revision_table.adoc | 1 + 4 files changed, 16 insertions(+), 11 deletions(-) diff --git a/docs/LVT_users_guide/LVT_users_guide.adoc b/docs/LVT_users_guide/LVT_users_guide.adoc index b4198240b..0d6ecb004 100644 --- a/docs/LVT_users_guide/LVT_users_guide.adoc +++ b/docs/LVT_users_guide/LVT_users_guide.adoc @@ -1,6 +1,6 @@ -= Land surface Verification Toolkit (LVT): LVT {lisfrevision} Users`' Guide -:revnumber: 2.4 -:revdate: 05 Jul 2023 += Land surface Verification Toolkit (LVT): LVT {lisfrevision} Users Guide +:revnumber: 3.0 +:revdate: 10 Jan 2024 :doctype: book :sectnums: :toc: @@ -9,13 +9,13 @@ :imagesoutdir: images :stem: latexmath :devonly: -:lisfrevision: 7.4 +:lisfrevision: 7.5 :lisfurl: https://lis.gsfc.nasa.gov :nasalisf: https://github.com/NASA-LIS/LISF :githuburl: https://github.com :nasalisfpages: https://nasa-lis.github.io/LISF/ :apachelicense: https://www.apache.org/licenses/LICENSE-2.0 -:lvttarball: LISF_public_release_7.4.0.tar.gz +:lvttarball: LISF_public_release_7.5.0.tar.gz :emdash: — :endash: – :vertellipsis: ⋮ diff --git a/docs/LVT_users_guide/build.adoc b/docs/LVT_users_guide/build.adoc index 5c73eca15..4d164db4a 100644 --- a/docs/LVT_users_guide/build.adoc +++ b/docs/LVT_users_guide/build.adoc @@ -89,12 +89,13 @@ This script will prompt the user with a series of questions regarding support to | `LVT_OPENJPEG` | path to openJPEG library | required | `LVT_ECCODES` | path to ecCodes library | required | `LVT_NETCDF` | path to NETCDF library | optional -| `LVT_HDF4` | path to HDF4 library | optional +| `LVT_HDF4` | path to HDF4 library | optional (required to use HDFEOS2) | `LVT_HDF5` | path to HDF5 library | optional | `LVT_HDFEOS` | path to HDFEOS2 library | optional | `LVT_GDAL` | path to GDAL library | optional | `LVT_FORTRANGIS` | path to FortranGIS library | optional (required to use GDAL) | `LVT_JPEG` | path to JPEG library | optional (use system libjpeg by default) +| `LVT_RPC` | path to RPC library | optional (use system RPC library by default) |=== //{cpp} is C++ diff --git a/docs/LVT_users_guide/intro.adoc b/docs/LVT_users_guide/intro.adoc index 8c4a645b8..4b37797be 100644 --- a/docs/LVT_users_guide/intro.adoc +++ b/docs/LVT_users_guide/intro.adoc @@ -2,7 +2,7 @@ [[sec-intro]] == Introduction -This is the Users`' Guide for Land surface Verification Toolkit (LVT; <>). +This is the Users Guide for Land surface Verification Toolkit (LVT; <>). This document describes how to download and install the LVT software. It also describes LVT`'s run-time configuration options (the _lvt.config_ file). This document consists of 9 sections, described as follows: @@ -37,10 +37,13 @@ This document consists of 9 sections, described as follows: === What's New //\attention{See \file{RELEASE\_NOTES} found in the \file{source.tar.gz} file for more details. (See Section~\ref{sec-obtain-src}.)} -//==== Version 7.5 -//. utils -//* s2smetric/ -//* s2spost/ +==== Version 7.5 + +. Supports additional data streams +* COAMPS forcing data (COAMPSout) +* GRUN runoff data (GRUNrunoff) +* GPM IMERG Monthly precipitation data (IMERG_monthly) +* Operational enhanced SMAP soil moisture retrieval data (SMAP_E_OPL) ==== Version 7.4 diff --git a/docs/LVT_users_guide/revision_table.adoc b/docs/LVT_users_guide/revision_table.adoc index 39edd94a6..44dd257f5 100644 --- a/docs/LVT_users_guide/revision_table.adoc +++ b/docs/LVT_users_guide/revision_table.adoc @@ -2,6 +2,7 @@ |=== | Revision | Summary of Changes | Date +| 3.0 | LISF Public 7.5.0 release | Jan 10, 2024 | 2.4 | LISF 557WW 7.5.9 release | Jul 05, 2023 | 2.3 | LISF 557WW 7.5.8 release | Jun 30, 2023 | 2.2 | LISF 557WW 7.5.4 release | May 5, 2023 From ad1e31eb75d405f5e52c2664341bb4b7160c2957 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 10 Jan 2024 16:27:11 -0500 Subject: [PATCH 277/328] Second round of major changes to improve fault tolerance. --- lis/metforcing/galwem/galwem_forcingMod.F90 | 6 +- lis/metforcing/galwem/get_galwem.F90 | 236 +++++++++----------- lis/metforcing/galwem/read_galwem.F90 | 51 +++-- 3 files changed, 148 insertions(+), 145 deletions(-) diff --git a/lis/metforcing/galwem/galwem_forcingMod.F90 b/lis/metforcing/galwem/galwem_forcingMod.F90 index d6e0e30c0..be1061f91 100644 --- a/lis/metforcing/galwem/galwem_forcingMod.F90 +++ b/lis/metforcing/galwem/galwem_forcingMod.F90 @@ -39,7 +39,7 @@ module galwem_forcingMod type, public :: galwem_type_dec real :: ts integer :: nc, nr, vector_len - real*8 :: fcsttime1,fcsttime2 + real*8 :: fcsttime1,fcsttime2,fcsttime3 character(len=LIS_CONST_PATH_LEN) :: odir !GALWEM forecast forcing Directory character*20 :: runmode integer :: resol !GALWEM forecast resolution (17km or 25deg) @@ -68,7 +68,7 @@ module galwem_forcingMod integer :: init_yr, init_mo, init_da, init_hr real, allocatable :: metdata1(:,:) real, allocatable :: metdata2(:,:) - + real, allocatable :: metdata3(:,:) integer :: nmodels end type galwem_type_dec @@ -154,6 +154,7 @@ subroutine init_galwem(findex) allocate(galwem_struc(n)%metdata1(LIS_rc%met_nf(findex),LIS_rc%ngrid(n))) allocate(galwem_struc(n)%metdata2(LIS_rc%met_nf(findex),LIS_rc%ngrid(n))) + allocate(galwem_struc(n)%metdata3(LIS_rc%met_nf(findex),LIS_rc%ngrid(n))) ! Initialize the forecast initial date-time and grib record: galwem_struc(n)%init_yr = LIS_rc%syr @@ -164,6 +165,7 @@ subroutine init_galwem(findex) galwem_struc(n)%fcst_hour = 0 galwem_struc(n)%metdata1 = 0 galwem_struc(n)%metdata2 = 0 + galwem_struc(n)%metdata3 = 0 gridDesci = 0 if(galwem_struc(n)%resol == 17) then !galwem-17km diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index ef0a5dfa2..8d4ece4e1 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -95,10 +95,12 @@ subroutine get_galwem(n, findex) endif !EMK...Perform audit of available GALWEM-GD GRIB files for current fcst - !run. + !run. First two files will be saved in galwem_struc(n) as metdata1 + !and metdata2; also saves fcst_hour. if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then use_prior_galwem_run = .false. - call run_audit(n, LIS_rc%syr, LIS_rc%smo, LIS_rc%sda, LIS_rc%shr, & + call run_audit(n, findex, & + LIS_rc%syr, LIS_rc%smo, LIS_rc%sda, LIS_rc%shr, & 0, filecount) if (filecount < 2) then !Roll back to prior GALWEM run yr1 = LIS_rc%syr @@ -109,7 +111,8 @@ subroutine get_galwem(n, findex) ss1 = 0 ts1 = -43200 call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) - call run_audit(n, yr1, mo1, da1, hr1, & + call run_audit(n, findex, & + yr1, mo1, da1, hr1, & 12, filecount) if (filecount < 2) then write(LIS_logunit,*) & @@ -127,78 +130,15 @@ subroutine get_galwem(n, findex) ! Get the bookends at the start of the run if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then - - ! Bookend-time record 1 - yr1 = LIS_rc%syr - mo1 = LIS_rc%smo - da1 = LIS_rc%sda - hr1 = LIS_rc%shr - mn1 = 0 - ss1 = 0 - ts1 = 0 - if (use_prior_galwem_run) ts1 = -43200 - call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) - - ! Find Bookend-time record 2 - first_fcsthr = 0 - if (use_prior_galwem_run) first_fcsthr = 12 - call find_next_fcsthr(n, galwem_struc(n)%init_yr, & - galwem_struc(n)%init_mo, & - galwem_struc(n)%init_da, & - galwem_struc(n)%init_hr, & - first_fcsthr, next_fcsthr, ierr) - if (ierr .ne. 0) then - write(LIS_logunit,*) '[ERR] Cannot find next GALWEM GRIB file!' - write(LIS_logunit,*) '[ERR] LIS run with terminate...' - flush(LIS_logunit) - call LIS_endrun() - end if - galwem_struc(n)%fcst_hour = next_fcsthr - yr2 = LIS_rc%syr - mo2 = LIS_rc%smo - da2 = LIS_rc%sda - hr2 = LIS_rc%shr - mn2 = 0 - ss2 = 0 - ts2 = next_fcsthr * 3600 - if (use_prior_galwem_run) ts2 = ts2 - 43200 - call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) - - openfile = 1 + write(LIS_logunit,*)'[INFO] time1 = ', & + galwem_struc(n)%fcsttime1 + write(LIS_logunit,*)'[INFO] time2 = ', & + galwem_struc(n)%fcsttime2 + openfile = 1 ! Data already stored in galwem_struc(n) by run_audit end if - ! If this is the beginning of the LIS run, read the two bookends - if (openfile == 1) then - - ferror = 0 - order = 1 - call getGALWEMfilename(n, galwem_struc(n)%odir, & - galwem_struc(n)%init_yr, & - galwem_struc(n)%init_mo, & - galwem_struc(n)%init_da, & - galwem_struc(n)%init_hr, & - first_fcsthr, fname) - - write(LIS_logunit,*) '[INFO] Getting GALWEM forecast file1 ... ', & - trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if (ferror .ge. 1) galwem_struc(n)%fcsttime1 = time1 - - ferror = 0 - order = 2 - call getGALWEMfilename(n, galwem_struc(n)%odir, & - galwem_struc(n)%init_yr, & - galwem_struc(n)%init_mo, & - galwem_struc(n)%init_da, & - galwem_struc(n)%init_hr, & - galwem_struc(n)%fcst_hour, fname) - - write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ', & - trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if (ferror .ge. 1) galwem_struc(n)%fcsttime2 = time2 - - else if (LIS_rc%mn==0 .and. & + ! If this is not the first LIS timestep, see if we need a new bookend + if (openfile == 0 .and. LIS_rc%mn==0 .and. & LIS_rc%tscount(n) .ne. 1) then ! See if we need to update the bookends @@ -211,60 +151,36 @@ subroutine get_galwem(n, findex) ts1 = 0 call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) - yr2 = galwem_struc(n)%init_yr - mo2 = galwem_struc(n)%init_mo - da2 = galwem_struc(n)%init_da - hr2 = galwem_struc(n)%init_hr - mn2 = 0 - ss2 = 0 - ts2 = 3600 * galwem_struc(n)%fcst_hour - call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) + if (time1 >= galwem_struc(n)%fcsttime2) then - if (time2 .le. time1) then - - ! Update the bookends - call find_next_fcsthr(n, galwem_struc(n)%init_yr, & + ! Update the bookends. Note: find_next_fcsthr will save + ! data from next file in galwem_struc(n)%metdata3 + call find_next_fcsthr(n, findex, & + galwem_struc(n)%init_yr, & galwem_struc(n)%init_mo, & galwem_struc(n)%init_da, & galwem_struc(n)%init_hr, & galwem_struc(n)%fcst_hour, next_fcsthr, ierr) + if (ierr .ne. 0) then + ! We couldn't find a newer GALWEM file. Set flag to + ! terminate after this timestep, and return. write(LIS_logunit,*) & '[WARN] Cannot find next GALWEM GRIB file!' flush(LIS_logunit) - lrc = LIS_endofrun(.true.) ! Force LIS_endofrun to return .true. + lrc = LIS_endofrun(.true.) ! Force LIS_endofrun to return true return - end if - yr2 = galwem_struc(n)%init_yr - mo2 = galwem_struc(n)%init_mo - da2 = galwem_struc(n)%init_da - hr2 = galwem_struc(n)%init_hr - mn2 = 0 - ss2 = 0 - ts2 = 3600 * next_fcsthr - call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, & - ts2) - - ! Update the bookends - galwem_struc(n)%fcsttime1 = galwem_struc(n)%fcsttime2 - galwem_struc(n)%metdata1 = galwem_struc(n)%metdata2 - - galwem_struc(n)%fcst_hour = next_fcsthr - - ferror = 0 - order = 2 - call getGALWEMfilename(n, galwem_struc(n)%odir, & - galwem_struc(n)%init_yr, & - galwem_struc(n)%init_mo, & - galwem_struc(n)%init_da, & - galwem_struc(n)%init_hr, & - galwem_struc(n)%fcst_hour, fname) + else + ! We have a new second bookend. Copy the saved older bookend + ! to the first end. + galwem_struc(n)%metdata1 = galwem_struc(n)%metdata2 + galwem_struc(n)%fcsttime1 = galwem_struc(n)%fcsttime2 - write(LIS_logunit,*)'[INFO] Getting GALWEM forecast file2 ... ', & - trim(fname) - call read_galwem(n, findex, order, fname, ferror) - if (ferror .ge. 1) galwem_struc(n)%fcsttime2 = time2 + galwem_struc(n)%fcst_hour = next_fcsthr + galwem_struc(n)%fcsttime2 = galwem_struc(n)%fcsttime3 + galwem_struc(n)%metdata2 = galwem_struc(n)%metdata3 + end if end if end if openfile = 0 @@ -317,7 +233,8 @@ subroutine getGALWEMfilename(n,rootdir,yr,mo,da,hr,fc_hr,filename) end subroutine getGALWEMfilename ! Run audit on GALWEM GRIB files with specified start date and time. -subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) +subroutine run_audit(n, findex, & + yr, mo, da, hr, first_fcsthr, filecount) ! Imports use galwem_forcingMod, only: galwem_struc @@ -330,6 +247,7 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) ! Arguments integer, intent(in) :: n + integer, intent(in) :: findex integer, intent(in) :: yr integer, intent(in) :: mo integer, intent(in) :: da @@ -340,7 +258,10 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) ! Locals integer, parameter :: MAX_FCSTHRS = 240 character(len=LIS_CONST_PATH_LEN) :: fname - integer :: fcsthr, delta + integer :: fcsthr, delta, ferror, order + integer :: yr1, mo1, da1, hr1, mn1, ss1, doy1 + real :: ts1, gmt1 + real*8 :: time1 logical :: found_inq integer :: i @@ -349,10 +270,49 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) filecount = 0 do i = 0, MAX_FCSTHRS fcsthr = first_fcsthr + (i * delta) - call getGALWEMfilename(n, galwem_struc(n)%odir, yr, mo, da, hr, & + yr1 = yr + mo1 = mo + da1 = da + hr1 = hr + call getGALWEMfilename(n, galwem_struc(n)%odir, yr1, mo1, da1, hr1, & fcsthr, fname) + + write(LIS_logunit,*)'EMK: Searching for ', trim(fname) + + ferror = 0 inquire(file=trim(fname), exist=found_inq) if (found_inq) then + if (i == 0) then + order = 1 + else if (filecount < 2) then + order = 2 + else + order = 3 + end if + call read_galwem(n, findex, order, fname, ferror) + if (ferror == 0) then + mn1 = 0 + ss1 = 0 + ts1 = fcsthr * 3600 + call LIS_tick(time1, doy1, gmt1, & + yr1, mo1, da1, hr1, mn1, ss1, ts1) + if (order == 1) then + galwem_struc(n)%fcsttime1 = time1 + write(LIS_logunit,*) & + '[INFO] Read ', trim(fname) + write(LIS_logunit,*) '[INFO] time1 = ', time1 + else if (order == 2) then + galwem_struc(n)%fcsttime2 = time1 + galwem_struc(n)%fcst_hour = fcsthr + write(LIS_logunit,*) & + '[INFO] Read ', trim(fname) + write(LIS_logunit,*) '[INFO] time2 = ', time1 + else + galwem_struc(n)%fcsttime3 = time1 + end if + end if + end if + if (found_inq .and. ferror .eq. 0) then filecount = filecount + 1 else if (i == 0) then @@ -364,29 +324,34 @@ subroutine run_audit(n, yr, mo, da, hr, first_fcsthr, filecount) exit end if end if + + if (filecount >= 2) exit end do - if (filecount > 0) then - write(LIS_logunit,*)'[INFO] Found ', filecount, ' files' - end if + !if (filecount > 0) then + ! write(LIS_logunit,*)'[INFO] Found ', filecount, ' files' + !end if end subroutine run_audit ! Find next GALWEM grib file given current selected time and ! forecast hour -subroutine find_next_fcsthr(n, yr, mo, da, hr, cur_fcsthr, & +subroutine find_next_fcsthr(n, findex, & + yr, mo, da, hr, cur_fcsthr, & next_fcsthr, ierr) ! Imports use galwem_forcingMod, only: galwem_struc use LIS_constantsMod, only: LIS_CONST_PATH_LEN use LIS_logMod, only: LIS_logunit, LIS_endrun - + use LIS_timeMgrMod, only: LIS_tick + ! Defaults implicit none ! Arguments integer, intent(in) :: n + integer, intent(in) :: findex integer, intent(in) :: yr integer, intent(in) :: mo integer, intent(in) :: da @@ -398,7 +363,10 @@ subroutine find_next_fcsthr(n, yr, mo, da, hr, cur_fcsthr, & ! Locals integer, parameter :: MAX_FCSTHRS = 240 character(len=LIS_CONST_PATH_LEN) :: fname - integer :: fcsthr, delta + integer :: fcsthr, delta, order, ferror + integer :: yr1, mo1, da1, hr1, mn1, ss1, doy1 + real :: gmt1, ts1 + real*8 :: time1 logical :: found_inq integer :: i @@ -407,10 +375,28 @@ subroutine find_next_fcsthr(n, yr, mo, da, hr, cur_fcsthr, & delta = 1 do i = 1, MAX_FCSTHRS fcsthr = cur_fcsthr + (i * delta) - call getGALWEMfilename(n, galwem_struc(n)%odir, yr, mo, da, hr, & + yr1 = yr + mo1 = mo + da1 = da + hr1 = hr + call getGALWEMfilename(n, galwem_struc(n)%odir, yr1, mo1, da1, hr1, & fcsthr, fname) inquire(file=trim(fname), exist=found_inq) + ferror = 0 if (found_inq) then + order = 3 + call read_galwem(n, findex, order, fname, ferror) + if (ferror == 0) then + mn1 = 0 + ss1 = 0 + ts1 = fcsthr * 3600 + call LIS_tick(time1, doy1, gmt1, & + yr1, mo1, da1, hr1, mn1, ss1, ts1) + galwem_struc(n)%fcsttime3 = time1 + end if + end if + if (found_inq .and. ferror .eq. 0) then + write(LIS_logunit,*)'[INFO] Read ', trim(fname) next_fcsthr = fcsthr ierr = 0 exit diff --git a/lis/metforcing/galwem/read_galwem.F90 b/lis/metforcing/galwem/read_galwem.F90 index 9772347c2..2856d0437 100644 --- a/lis/metforcing/galwem/read_galwem.F90 +++ b/lis/metforcing/galwem/read_galwem.F90 @@ -78,7 +78,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) inquire(file=trim(gribfile),exist=found_inq) if (.not. found_inq) then write(LIS_logunit,*)'[ERR] Cannot find file '//trim(gribfile) - call LIS_endrun() + rc = 1 + return end if #if (defined USE_GRIBAPI) @@ -86,7 +87,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) call grib_open_file(ftn,trim(gribfile),'r',ierr) if ( ierr .ne. 0 ) then write(LIS_logunit,*) '[ERR] Failed to open - '//trim(gribfile) - call LIS_endrun() + rc = 1 + return end if ! Read in the first grib record, unpack the header and extract @@ -95,7 +97,7 @@ subroutine read_galwem(n, findex, order, gribfile, rc) if ( ierr .ne. 0 ) then write(LIS_logunit,*) '[ERR] failed to read - '//trim(gribfile) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 endif call grib_get(igrib,'centre',center,ierr) @@ -104,7 +106,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'centre in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'gridType',gtype,ierr) @@ -113,14 +116,16 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'gridtype in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif if(trim(gtype).ne."regular_ll") then write(LIS_logunit,*)'[ERR] GALWEM file not on lat/lon grid!' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'Ni',iginfo(1),ierr) @@ -128,7 +133,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) write(LIS_logunit,*) '[ERR] in grid_get: Ni in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'Nj',iginfo(2),ierr) @@ -136,7 +142,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) write(LIS_logunit,*) '[ERR] in grid_get: Nj in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'jDirectionIncrementInDegrees',gridres_dlat,ierr) @@ -146,7 +153,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif ! EMK...Added dlon @@ -157,7 +165,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'in read_galwem' call grib_release(igrib, ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'dataDate',dataDate,ierr) @@ -166,7 +175,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'dataDate in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif call grib_get(igrib,'dataTime',dataTime,ierr) @@ -175,7 +185,8 @@ subroutine read_galwem(n, findex, order, gribfile, rc) 'dataTime in read_galwem' call grib_release(igrib,ierr) call grib_close_file(ftn) - call LIS_endrun() + rc = 1 + return endif ! Here we tentatively have a file we can use. Close it for now, and @@ -197,7 +208,7 @@ subroutine read_galwem(n, findex, order, gribfile, rc) call assign_processed_galwemforc(n,order,6,vwind) call assign_processed_galwemforc(n,order,7,ps) call assign_processed_galwemforc(n,order,8,prectot) - + #endif end subroutine read_galwem @@ -269,7 +280,7 @@ subroutine fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess,& ! Executable code begins here ... - rc = 1 ! Initialize as "no error" + rc = 0 ! Initialize as "no error" ! EMK...Before using ECCODES/GRIB_API, see if the GRIB file exists ! using a simple inquire statement. This avoids ECCODES/GRIB_API @@ -278,7 +289,7 @@ subroutine fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess,& inquire(file=trim(gribfile),exist=found_inq) if (.not. found_inq) then write(LIS_logunit,*) '[WARN] Cannot find file '//trim(gribfile) - rc = 0 + rc = 1 return end if @@ -289,7 +300,7 @@ subroutine fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess,& call grib_open_file(ftn,trim(gribfile),'r',ierr) if ( ierr .ne. 0 ) then write(LIS_logunit,*) '[WARN] Failed to open - '//trim(gribfile) - rc = 0 + rc = 1 return end if @@ -514,7 +525,7 @@ subroutine fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess,& ! At this point, we have everything. Close the file and return. call grib_close_file(ftn) - rc = 1 + rc = 0 return ! Jump down here to clean up memory before returning after finding a @@ -531,7 +542,7 @@ subroutine fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess,& deallocate ( fg_vwind ) deallocate ( fg_ps ) deallocate ( fg_prectot ) - rc = 0 + rc = 1 #endif end subroutine fldbld_read_galwem @@ -749,6 +760,10 @@ subroutine assign_processed_galwemforc(n,order,var_index,galwemforc) galwem_struc(n)%metdata2(var_index,& LIS_domain(n)%gindex(c,r)) = & galwemforc(c,r) + elseif(order.eq.3) then + galwem_struc(n)%metdata3(var_index,& + LIS_domain(n)%gindex(c,r)) = & + galwemforc(c,r) endif endif enddo From 7610effabd55174f10d22c0c5b33e9d9292d226b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 11 Jan 2024 12:26:28 -0500 Subject: [PATCH 278/328] Final (?) clean-up to add fault tolerance to GALWEM reader. --- lis/metforcing/galwem/galwem_forcingMod.F90 | 4 +++- lis/metforcing/galwem/get_galwem.F90 | 13 +++---------- lis/metforcing/galwem/read_galwem.F90 | 3 +++ 3 files changed, 9 insertions(+), 11 deletions(-) diff --git a/lis/metforcing/galwem/galwem_forcingMod.F90 b/lis/metforcing/galwem/galwem_forcingMod.F90 index be1061f91..60a3973c2 100644 --- a/lis/metforcing/galwem/galwem_forcingMod.F90 +++ b/lis/metforcing/galwem/galwem_forcingMod.F90 @@ -20,7 +20,8 @@ module galwem_forcingMod ! REVISION HISTORY: ! 11 Mar 2022; Yeosang Yoon; Initial Specification ! 08 Sep 2022; Yeosang Yoon, Add codes to read GALWEM 25 DEG dataset - +! 11 Jan 2024; Eric Kemp, added third entries for fcsttime and metdata +! for temporary storage. ! !USES: use LIS_constantsMod, only : LIS_CONST_PATH_LEN @@ -199,6 +200,7 @@ subroutine init_galwem(findex) galwem_struc(n)%mi = galwem_struc(n)%nc*galwem_struc(n)%nr galwem_struc(n)%fcsttime1 = 3000.0 galwem_struc(n)%fcsttime2 = 0.0 + galwem_struc(n)%fcsttime3 = 0.0 enddo do n=1,LIS_rc%nnest diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index 8d4ece4e1..29f5c3624 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -21,7 +21,7 @@ ! 00Z, to correct time intervals between GALWEM-GD files, ! and to stop searching for (nonexistent) GALWEM-GD file ! when LIS reaches it's end time. -! 09 Jan 2024: Eric Kemp. Reworked code to be fault tolerant, to roll +! 11 Jan 2024: Eric Kemp. Reworked code to be fault tolerant, to roll ! back to an earlier GALWEM run if necessary, and to better ! ensure LIS outputs history files before an early ! termination. @@ -110,7 +110,8 @@ subroutine get_galwem(n, findex) mn1 = 0 ss1 = 0 ts1 = -43200 - call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + call LIS_tick(time1, doy1, gmt1, & + yr1, mo1, da1, hr1, mn1, ss1, ts1) call run_audit(n, findex, & yr1, mo1, da1, hr1, & 12, filecount) @@ -130,10 +131,6 @@ subroutine get_galwem(n, findex) ! Get the bookends at the start of the run if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then - write(LIS_logunit,*)'[INFO] time1 = ', & - galwem_struc(n)%fcsttime1 - write(LIS_logunit,*)'[INFO] time2 = ', & - galwem_struc(n)%fcsttime2 openfile = 1 ! Data already stored in galwem_struc(n) by run_audit end if @@ -277,8 +274,6 @@ subroutine run_audit(n, findex, & call getGALWEMfilename(n, galwem_struc(n)%odir, yr1, mo1, da1, hr1, & fcsthr, fname) - write(LIS_logunit,*)'EMK: Searching for ', trim(fname) - ferror = 0 inquire(file=trim(fname), exist=found_inq) if (found_inq) then @@ -300,13 +295,11 @@ subroutine run_audit(n, findex, & galwem_struc(n)%fcsttime1 = time1 write(LIS_logunit,*) & '[INFO] Read ', trim(fname) - write(LIS_logunit,*) '[INFO] time1 = ', time1 else if (order == 2) then galwem_struc(n)%fcsttime2 = time1 galwem_struc(n)%fcst_hour = fcsthr write(LIS_logunit,*) & '[INFO] Read ', trim(fname) - write(LIS_logunit,*) '[INFO] time2 = ', time1 else galwem_struc(n)%fcsttime3 = time1 end if diff --git a/lis/metforcing/galwem/read_galwem.F90 b/lis/metforcing/galwem/read_galwem.F90 index 2856d0437..04ad22c61 100644 --- a/lis/metforcing/galwem/read_galwem.F90 +++ b/lis/metforcing/galwem/read_galwem.F90 @@ -15,6 +15,7 @@ ! ! !REVISION HISTORY: ! 15 Mar 2022: Yeosang Yoon, initial code +! 11 Jan 2024; Eric Kemp, revisions for fault tolerance. ! ! !INTERFACE: subroutine read_galwem(n, findex, order, gribfile, rc) @@ -98,6 +99,7 @@ subroutine read_galwem(n, findex, order, gribfile, rc) write(LIS_logunit,*) '[ERR] failed to read - '//trim(gribfile) call grib_close_file(ftn) rc = 1 + return endif call grib_get(igrib,'centre',center,ierr) @@ -199,6 +201,7 @@ subroutine read_galwem(n, findex, order, gribfile, rc) call fldbld_read_galwem(n, findex, order, gribfile, ifguess, jfguess, & tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) + if (rc .ne. 0) return call assign_processed_galwemforc(n,order,1,tair) call assign_processed_galwemforc(n,order,2,qair) From 2dbabf2d252f2bcaae835540d9365e1062e669ee Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 11 Jan 2024 12:33:19 -0500 Subject: [PATCH 279/328] Update LIS Users Guide for LISF 7.5.0 public release --- docs/LIS_users_guide/LIS_users_guide.adoc | 10 +++---- docs/LIS_users_guide/build.adoc | 3 ++- docs/LIS_users_guide/intro.adoc | 14 ++++++++++ docs/LIS_users_guide/obtain-source.adoc | 33 +++++++++++++++++++++++ docs/LIS_users_guide/revision_table.adoc | 1 + docs/LIS_users_guide/user_cfg_table.adoc | 5 +++- 6 files changed, 59 insertions(+), 7 deletions(-) diff --git a/docs/LIS_users_guide/LIS_users_guide.adoc b/docs/LIS_users_guide/LIS_users_guide.adoc index c3eaaf36b..06e9f950e 100644 --- a/docs/LIS_users_guide/LIS_users_guide.adoc +++ b/docs/LIS_users_guide/LIS_users_guide.adoc @@ -1,6 +1,6 @@ = Land Information System (LIS): LIS {lisfrevision} Users Guide -:revnumber: 2.5 -:revdate: 05 Jul 2023 +:revnumber: 3.0 +:revdate: 11 Jan 2024 :doctype: book :sectnums: :toc: @@ -9,15 +9,15 @@ :imagesoutdir: images :stem: latexmath :devonly: -:lisfrevision: 7.4 +:lisfrevision: 7.5 :lisfurl: https://lis.gsfc.nasa.gov :listesturl: https://lis.gsfc.nasa.gov/lis-testcases :nasalisf: https://github.com/NASA-LIS/LISF :githuburl: https://github.com :nasalisfpages: https://nasa-lis.github.io/LISF/ :apachelicense: https://www.apache.org/licenses/LICENSE-2.0 -:listarball: LISF_public_release_7.4.0.tar.gz -:lispublicna: Not available in the {listarball} public release of LISF 7.4. +:listarball: LISF_public_release_7.5.0.tar.gz +:lispublicna: Not available in the {listarball} public release of LISF 7.5. :emdash: — :endash: – :vertellipsis: ⋮ diff --git a/docs/LIS_users_guide/build.adoc b/docs/LIS_users_guide/build.adoc index 9251602b1..5b2663c41 100644 --- a/docs/LIS_users_guide/build.adoc +++ b/docs/LIS_users_guide/build.adoc @@ -88,7 +88,7 @@ This script will prompt the user with a series of questions regarding support to | `LIS_OPENJPEG` | path to openJPEG library | required | `LIS_ECCODES` | path to ecCodes library | required | `LIS_NETCDF` | path to NetCDF library | required -| `LIS_HDF4` | path to HDF4 library | optional +| `LIS_HDF4` | path to HDF4 library | optional (required to use HDFEOS2) | `LIS_HDF5` | path to HDF5 library | optional | `LIS_HDFEOS` | path to HDFEOS2 library | optional | `LIS_MINPACK` | path to MINPACK library | optional @@ -98,6 +98,7 @@ This script will prompt the user with a series of questions regarding support to | `LIS_LAPACK` | path to LAPACK library | optional | `LIS_PETSC` | path to PETSc library | optional | `LIS_JPEG` | path to JPEG library | optional (use system libjpeg by default) +| `LIS_RPC` | path to RPC library | optional (use system RPC library by default) |==== //{cpp} is C++ diff --git a/docs/LIS_users_guide/intro.adoc b/docs/LIS_users_guide/intro.adoc index 7944a5133..04ffdc381 100644 --- a/docs/LIS_users_guide/intro.adoc +++ b/docs/LIS_users_guide/intro.adoc @@ -46,6 +46,20 @@ This document consists of 12 sections, described as follows: === What's New //\attention{See _RELEASE_NOTES_ found in the _source.tar.gz_ file for more details. (See Section <>.)} +==== Version 7.5 + +. Supports additional metforcing datasets +* GALWEM 17km or 0.25deg deterministic forecast reader (galwem) +* GALWEM-GE forecast reader (galwem_ge) +* GEOS-IT (geos_it) +. Supports additional data assimilation observation datasets +* CDFS green vegetation fraction (CDFS_GVF) +* CDF_Transfer_NASA_SMAPsm +* Operation Enhanced (9-km) SMAP soil moisture (SMAP_E_OPLsm) +* VIIRS green vegetation fraction (VIIRS_GVF) +* Margulis Western US Snow Reanalysis dataset (WUS_UCLAsnow) +. Includes RAPID router + ==== Version 7.4 . Includes new runmodes diff --git a/docs/LIS_users_guide/obtain-source.adoc b/docs/LIS_users_guide/obtain-source.adoc index bc9417480..d83036ba6 100644 --- a/docs/LIS_users_guide/obtain-source.adoc +++ b/docs/LIS_users_guide/obtain-source.adoc @@ -197,6 +197,14 @@ ASCAT (TU Wein) soil moisture + [red]##specifies what?## +*** _CDFS_GVF_ ++ +CDFS green vegetation fraction + +*** _CDF_Transfer_NASA_SMAPsm_ ++ +[red]##specifies what?## + *** _ESACCI_sm_ + ESACCI Essential Climate Variable product @@ -261,6 +269,10 @@ NASA SMAP vegetation optical depth retrievals + PMW snow +*** _SMAP_E_OPLsm_ ++ +Operation Enhanced (9-km) SMAP soil moisture + *** _SMAP_NRTsm_ + SMAP near-real time soil moisture retrievals @@ -321,6 +333,14 @@ Thermal hydraulic disaggregation of soil moisture (THySM) + USAF Snow and Ice Analysis +*** _VIIRS_GVF_ ++ +VIIRS green vegetation fraction + +*** _WUS_UCLAsnow_ ++ +Margulis Western US Snow Reanalysis dataset + *** _WindSat_Cband_sm_ + C-band soil moisture retrievals from WindSat @@ -531,6 +551,14 @@ ECMWF meteorological forcing data + [red]##specifies what?## +** _galwem_ ++ +GALWEM 17km or 0.25deg deterministic forecast reader + +** _galwem_ge_ ++ +GALWEM-GE forecast reader + ** _gdas_ + NCEP GDAS meteorological forcing data @@ -559,6 +587,10 @@ LDT-generated meteorological forcing data + NASA GEOS 5 meteorological forecast forcing data +** _geos_it_ ++ +GEOS-IT + ** _gfs_ + NCEP GFS meteorological forcing data @@ -824,6 +856,7 @@ Directory containing routing models ** _HYMAP_router_ ** _HYMAP2_router_ ** _NLDAS_router_ +** _RAPID_router_ * _rtms_ + diff --git a/docs/LIS_users_guide/revision_table.adoc b/docs/LIS_users_guide/revision_table.adoc index 8671fe499..9f9e0fe32 100644 --- a/docs/LIS_users_guide/revision_table.adoc +++ b/docs/LIS_users_guide/revision_table.adoc @@ -2,6 +2,7 @@ |==== |Revision | Summary of Changes | Date +|3.0 | LISF Public 7.5.0 release | Jan 11, 2024 |2.5 | LISF 557WW 7.5.9 release | Jul 05, 2023 |2.4 | LISF 557WW 7.5.8 release | Jun 30, 2023 |2.3 | LISF 557WW 7.5.5 release | Jun 20, 2023 diff --git a/docs/LIS_users_guide/user_cfg_table.adoc b/docs/LIS_users_guide/user_cfg_table.adoc index e6a0acb33..63962d576 100644 --- a/docs/LIS_users_guide/user_cfg_table.adoc +++ b/docs/LIS_users_guide/user_cfg_table.adoc @@ -35,6 +35,7 @@ | GLDAS | On | GFS | On | MERRA2 | On +| GEOS-IT | On | ERA5 | On | CMAP | On | CHIRPS2 | On @@ -173,6 +174,7 @@ | DA OBS NRT_SMAPsm | On | DA OBS pildas | On | DA OBS GRACE | On +| DA CDF TRANSFER NASA SMAPSM | On |==== .Bias estimation @@ -255,9 +257,10 @@ | FASST | Off | CLSM F2.5 | On | GeoWRSI.2 | On -| LSM RDHM.3.5.6 | On +| LSM RDHM.3.5.6 | Off | SUMMA.1.0 | Off | Crocus.8.1 | Off +| SNOWMODEL | Off | Flake.1.0 | Off | NoahMP-GL.3.9.1.1 | On | template glacier | On From 3a6dbb5fdefa0d4bc37355ed9227e0a060aa94c9 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Thu, 11 Jan 2024 13:09:07 -0500 Subject: [PATCH 280/328] Update LISF Installation Guide for LISF 7.5.0 public release --- .../LISF_installation_guide.adoc | 4 +- .../additional_platforms.adoc | 47 +++++++++++++++++++ .../LISF_installation_guide/dependencies.adoc | 8 ++++ docs/LISF_installation_guide/devenv.adoc | 15 +++--- docs/LISF_installation_guide/platforms.adoc | 12 +++-- .../revision_table.adoc | 1 + 6 files changed, 72 insertions(+), 15 deletions(-) diff --git a/docs/LISF_installation_guide/LISF_installation_guide.adoc b/docs/LISF_installation_guide/LISF_installation_guide.adoc index bb7ec1305..07e28d7fa 100644 --- a/docs/LISF_installation_guide/LISF_installation_guide.adoc +++ b/docs/LISF_installation_guide/LISF_installation_guide.adoc @@ -1,6 +1,6 @@ = LISF Installation Guide -:revnumber: 1.1 -:revdate: 30 Nov 2022 +:revnumber: 2.0 +:revdate: 11 Jan 2024 :doctype: book :sectnums: :toc: diff --git a/docs/LISF_installation_guide/additional_platforms.adoc b/docs/LISF_installation_guide/additional_platforms.adoc index baed71df7..9649b5bf5 100644 --- a/docs/LISF_installation_guide/additional_platforms.adoc +++ b/docs/LISF_installation_guide/additional_platforms.adoc @@ -2,6 +2,53 @@ [[sec_additional_platforms,Additional platforms]] == Additional platforms +// discover +.SUSE Linux Enterprise Server 12.3 +|==== +| Library | Version + +| GNU compiler | 11.2.0 +| Intel compiler | 2021.4.0 +| Intel MPI | 2021.4.0 +| HDF 5 | 1.12.1 +| NetCDF | 4.8.1 +| NetCDF-Fortran | 4.5.3 +| openJPEG | 2.4.0 +| ecCodes | 2.23.0 +| ESMF | 8.1.1 +| HDF 4 | 4.2.15 +| HDF-EOS2 | 2.20v.1.00 +| SQLite3 | 3.35.0 +| PROJ | 7.1.1 +| GeoTIFF | 1.7.0 +| GDAL | 2.4.4 +| FortranGIS | 2.6 +| JPEG | 8d +|==== + +// discover +.SUSE Linux Enterprise Server 12.3 +|==== +| Library | Version + +| GNU compiler | 11.2.0 +| Intel MPI | 2021.4.0 +| HDF 5 | 1.12.1 +| NetCDF | 4.8.1 +| NetCDF-Fortran | 4.5.3 +| openJPEG | 2.4.0 +| ecCodes | 2.23.0 +| ESMF | 8.1.1 +| HDF 4 | 4.2.15 +| HDF-EOS2 | 2.20v.1.00 [red]#Not installed; failed make check# +| SQLite3 | 3.35.0 +| PROJ | 7.1.1 +| GeoTIFF | 1.7.0 +| GDAL | 2.4.4 +| FortranGIS | 2.6 +| JPEG | 8d +|==== + // koehr .Red Hat Enterprise Linux Server 7.8 |==== diff --git a/docs/LISF_installation_guide/dependencies.adoc b/docs/LISF_installation_guide/dependencies.adoc index a6eba4131..4a8412c69 100644 --- a/docs/LISF_installation_guide/dependencies.adoc +++ b/docs/LISF_installation_guide/dependencies.adoc @@ -212,6 +212,12 @@ NOTE: Required by PROJ. NOTE: Required by GeoTIFF and GDAL. +==== PETSc 3.16.1 + +*URL*: https://petsc.org/ + +NOTE: Required by RAPID router + === Notes To install these libraries, follow the instructions provided at the various URL listed above. These libraries have their own dependencies, which should be documented in their respective documentation. @@ -242,6 +248,8 @@ If you wish to install all the libraries (required and optional, excluding JCSDA . GDAL (optional) . FortranGIS (optional) + Required to use GDAL +. PETSc (optional) + + Required to use RAPID router //If not, review the appropriate _$WORKING/arch/configure.lis.*_ file //for some hints regarding additional low level libraries needed for diff --git a/docs/LISF_installation_guide/devenv.adoc b/docs/LISF_installation_guide/devenv.adoc index 16cfc07af..0119f764c 100644 --- a/docs/LISF_installation_guide/devenv.adoc +++ b/docs/LISF_installation_guide/devenv.adoc @@ -16,14 +16,14 @@ These instructions expect that you are using such a system. In particular you n ===== Compilers -* Intel Fortran Compiler versions 18, 19, 20, or 21 with corresponding Intel C Compiler along with GNU`'s Compiler Collection version 9.2.0 or 11.2.0. -* or GNU`'s Compiler Collection version 9.2.0 or 11.2.0, both gfortran and gcc. +* Intel Fortran Compiler versions 2021 or 2022 with corresponding Intel C Compiler along with GNU`'s Compiler Collection version 11.2.0 or 12.1.0. +* or GNU`'s Compiler Collection version 11.2.0, both gfortran and gcc. ===== Tools * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.8 +* Python, version 2.7 or 3.4 IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. @@ -39,15 +39,14 @@ IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depen ===== Compilers -* Intel Fortran Compiler version 18 or 19 with corresponding Intel C Compiler, along with GNU`'s Compiler Collection version 7.3.0 -* or Intel Fortran Compiler version 21 with corresponding Intel C Compiler, along with GNU`'s Compiler Collection version 7.5.0 -* or Cray Compiler Environment (cce) version 12.0.3 or 13.0.0, along with GNU`'s Compiler Collection version 11.2.0 +* Intel Fortran Compiler version 2021 or 2022 with corresponding Intel C Compiler, along with GNU`'s Compiler Collection version 11.2.0 or 12.1.0. +* or Cray Compiler Environment (cce) version 14.0.0, along with GNU`'s Compiler Collection version 11.2.0. ===== Tools * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.8 +* Python, version 2.7 or 3.4 IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. @@ -61,7 +60,7 @@ IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depen * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.8 +* Python, version 2.7 or 3.4 IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. diff --git a/docs/LISF_installation_guide/platforms.adoc b/docs/LISF_installation_guide/platforms.adoc index a5b32800c..9f25915fb 100644 --- a/docs/LISF_installation_guide/platforms.adoc +++ b/docs/LISF_installation_guide/platforms.adoc @@ -19,10 +19,11 @@ The following tables provide some specific platforms with compiler and library v | HDF 4 | 4.2.15 | HDF-EOS2 | 2.20v.1.00 | SQLite3 | 3.35.0 -| PROJ | 7.1.1 +| PROJ | 9.1.0 | GeoTIFF | 1.7.0 -| GDAL | 2.4.4 +| GDAL | 3.5.2 | FortranGIS | 2.6 +| PETSc | 3.16.1 | JPEG | 8d |==== @@ -40,12 +41,13 @@ The following tables provide some specific platforms with compiler and library v | ecCodes | 2.23.0 | ESMF | 8.1.1 | HDF 4 | 4.2.15 -| HDF-EOS2 | 2.20v.1.00 [red]#Not installed; failed make check# +| HDF-EOS2 | 3.0 | SQLite3 | 3.35.0 -| PROJ | 7.1.1 +| PROJ | 9.1.0 | GeoTIFF | 1.7.0 -| GDAL | 2.4.4 +| GDAL | 3.5.2 | FortranGIS | 2.6 +| PETSc | 3.16.1 | JPEG | 8d |==== diff --git a/docs/LISF_installation_guide/revision_table.adoc b/docs/LISF_installation_guide/revision_table.adoc index a5ef49849..46934f422 100644 --- a/docs/LISF_installation_guide/revision_table.adoc +++ b/docs/LISF_installation_guide/revision_table.adoc @@ -2,6 +2,7 @@ |==== |Revision | Summary of Changes | Date +|2.0 | LISF Public 7.5.0 release | Jan 11, 2024 |1.1 | LISF 557WW 7.5.0 release | Nov 30, 2022 |1.0 | LISF Public 7.4.0 release | Jun 14, 2022 |==== From 1087f2ea8c6266da8169d49a9a513222e37818e7 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 19 Jan 2024 11:39:14 -0500 Subject: [PATCH 281/328] Replaced LIS_endrun with LIS_alert and LIS_abort. This will create special alert files in case LIS has to terminate early, which should be more useful diagnose behavior in real-time operations. Also, changed the LIS time step check to be no more than 1 hour (the minimum interval between GALWEM GRIB files. --- lis/metforcing/galwem/get_galwem.F90 | 76 ++++++++++++++++++++++------ 1 file changed, 60 insertions(+), 16 deletions(-) diff --git a/lis/metforcing/galwem/get_galwem.F90 b/lis/metforcing/galwem/get_galwem.F90 index 29f5c3624..8c6e42aa1 100644 --- a/lis/metforcing/galwem/get_galwem.F90 +++ b/lis/metforcing/galwem/get_galwem.F90 @@ -28,12 +28,13 @@ ! !INTERFACE: subroutine get_galwem(n, findex) ! !USES: - use LIS_coreMod - use LIS_timeMgrMod - use LIS_logMod - use LIS_metforcingMod use galwem_forcingMod use LIS_constantsMod, only: LIS_CONST_PATH_LEN + use LIS_coreMod, only: LIS_masterproc, LIS_rc, LIS_endofrun + use LIS_logMod, only: LIS_logunit, LIS_abort, LIS_alert, LIS_endrun + use LIS_metforcingMod + use LIS_mpiMod + use LIS_timeMgrMod, only: LIS_julhr_date, LIS_tick implicit none @@ -64,15 +65,31 @@ subroutine get_galwem(n, findex) integer :: first_fcsthr, next_fcsthr integer :: ierr logical :: lrc + character(255) :: message(20) ! GALWEM cycles every 6 hours; each cycle provide up to 168 hours (7 days) forecast for GALWEM-17km; ! each cycle provide up to 240 hours (10 days) forecast for GALWEM-25deg; ! <=42 (every 1-hour); > 42 (every 3-hour) - if(LIS_rc%ts.gt.10800) then - write(LIS_logunit,*) '[WARN] The model timestep is > forcing data timestep ...' - write(LIS_logunit,*) '[WARN] LIS does not support this mode currently.' - call LIS_endrun() + if (LIS_rc%ts .gt. 3600) then + write(LIS_logunit,*) '[ERR] The model timestep is > 1 hour ...' + write(LIS_logunit,*) '[ERR] LIS does not support this mode currently.' + message = '' + message(1) = '[ERR] Program: LIS' + message(2) = ' Routine: get_galwem.' + message(3) = ' Model timestep > 1 hour' + message(4) = ' LIS does not support this mode.' + +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) +#endif + if (LIS_masterproc) then + call LIS_alert( 'LIS.get_galwem ', 1, message) + call LIS_abort(message) + else + call sleep(10) ! Make sure LIS_masterproc finishes LIS_abort + call LIS_endrun() + end if endif ! EMK...Return if LIS has reached the end time (meaning a new GALWEM @@ -118,7 +135,23 @@ subroutine get_galwem(n, findex) if (filecount < 2) then write(LIS_logunit,*) & "[ERR] No GALWEM files found, LIS will be halted!" - call LIS_endrun() + message = '' + message(1) = '[ERR] Program: LIS' + message(2) = ' Routine: get_galwem.' + message(3) = ' No GALWEM files found.' + message(4) = ' LIS will be halted.' + +#if (defined SPMD) + call MPI_Barrier(LIS_MPI_COMM, ierr) +#endif + if (LIS_masterproc) then + call LIS_alert( 'LIS.get_galwem ', 1, message) + call LIS_abort(message) + else + call sleep(10) ! Make sure LIS_masterproc finishes LIS_abort + call LIS_endrun() + end if + else use_prior_galwem_run = .true. galwem_struc(n)%init_yr = yr1 @@ -164,8 +197,18 @@ subroutine get_galwem(n, findex) ! terminate after this timestep, and return. write(LIS_logunit,*) & '[WARN] Cannot find next GALWEM GRIB file!' + write(LIS_logunit,*) & + '[WARN] LIS will terminate early.' flush(LIS_logunit) lrc = LIS_endofrun(.true.) ! Force LIS_endofrun to return true + message = '' + message(1) = '[WARN] Program: LIS' + message(2) = ' Routine: get_galwem.' + message(3) = ' Cannot find next GALWEM GRIB file.' + message(4) = ' LIS will terminate early.' + if (LIS_masterproc) then + call LIS_alert( 'LIS.get_galwem ', 1, message) + end if return else ! We have a new second bookend. Copy the saved older bookend @@ -192,11 +235,12 @@ end subroutine get_galwem ! !INTERFACE: subroutine getGALWEMfilename(n,rootdir,yr,mo,da,hr,fc_hr,filename) - use LIS_logMod, only: LIS_logunit, LIS_endrun use galwem_forcingMod + use LIS_logMod, only: LIS_logunit implicit none -! !ARGUMENTS: + + ! !ARGUMENTS: integer, intent(in) :: n character(len=*), intent(in) :: rootdir integer, intent(in) :: yr,mo,da,hr @@ -212,9 +256,9 @@ subroutine getGALWEMfilename(n,rootdir,yr,mo,da,hr,fc_hr,filename) write (UNIT=chr, FMT='(i2.2)') hr write (UNIT=fchr, FMT='(i3.3)') fc_hr - - ! GALWEM-17km - if(galwem_struc(n)%resol == 17) then + + ! GALWEM-17km + if(galwem_struc(n)%resol == 17) then fname = 'PS.557WW_SC.U_DI.C_GP.GALWEM-GD_GR.C17KM_AR.GLOBAL_DD.' endif @@ -236,7 +280,7 @@ subroutine run_audit(n, findex, & ! Imports use galwem_forcingMod, only: galwem_struc use LIS_constantsMod, only: LIS_CONST_PATH_LEN - use LIS_logMod, only: LIS_logunit, LIS_endrun + use LIS_logMod, only: LIS_logunit use LIS_timeMgrMod, only: LIS_tick ! Defaults @@ -336,7 +380,7 @@ subroutine find_next_fcsthr(n, findex, & ! Imports use galwem_forcingMod, only: galwem_struc use LIS_constantsMod, only: LIS_CONST_PATH_LEN - use LIS_logMod, only: LIS_logunit, LIS_endrun + use LIS_logMod, only: LIS_logunit use LIS_timeMgrMod, only: LIS_tick ! Defaults From f4c1257a32297458f926fb4103cd4fea8f27774a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 19 Jan 2024 15:41:28 -0500 Subject: [PATCH 282/328] Removed unused variables, and added external declarations. This is to appease the Intel compiler in strict check mode. --- lis/metforcing/mogreps_g/get_mogrepsg.F90 | 10 ++++---- .../mogreps_g/mogrepsg_forcingMod.F90 | 7 +++++- lis/metforcing/mogreps_g/read_mogrepsg.F90 | 23 +++++++++++-------- lis/metforcing/mogreps_g/reset_mogrepsg.F90 | 1 - .../mogreps_g/timeinterp_mogrepsg.F90 | 7 +++--- lis/plugins/LIS_metforcing_pluginMod.F90 | 8 ++++++- 6 files changed, 36 insertions(+), 20 deletions(-) diff --git a/lis/metforcing/mogreps_g/get_mogrepsg.F90 b/lis/metforcing/mogreps_g/get_mogrepsg.F90 index 31a206b91..f15e45221 100644 --- a/lis/metforcing/mogreps_g/get_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/get_mogrepsg.F90 @@ -43,21 +43,21 @@ subroutine get_mogrepsg(n, findex) ! the current model timestep. !EOP - integer :: order, ferror, m, t + integer :: order, ferror, m character(len=LIS_CONST_PATH_LEN) :: fname integer :: yr1, mo1, da1, hr1, mn1, ss1, doy1 integer :: yr2, mo2, da2, hr2, mn2, ss2, doy2 real*8 :: time1, time2 real :: gmt1, gmt2 real :: ts1, ts2 - integer :: fc_hr - integer :: hr_int1, hr_int2 integer :: valid_hour integer :: fcsthr_intv - integer :: fcst_hour integer :: openfile + external :: get_mogrepsg_filename + external :: read_mogrepsg + ! MOGREPS-G cycles every 6 hours; ecch cycle provide up to 192 hours (8 days; 3-hour interval) forecast if(LIS_rc%ts.gt.10800) then write(LIS_logunit,*) '[WARN] The model timestep is > forcing data timestep ...' @@ -186,7 +186,7 @@ end subroutine get_mogrepsg ! !INTERFACE: subroutine get_mogrepsg_filename(rootdir,yr,mo,da,hr,fc_hr,ens_id,filename) - use LIS_logMod, only: LIS_logunit, LIS_endrun + use LIS_logMod, only: LIS_endrun implicit none ! !ARGUMENTS: character(len=*), intent(in) :: rootdir diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 index 70445c340..d5f7e0858 100644 --- a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -103,7 +103,7 @@ module mogrepsg_forcingMod ! !INTERFACE: subroutine init_mogrepsg(findex) ! !USES: - use LIS_coreMod, only : LIS_rc, LIS_domain + use LIS_coreMod, only : LIS_rc use LIS_timeMgrMod, only : LIS_update_timestep use LIS_logMod, only : LIS_logunit, LIS_endrun @@ -123,6 +123,11 @@ subroutine init_mogrepsg(findex) real :: gridDesci(LIS_rc%nnest,50) real :: gridDesci_v(LIS_rc%nnest,50) ! v-wind + external :: readcrd_mogrepsg + external :: bilinear_interp_input + external :: conserv_interp_input + external :: neighbor_interp_input + write(LIS_logunit,*) "[INFO] Initializing the MOGREPS-G forecast inputs " ! Forecast mode -- NOT Available at this time for this forcing reader: diff --git a/lis/metforcing/mogreps_g/read_mogrepsg.F90 b/lis/metforcing/mogreps_g/read_mogrepsg.F90 index 31db01ed8..993d87c52 100644 --- a/lis/metforcing/mogreps_g/read_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/read_mogrepsg.F90 @@ -23,7 +23,6 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) ! !USES: use LIS_coreMod use LIS_logMod - use mogrepsg_forcingMod, only : mogrepsg_struc #if (defined USE_GRIBAPI) use grib_api @@ -68,14 +67,10 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) integer :: ftn, igrib, ierr integer :: center character*100 :: gtype - integer :: file_julhr - integer :: yr1, mo1, da1, hr1 - character*255 :: message ( 20 ) integer :: iginfo ( 40 ) real :: gridres_dlat, gridres_dlon integer :: ifguess, jfguess integer :: dataDate, dataTime - integer :: fc_hr real :: tair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Temperature interpolated to 2 metres [K] real :: qair(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Relative humidity interpolated to 2 metres[kg/kg] @@ -88,6 +83,9 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) integer, intent(out) :: rc + external :: fldbld_read_mogrepsg + external :: assign_processed_mogrepsgforc + ! Initialize return code to "no error". We will change it below if ! necessary. rc = 0 @@ -277,6 +275,9 @@ subroutine fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, logical :: found_inq + external :: interp_mogrepsg + external :: interp_mogrepsg_vwind + rc = 1 ! Initialize as "no error" ! EMK...Before using ECCODES/GRIB_API, see if the GRIB file exists @@ -620,15 +621,17 @@ subroutine interp_mogrepsg(n, findex, ifguess, jfguess, pcp_flag, input, output) !EOP integer :: mi, mo - integer :: k integer :: i,j integer :: iret integer :: midway - character(len=50) :: method real, allocatable, dimension(:,:) :: var logical*1, allocatable, dimension(:) :: lb logical*1, allocatable, dimension(:) :: lo + external :: bilinear_interp + external :: conserv_interp + external :: neighbor_interp + allocate(var(ifguess,jfguess)) allocate(lb(ifguess*jfguess)) allocate(lo(LIS_rc%lnc(n)*LIS_rc%lnr(n))) @@ -725,15 +728,17 @@ subroutine interp_mogrepsg_vwind(n, findex, ifguess, jfguess, pcp_flag, input, o !EOP integer :: mi, mo - integer :: k integer :: i,j integer :: iret integer :: midway - character(len=50) :: method real, allocatable, dimension(:,:) :: var logical*1, allocatable, dimension(:) :: lb logical*1, allocatable, dimension(:) :: lo + external :: bilinear_interp + external :: conserv_interp + external :: neighbor_interp + allocate(var(ifguess,jfguess)) allocate(lb(ifguess*jfguess)) allocate(lo(LIS_rc%lnc(n)*LIS_rc%lnr(n))) diff --git a/lis/metforcing/mogreps_g/reset_mogrepsg.F90 b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 index e7db3ba4e..29fc53503 100644 --- a/lis/metforcing/mogreps_g/reset_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 @@ -28,7 +28,6 @@ subroutine reset_mogrepsg() implicit none integer :: n - integer :: findex do n=1,LIS_rc%nnest mogrepsg_struc(n)%fcsttime1 = 3000.0 diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 index 7ad237b80..7b79d9207 100644 --- a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -67,9 +67,10 @@ subroutine timeinterp_mogrepsg(n,findex) type(ESMF_Field) :: psurfField,pcpField real,pointer :: tmp(:),q2(:),uwind(:),vwind(:) real,pointer :: swd(:),lwd(:),psurf(:),pcp(:) - real :: pcp_tmp - integer :: mfactor, m, k, tid, fcsthr_intv -! ________________________________________ + integer :: mfactor, m, k, tid + + external :: zterp + ! ________________________________________ btime=mogrepsg_struc(n)%fcsttime1 call LIS_time2date(btime,bdoy,gmt1,byr,bmo,bda,bhr,bmn) diff --git a/lis/plugins/LIS_metforcing_pluginMod.F90 b/lis/plugins/LIS_metforcing_pluginMod.F90 index 1d8cc979f..3020fee1f 100644 --- a/lis/plugins/LIS_metforcing_pluginMod.F90 +++ b/lis/plugins/LIS_metforcing_pluginMod.F90 @@ -666,7 +666,13 @@ subroutine LIS_metforcing_plugin external finalize_mogrepsg external reset_mogrepsg #endif - + + external :: registerinitmetforc + external :: registerretrievemetforc + external :: registertimeinterpmetforc + external :: registerfinalmetforc + external :: registerresetmetforc + #if ( defined MF_MET_TEMPLATE ) ! - Meteorological Forcing Template: call registerinitmetforc(trim(LIS_metForcTemplateId)//char(0), & From aa788ddd70681c9d76646d711ddf9f1af633404c Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 22 Jan 2024 10:04:01 -0500 Subject: [PATCH 283/328] Removed unused argument. --- lis/metforcing/mogreps_g/read_mogrepsg.F90 | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/lis/metforcing/mogreps_g/read_mogrepsg.F90 b/lis/metforcing/mogreps_g/read_mogrepsg.F90 index 993d87c52..2ea987673 100644 --- a/lis/metforcing/mogreps_g/read_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/read_mogrepsg.F90 @@ -36,6 +36,7 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) integer, intent(in) :: findex ! forcing index integer, intent(in) :: order character(len=*), intent(in) :: gribfile + integer, intent(out) :: rc !DESCRIPTION: ! For the given time, reads the forcing data from the @@ -81,8 +82,6 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) real :: ps(LIS_rc%lnc(n),LIS_rc%lnr(n)) !Instantaneous Surface Pressure [Pa] real :: prectot(LIS_rc%lnc(n),LIS_rc%lnr(n)) ! Total precipitation [kg/m^2] - integer, intent(out) :: rc - external :: fldbld_read_mogrepsg external :: assign_processed_mogrepsgforc @@ -195,7 +194,7 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) ifguess = iginfo(1) jfguess = iginfo(2) - call fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, & + call fldbld_read_mogrepsg(n, findex, gribfile, ifguess, jfguess, & tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) call assign_processed_mogrepsgforc(n, m, order, 1, tair) @@ -211,8 +210,8 @@ subroutine read_mogrepsg(n, m, findex, order, gribfile, rc) end subroutine read_mogrepsg -subroutine fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, & - tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) +subroutine fldbld_read_mogrepsg(n, findex, gribfile, ifguess, jfguess, & + tair, qair, swdown, lwdown, uwind, vwind, ps, prectot, rc) ! !USES: use LIS_coreMod, only : LIS_rc @@ -226,7 +225,6 @@ subroutine fldbld_read_mogrepsg(n, findex, order, gribfile, ifguess, jfguess, ! !ARGUMENTS: integer, intent(in) :: n integer, intent(in) :: findex ! Forcing index - integer, intent(in) :: order character(len=*), intent(in) :: gribfile integer, intent(in) :: ifguess integer, intent(in) :: jfguess From 95f7ff477b8f5d7a9a382a921f8acb66762d5f8a Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Mon, 22 Jan 2024 13:27:54 -0500 Subject: [PATCH 284/328] S2S CFSv2 script update - Corrected the year directory placement for January forecast files, where members are made up of December dates of prior year. - Also, increased slurm request hours for BCSD hindcast preprocessing. (since time outs have been occurring recently on Discover) --- .../usaf/s2s/s2s_app/s2s_hcst_preprocess.sh | 12 ++--- .../s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh | 48 +++++++++---------- 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh index 480a70184..3679a4aea 100644 --- a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh +++ b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh @@ -3,12 +3,12 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.5 -# -# Copyright (c) 2024 United States Government as represented by the +# Version 7.4 +# +# Copyright (c) 2022 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. -#-------------------------END NOTICE -- DO NOT EDIT----------------------- +# -------------------------END NOTICE -- DO NOT EDIT----------------------- # source and load shared functions from s2s_run.sh source s2s_app/s2s_run.sh --source-only @@ -147,9 +147,9 @@ reorg_cfsv2(){ /bin/ln -s ${E2ESDIR}/bcsd_fcst/ jobname=reorg_cfsv2 - python $LISHDIR/s2s_modules/bcsd_fcst/forecast_task_01.py -s $clim_syr -e $clim_mid -m $mmm -c $BWD/$CFILE -w ${CWD} -t 1 -H 9 -j ${jobname}_set1 + python $LISHDIR/s2s_modules/bcsd_fcst/forecast_task_01.py -s $clim_syr -e $clim_mid -m $mmm -c $BWD/$CFILE -w ${CWD} -t 1 -H 10 -j ${jobname}_set1 ((clim_mid++)) - python $LISHDIR/s2s_modules/bcsd_fcst/forecast_task_01.py -s $clim_mid -e $clim_eyr -m $mmm -c $BWD/$CFILE -w ${CWD} -t 1 -H 9 -j ${jobname}_set2 + python $LISHDIR/s2s_modules/bcsd_fcst/forecast_task_01.py -s $clim_mid -e $clim_eyr -m $mmm -c $BWD/$CFILE -w ${CWD} -t 1 -H 10 -j ${jobname}_set2 job_list="$jobname*.j" for jfile in $job_list diff --git a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh index 9f5f797f5..4da4cc8f4 100755 --- a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh +++ b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh @@ -3,12 +3,12 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.5 -# -# Copyright (c) 2024 United States Government as represented by the +# Version 7.4 +# +# Copyright (c) 2022 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. -#-------------------------END NOTICE -- DO NOT EDIT----------------------- +# -------------------------END NOTICE -- DO NOT EDIT----------------------- # Title: CFSv2 Operational Timeseries (Oper_TS) Download Script # @@ -128,10 +128,11 @@ main_loop() { echo $ret_code > $ret_code_pipe } # ________________________________________________________________ -# Main script +# +# Main part of the script # ________________________________________________________________ -# process command line arguments +# Process command line arguments ret_code=0 while getopts y:m:c:d: flag @@ -154,6 +155,7 @@ do ;; esac done + if [[ -z "$year" ]] || [[ -z "$mon" ]] || [[ -z "$configfile" ]] || [[ -z "$download" ]]; then echo "`basename ${0}`: usage: [-y year] [-m month ] [-c FULL_PATH/config_file] [-d download (Y/N)]" exit 1 @@ -163,14 +165,15 @@ echo "Month: $mon"; echo "Configfile: $configfile"; echo -# Read config file and extract information - +# Read config file and extract information: export NODE_NAME=`uname -n` if [[ $NODE_NAME =~ discover* ]] || [[ $NODE_NAME =~ borg* ]]; then cfsv2datadir=`grep fcst_download_dir $configfile | cut -d':' -f2 | tr -d "[:space:]"`"/Oper_TS/" else cfsv2datadir=`grep fcst_download_dir $configfile | cut -d':' -f2 | tr -d "[:space:]"` fi + +# Patch file info: patchfile=`grep supplementarydir $configfile | cut -d':' -f2 | tr -d "[:space:]"`"/bcsd_fcst/patch_files/patch_files_list.txt" patchdir=`grep supplementarydir $configfile | cut -d':' -f2 | tr -d "[:space:]"`"/bcsd_fcst/patch_files/" export LISFDIR=`grep LISFDIR $configfile | cut -d':' -f2 | tr -d "[:space:]"` @@ -222,11 +225,19 @@ ulimit -s unlimited fi yearmo=${year}${mon} cd ${cfsv2datadir} - echo ${year} - mkdir -p ${year} - cd ${year} - # open CFSv2 missing/corrupted file info log + echo " -- Run year :: "${year} +# - Need to account for Dec/Jan crossover + if [ ${mon} -eq "01" ]; then + year2=$((year-1)) + else + year2=${year} + fi + echo " -- Making and changing directory to target year for downloads -- "${year2} + mkdir -p ${year2} + cd ${year2} + + # Open CFSv2 missing/corrupted file info log SCRDIR=${E2ESDIR}/scratch/${yearmo}/ mkdir -p -m 775 ${SCRDIR}/ CFSV2_LOG=${SCRDIR}/CFSv2_missing_corrupted_files @@ -262,7 +273,6 @@ if [ ${mon} -eq "01" ]; then # "jan01" : ['1217', '1222', '1227'] echo "January ..." prevmon=12 - year2=$((year-1)) day1=17 day2=22 day3=27 @@ -271,7 +281,6 @@ elif [ ${mon} -eq "02" ]; then # "feb01" : ['0121', '0126', '0131'] echo "February ..." prevmon=01 - year2=${year} day1=21 day2=26 day3=31 @@ -280,7 +289,6 @@ elif [ ${mon} -eq "03" ]; then # "mar01" : ['0215', '0220', '0225'] echo "March ..." prevmon=02 - year2=${year} day1=15 day2=20 day3=25 @@ -289,7 +297,6 @@ elif [ ${mon} -eq "04" ]; then # "apr01" : ['0317', '0322', '0327'] echo "April ..." prevmon=03 - year2=${year} day1=17 day2=22 day3=27 @@ -298,7 +305,6 @@ elif [ ${mon} -eq "05" ]; then # "may01" : ['0416', '0421', '0426'] echo "May ..." prevmon=04 - year2=${year} day1=16 day2=21 day3=26 @@ -307,7 +313,6 @@ elif [ ${mon} -eq "06" ]; then # "jun01" : ['0521', '0526', '0531'] echo "June ..." prevmon=05 - year2=${year} day1=21 day2=26 day3=31 @@ -316,7 +321,6 @@ elif [ ${mon} -eq "07" ]; then # "jul01" : ['0620', '0625', '0630'] echo "July ..." prevmon=06 - year2=${year} day1=20 day2=25 day3=30 @@ -325,7 +329,6 @@ elif [ ${mon} -eq "08" ]; then # "aug01" : ['0720', '0725', '0730'] echo "August ..." prevmon=07 - year2=${year} day1=20 day2=25 day3=30 @@ -334,7 +337,6 @@ elif [ ${mon} -eq "09" ]; then # "sep01" : ['0819', '0824', '0829'] echo "September ..." prevmon=08 - year2=${year} day1=19 day2=24 day3=29 @@ -343,7 +345,6 @@ elif [ ${mon} -eq "10" ]; then # "oct01" : ['0918', '0923', '0928'] echo "October ..." prevmon=09 - year2=${year} day1=18 day2=23 day3=28 @@ -352,7 +353,6 @@ elif [ ${mon} -eq "11" ]; then # "nov01" : ['1018', '1023', '1028'] echo "November ..." prevmon=10 - year2=${year} day1=18 day2=23 day3=28 @@ -361,11 +361,11 @@ elif [ ${mon} -eq "12" ]; then # "dec01" : ['1117', '1122', '1127'] echo "December ..." prevmon=11 - year2=${year} day1=17 day2=22 day3=27 fi + echo "Previous mon,days 1-2-3 :: "${prevmon}", "${day1}"-"${day2}"-"${day3} echo " " echo "==================================================================================================" From de318435a1ce6e288c454059e301391a577ae246 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Mon, 22 Jan 2024 14:16:30 -0500 Subject: [PATCH 285/328] Ensuring correct LIS version and copyright year --- lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh | 6 +++--- lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh index 3679a4aea..a28a9625d 100644 --- a/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh +++ b/lis/utils/usaf/s2s/s2s_app/s2s_hcst_preprocess.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 -# -# Copyright (c) 2022 United States Government as represented by the +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. # -------------------------END NOTICE -- DO NOT EDIT----------------------- diff --git a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh index 4da4cc8f4..86588529a 100755 --- a/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh +++ b/lis/utils/usaf/s2s/s2s_app/wget_cfsv2_oper_ts_e2es.sh @@ -3,9 +3,9 @@ #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center # Land Information System Framework (LISF) -# Version 7.4 -# -# Copyright (c) 2022 United States Government as represented by the +# Version 7.5 +# +# Copyright (c) 2024 United States Government as represented by the # Administrator of the National Aeronautics and Space Administration. # All Rights Reserved. # -------------------------END NOTICE -- DO NOT EDIT----------------------- From 35b5016d58c52a69bbc816c87727f02407d88634 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 23 Jan 2024 09:06:15 -0500 Subject: [PATCH 286/328] Minor changes to reduce warnings from gfortran with strict checks. 1. Tweaked full-array copies to use (:,:,:) notation, which may stop gfortran from performing unnecessary array reallocations. See -Wrealloc-lhs flag in gfortran man page. 2. Explicitly convert doubles to reals before assigning to real variables. NOTE 1: Gfortran complains about some gridDesc entries having non-significant digits. Since the flagged assignments specify corner lat/lons, I decided to ignore the warnings and leave the code undisturbed. NOTE 2: Gfortran also complains about checking for equality for floating point numbers when searching for "undefined" or "missing" flags in some arrays. I decided to ignore the warnings and leave the code undisturbed, but in the long term this should be corrected throughout LIS. --- lis/metforcing/mogreps_g/get_mogrepsg.F90 | 2 +- .../mogreps_g/mogrepsg_forcingMod.F90 | 24 ++++++++++++++----- lis/metforcing/mogreps_g/read_mogrepsg.F90 | 18 +++++++------- lis/metforcing/mogreps_g/reset_mogrepsg.F90 | 4 ++-- .../mogreps_g/timeinterp_mogrepsg.F90 | 8 +++---- 5 files changed, 34 insertions(+), 22 deletions(-) diff --git a/lis/metforcing/mogreps_g/get_mogrepsg.F90 b/lis/metforcing/mogreps_g/get_mogrepsg.F90 index f15e45221..7f4169c3e 100644 --- a/lis/metforcing/mogreps_g/get_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/get_mogrepsg.F90 @@ -117,7 +117,7 @@ subroutine get_mogrepsg(n, findex) ! Update bookend-time record 2: if(LIS_rc%tscount(n).ne.1) then mogrepsg_struc(n)%fcsttime1=mogrepsg_struc(n)%fcsttime2 - mogrepsg_struc(n)%metdata1=mogrepsg_struc(n)%metdata2 + mogrepsg_struc(n)%metdata1(:,:,:)=mogrepsg_struc(n)%metdata2(:,:,:) yr2=LIS_rc%yr mo2=LIS_rc%mo diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 index d5f7e0858..180162578 100644 --- a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -187,29 +187,41 @@ subroutine init_mogrepsg(findex) gridDesci = 0 gridDesci(n,1) = 0 - gridDesci(n,2) = mogrepsg_struc(n)%nc !gnc - gridDesci(n,3) = mogrepsg_struc(n)%nr !gnr + gridDesci(n,2) = real(mogrepsg_struc(n)%nc) !gnc + gridDesci(n,3) = real(mogrepsg_struc(n)%nr) !gnr gridDesci(n,4) = -89.906250 !lat(1,1) + !NOTE: gfortran complains about non-significant digits in below + !assignment. For now we ignore the warning message from the + !compiler. gridDesci(n,5) = -179.859375 !lon(1,1) gridDesci(n,6) = 128 gridDesci(n,7) = 89.906250 !lat(gnc,gnr) + !NOTE: gfortran complains about non-significant digits in below + !assignment. For now we ignore the warning message from the + !compiler. gridDesci(n,8) = 179.859375 !lon(gnc,gnr) gridDesci(n,9) = 0.28125 !dx gridDesci(n,10) = 0.18750 !dy gridDesci(n,20) = 0 !for 0 to 360? mogrepsg_struc(n)%mi = mogrepsg_struc(n)%nc*mogrepsg_struc(n)%nr - mogrepsg_struc(n)%fcsttime1 = 3000.0 - mogrepsg_struc(n)%fcsttime2 = 0.0 + mogrepsg_struc(n)%fcsttime1 = dble(3000.0) + mogrepsg_struc(n)%fcsttime2 = dble(0.0) ! v-wind gridDesci_v(n,1) = 0 - gridDesci_v(n,2) = mogrepsg_struc(n)%nc !gnc - gridDesci_v(n,3) = mogrepsg_struc(n)%nrv !gnr + gridDesci_v(n,2) = real(mogrepsg_struc(n)%nc) !gnc + gridDesci_v(n,3) = real(mogrepsg_struc(n)%nrv) !gnr gridDesci_v(n,4) = -90.000000 !lat(1,1) + !NOTE: gfortran complains about non-significant digits in below + !assignment. For now we ignore the warning message from the + !compiler. gridDesci_v(n,5) = -179.859375 !lon(1,1) gridDesci_v(n,6) = 128 gridDesci_v(n,7) = 90.000000 !lat(gnc,gnr) + !NOTE: gfortran complains about non-significant digits in below + !assignment. For now we ignore the warning message from the + !compiler. gridDesci_v(n,8) = 179.859375 !lon(gnc,gnr) gridDesci_v(n,9) = 0.28125 !dx gridDesci_v(n,10) = 0.18750 !dy diff --git a/lis/metforcing/mogreps_g/read_mogrepsg.F90 b/lis/metforcing/mogreps_g/read_mogrepsg.F90 index 2ea987673..d32709d3b 100644 --- a/lis/metforcing/mogreps_g/read_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/read_mogrepsg.F90 @@ -437,32 +437,32 @@ subroutine fldbld_read_mogrepsg(n, findex, gribfile, ifguess, jfguess, & select case (grib_msg) case('t2') ! 2-m temperature - fg_tair = reshape(dum1d, (/ifguess,jfguess/)) + fg_tair(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_tair = count_tair + 1 case ('q2') ! 2-m relative humidity - fg_qair = reshape(dum1d, (/ifguess,jfguess/)) + fg_qair(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_qair = count_qair + 1 case ('swdown') ! downward shortwave - fg_swdown = reshape(dum1d, (/ifguess,jfguess/)) + fg_swdown(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_swdown = count_swdown + 1 case ('lwdown') ! downward longwave radiation - fg_lwdown = reshape(dum1d, (/ifguess,jfguess/)) + fg_lwdown(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_lwdown = count_lwdown + 1 case ('u10') ! 10m u-wind - fg_uwind = reshape(dum1d, (/ifguess,jfguess/)) + fg_uwind(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_uwind = count_uwind + 1 case('v10') ! 10m v-wind - fg_vwind = reshape(dumv1d, (/ifguess,jfguess+1/)) + fg_vwind(:,:) = reshape(dumv1d, (/ifguess,jfguess+1/)) count_vwind = count_vwind + 1 case('ps') ! surface pressure - fg_ps = reshape(dum1d, (/ifguess,jfguess/)) + fg_ps(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_ps = count_ps + 1 case('prectot') ! accumulated total precipitation - fg_prectot = reshape(dum1d, (/ifguess,jfguess/)) + fg_prectot(:,:) = reshape(dum1d, (/ifguess,jfguess/)) count_prectot = count_prectot + 1 case default ! Internal error, we shouldn't be here - write(LIS_logunit,*)'[WARN] Unknown grib_message ',grib_msg + write(LIS_logunit,*)'[ERR] Unknown grib_message ',grib_msg write(LIS_logunit,*)'Aborting...' flush(LIS_logunit) write(cstat,'(i9)',iostat=istat1) ierr diff --git a/lis/metforcing/mogreps_g/reset_mogrepsg.F90 b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 index 29fc53503..24ff0cd4e 100644 --- a/lis/metforcing/mogreps_g/reset_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/reset_mogrepsg.F90 @@ -30,8 +30,8 @@ subroutine reset_mogrepsg() integer :: n do n=1,LIS_rc%nnest - mogrepsg_struc(n)%fcsttime1 = 3000.0 - mogrepsg_struc(n)%fcsttime2 = 0.0 + mogrepsg_struc(n)%fcsttime1 = dble(3000.0) + mogrepsg_struc(n)%fcsttime2 = dble(0.0) enddo end subroutine reset_mogrepsg diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 index 7b79d9207..846260b0f 100644 --- a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -107,10 +107,10 @@ subroutine timeinterp_mogrepsg(n,findex) tempbss,tempbts) !Interpolate Data in Time - wt1=(mogrepsg_struc(n)%fcsttime2-LIS_rc%time)/ & - (mogrepsg_struc(n)%fcsttime2-mogrepsg_struc(n)%fcsttime1) + wt1=real((mogrepsg_struc(n)%fcsttime2-LIS_rc%time)/ & + (mogrepsg_struc(n)%fcsttime2-mogrepsg_struc(n)%fcsttime1)) wt2=1.0-wt1 - swt1=(newtime2-LIS_rc%time)/(newtime2-newtime1) + swt1=real((newtime2-LIS_rc%time)/(newtime2-newtime1)) swt2=1.0-swt1 call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Tair%varname(1),tmpField,& @@ -241,7 +241,7 @@ subroutine timeinterp_mogrepsg(n,findex) if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then ! account for the accum fields - pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/(3600*3) + pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/real(3600*3) if(pcp(tid).lt.0) then pcp(tid) = 0.0 endif From 513d30b5b3cf938de1084ad40e9cd308de11f942 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 23 Jan 2024 11:49:58 -0500 Subject: [PATCH 287/328] Change build scripts to explicitly use Python 3 --- ldt/make/makedep.py | 2 +- lis/make/makedep.py | 2 +- lis/make/plugins.py | 2 +- lvt/make/makedep.py | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/ldt/make/makedep.py b/ldt/make/makedep.py index daec48a11..77955a4c1 100755 --- a/ldt/make/makedep.py +++ b/ldt/make/makedep.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center diff --git a/lis/make/makedep.py b/lis/make/makedep.py index daec48a11..77955a4c1 100755 --- a/lis/make/makedep.py +++ b/lis/make/makedep.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center diff --git a/lis/make/plugins.py b/lis/make/plugins.py index a3fb119aa..967a6bc00 100755 --- a/lis/make/plugins.py +++ b/lis/make/plugins.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center diff --git a/lvt/make/makedep.py b/lvt/make/makedep.py index daec48a11..77955a4c1 100755 --- a/lvt/make/makedep.py +++ b/lvt/make/makedep.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 #-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- # NASA Goddard Space Flight Center From 86bada9ac9b9600bce46a64fbf887ce058144ed8 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 23 Jan 2024 11:51:12 -0500 Subject: [PATCH 288/328] Update LISF Installation Guide regarding use of Python 3 --- docs/LISF_installation_guide/devenv.adoc | 35 ++++++++++++++++++++---- 1 file changed, 29 insertions(+), 6 deletions(-) diff --git a/docs/LISF_installation_guide/devenv.adoc b/docs/LISF_installation_guide/devenv.adoc index 0119f764c..9c1f34c0a 100644 --- a/docs/LISF_installation_guide/devenv.adoc +++ b/docs/LISF_installation_guide/devenv.adoc @@ -23,9 +23,9 @@ These instructions expect that you are using such a system. In particular you n * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.4 +* Python, version 3.6 -IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. +IMPORTANT: The use of Python 2.7 for building LISF is now deprecated. See Section <>. // // *** or Absoft's Pro Fortran Software Developement Kit, version 10.0 @@ -46,9 +46,9 @@ IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depen * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.4 +* Python, version 3.6 -IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. +IMPORTANT: The use of Python 2.7 for building LISF is now deprecated. See Section <>. ==== IBM/Linux @@ -60,9 +60,9 @@ IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depen * GNU`'s make, gmake, version 3.77 or 3.81 * Perl, version 5.10 -* Python, version 2.7 or 3.4 +* Python, version 3.6 -IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depend on Python 3. +IMPORTANT: The use of Python 2.7 for building LISF is now deprecated. See Section <>. // // * IBM @@ -73,3 +73,26 @@ IMPORTANT: Support for Python 2.7 is now deprecated. Future releases will depen // ** Intel Fortran Compiler version 12 // ** GNU`'s make, gmake, version 3.77 +==== Python support + +The use of Python 2.7 for building LISF is now deprecated. If you only have Python 2.7, then edit the following four files + +* ldt/make/makedep.py +* lis/make/makedep.py +* lis/make/plugins.py +* lvt/make/makedep.py + +changing + +``` +#!/usr/bin/env python3 +``` + +to + +``` +#!/usr/bin/env python +``` + +Future releases will depend on Python 3 only. + From 1ce185ce5ec9eeca044608aafd9c1262ae44650d Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 23 Jan 2024 13:47:11 -0500 Subject: [PATCH 289/328] Move existing LISF modulefiles into env/discover/sles12 --- env/discover/{ => sles12}/lisf_7.5_gnu_11.2.0_impi_2021.4.0 | 0 env/discover/{ => sles12}/lisf_7.5_intel_2021.4.0 | 0 env/discover/{ => sles12}/lisf_7.5_intel_2021.4.0_s2s | 0 env/discover/{ => sles12}/lisf_7_gnu_11.2.0_impi_2021.4.0 | 0 env/discover/{ => sles12}/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 | 0 env/discover/{ => sles12}/lisf_7_intel_18_0_3_222 | 0 env/discover/{ => sles12}/lisf_7_intel_19_1_0_166 | 0 .../{ => sles12}/lisf_7_intel_19_1_0_166_traceback-work-around | 0 env/discover/{ => sles12}/lisf_7_intel_19_1_3_304 | 0 env/discover/{ => sles12}/lisf_7_intel_2021.4.0 | 0 env/discover/{ => sles12}/lisf_7_intel_2021.4.0_petsc | 0 env/discover/{ => sles12}/lisf_7_intel_2021.4.0_s2s | 0 12 files changed, 0 insertions(+), 0 deletions(-) rename env/discover/{ => sles12}/lisf_7.5_gnu_11.2.0_impi_2021.4.0 (100%) rename env/discover/{ => sles12}/lisf_7.5_intel_2021.4.0 (100%) rename env/discover/{ => sles12}/lisf_7.5_intel_2021.4.0_s2s (100%) rename env/discover/{ => sles12}/lisf_7_gnu_11.2.0_impi_2021.4.0 (100%) rename env/discover/{ => sles12}/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 (100%) rename env/discover/{ => sles12}/lisf_7_intel_18_0_3_222 (100%) rename env/discover/{ => sles12}/lisf_7_intel_19_1_0_166 (100%) rename env/discover/{ => sles12}/lisf_7_intel_19_1_0_166_traceback-work-around (100%) rename env/discover/{ => sles12}/lisf_7_intel_19_1_3_304 (100%) rename env/discover/{ => sles12}/lisf_7_intel_2021.4.0 (100%) rename env/discover/{ => sles12}/lisf_7_intel_2021.4.0_petsc (100%) rename env/discover/{ => sles12}/lisf_7_intel_2021.4.0_s2s (100%) diff --git a/env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 b/env/discover/sles12/lisf_7.5_gnu_11.2.0_impi_2021.4.0 similarity index 100% rename from env/discover/lisf_7.5_gnu_11.2.0_impi_2021.4.0 rename to env/discover/sles12/lisf_7.5_gnu_11.2.0_impi_2021.4.0 diff --git a/env/discover/lisf_7.5_intel_2021.4.0 b/env/discover/sles12/lisf_7.5_intel_2021.4.0 similarity index 100% rename from env/discover/lisf_7.5_intel_2021.4.0 rename to env/discover/sles12/lisf_7.5_intel_2021.4.0 diff --git a/env/discover/lisf_7.5_intel_2021.4.0_s2s b/env/discover/sles12/lisf_7.5_intel_2021.4.0_s2s similarity index 100% rename from env/discover/lisf_7.5_intel_2021.4.0_s2s rename to env/discover/sles12/lisf_7.5_intel_2021.4.0_s2s diff --git a/env/discover/lisf_7_gnu_11.2.0_impi_2021.4.0 b/env/discover/sles12/lisf_7_gnu_11.2.0_impi_2021.4.0 similarity index 100% rename from env/discover/lisf_7_gnu_11.2.0_impi_2021.4.0 rename to env/discover/sles12/lisf_7_gnu_11.2.0_impi_2021.4.0 diff --git a/env/discover/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 b/env/discover/sles12/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 similarity index 100% rename from env/discover/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 rename to env/discover/sles12/lisf_7_gnu_9.3.0_gmao_openmpi_4.0.4 diff --git a/env/discover/lisf_7_intel_18_0_3_222 b/env/discover/sles12/lisf_7_intel_18_0_3_222 similarity index 100% rename from env/discover/lisf_7_intel_18_0_3_222 rename to env/discover/sles12/lisf_7_intel_18_0_3_222 diff --git a/env/discover/lisf_7_intel_19_1_0_166 b/env/discover/sles12/lisf_7_intel_19_1_0_166 similarity index 100% rename from env/discover/lisf_7_intel_19_1_0_166 rename to env/discover/sles12/lisf_7_intel_19_1_0_166 diff --git a/env/discover/lisf_7_intel_19_1_0_166_traceback-work-around b/env/discover/sles12/lisf_7_intel_19_1_0_166_traceback-work-around similarity index 100% rename from env/discover/lisf_7_intel_19_1_0_166_traceback-work-around rename to env/discover/sles12/lisf_7_intel_19_1_0_166_traceback-work-around diff --git a/env/discover/lisf_7_intel_19_1_3_304 b/env/discover/sles12/lisf_7_intel_19_1_3_304 similarity index 100% rename from env/discover/lisf_7_intel_19_1_3_304 rename to env/discover/sles12/lisf_7_intel_19_1_3_304 diff --git a/env/discover/lisf_7_intel_2021.4.0 b/env/discover/sles12/lisf_7_intel_2021.4.0 similarity index 100% rename from env/discover/lisf_7_intel_2021.4.0 rename to env/discover/sles12/lisf_7_intel_2021.4.0 diff --git a/env/discover/lisf_7_intel_2021.4.0_petsc b/env/discover/sles12/lisf_7_intel_2021.4.0_petsc similarity index 100% rename from env/discover/lisf_7_intel_2021.4.0_petsc rename to env/discover/sles12/lisf_7_intel_2021.4.0_petsc diff --git a/env/discover/lisf_7_intel_2021.4.0_s2s b/env/discover/sles12/lisf_7_intel_2021.4.0_s2s similarity index 100% rename from env/discover/lisf_7_intel_2021.4.0_s2s rename to env/discover/sles12/lisf_7_intel_2021.4.0_s2s From 6ef813d79c5904a941c3266685ae379bc4b45c13 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 23 Jan 2024 14:50:05 -0500 Subject: [PATCH 290/328] Add new lisf_7.5_intel_2023.2.1 modulefile for discover SCU 17 (SLES 15.4) --- env/discover/sles15/lisf_7.5_intel_2023.2.1 | 160 ++++++++++++++++++++ 1 file changed, 160 insertions(+) create mode 100644 env/discover/sles15/lisf_7.5_intel_2023.2.1 diff --git a/env/discover/sles15/lisf_7.5_intel_2023.2.1 b/env/discover/sles15/lisf_7.5_intel_2023.2.1 new file mode 100644 index 000000000..3fb5657e1 --- /dev/null +++ b/env/discover/sles15/lisf_7.5_intel_2023.2.1 @@ -0,0 +1,160 @@ +#%Module1.0################################################################### + +proc ModulesHelp { } { + puts stderr "\t[module-info name] - loads the LISF_7_5_INTEL_2023_2_1 env" + puts stderr "" + puts stderr "This is for use on NCCS' discover system running SLES 15.4." + puts stderr "" + puts stderr "\tThe following env variables are set:" + puts stderr "\t\tDEV_ENV" + puts stderr "\t\tLIS_ARCH" + puts stderr "\t\tLIS_SPMD" + puts stderr "\t\tLIS_FC" + puts stderr "\t\tLIS_CC" + puts stderr "\t\tLIS_OPENJPEG" + puts stderr "\t\tLIS_ECCODES" + puts stderr "\t\tLIS_NETCDF" + puts stderr "\t\tLIS_HDF4" + puts stderr "\t\tLIS_HDFEOS" + puts stderr "\t\tLIS_HDF5" + puts stderr "\t\tLIS_MODESMF" + puts stderr "\t\tLIS_LIBESMF" + puts stderr "\t\tLIS_MINPACK" + puts stderr "\t\tLIS_CRTM" + puts stderr "\t\tLIS_CRTM_PROF" + puts stderr "\t\tLIS_CMEM" + puts stderr "\t\tLIS_LAPACK" + puts stderr "\t\tLIS_PETSC" + puts stderr "\t\tLDT_ARCH" + puts stderr "\t\tLDT_FC" + puts stderr "\t\tLDT_CC" + puts stderr "\t\tLDT_OPENJPEG" + puts stderr "\t\tLDT_ECCODES" + puts stderr "\t\tLDT_NETCDF" + puts stderr "\t\tLDT_HDF4" + puts stderr "\t\tLDT_HDFEOS" + puts stderr "\t\tLDT_HDF5" + puts stderr "\t\tLDT_MODESMF" + puts stderr "\t\tLDT_LIBESMF" + puts stderr "\t\tLDT_GDAL" + puts stderr "\t\tLDT_FORTRANGIS" + puts stderr "\t\tLDT_LIBGEOTIFF" + puts stderr "\t\tLVT_ARCH" + puts stderr "\t\tLVT_FC" + puts stderr "\t\tLVT_CC" + puts stderr "\t\tLVT_OPENJPEG" + puts stderr "\t\tLVT_ECCODES" + puts stderr "\t\tLVT_NETCDF" + puts stderr "\t\tLVT_HDF4" + puts stderr "\t\tLVT_HDFEOS" + puts stderr "\t\tLVT_HDF5" + puts stderr "\t\tLVT_MODESMF" + puts stderr "\t\tLVT_LIBESMF" + puts stderr "\t\tLVT_GDAL" + puts stderr "\t\tLVT_FORTRANGIS" + puts stderr "" + puts stderr "\tThe following modules are loaded:" + puts stderr "\t\tcomp/gcc/13.2.0" + puts stderr "\t\tcomp/intel/2023.2.1" + puts stderr "\t\tmpi/impi/2021.11" + puts stderr "\t\tgit/2.42.0" + puts stderr "" +} + +conflict comp mpi + +module-whatis "loads the [module-info name] environment" + +set modname [module-info name] +set modmode [module-info mode] + +module load comp/gcc/13.2.0 +module load comp/intel/2023.2.1 +module load mpi/impi/2021.11 +module load git/2.42.0 + +set def_lis_rpc /usr/lib64/libtirpc.so +set def_lis_hdf5 /discover/nobackup/projects/lis/libs/sles-15.4/hdf5/1.14.2_intel-2023.2.1 +set def_lis_netcdf /discover/nobackup/projects/lis/libs/sles-15.4/netcdf/4.9.2_intel-2023.2.1 +set def_lis_openjpeg /discover/nobackup/projects/lis/libs/sles-15.4/openjpeg/2.3.0-150000.3.13.1.x86_64/usr +set def_lis_eccodes /discover/nobackup/projects/lis/libs/sles-15.4/eccodes/2.32.0_intel-2023.2.1 +set def_lis_hdf4 /discover/nobackup/projects/lis/libs/sles-15.4/hdf4/4.2.16-2_intel-2023.2.1 +set def_lis_hdfeos /discover/nobackup/projects/lis/libs/sles-15.4/hdfeos2/3.0_intel-2023.2.1 +set def_lis_modesmf /discover/nobackup/projects/lis/libs/sles-15.4/esmf/8.5.0_intel-2023.2.1_impi-2021.11/mod/modO/Linux.intel.64.intelmpi.default +set def_lis_libesmf /discover/nobackup/projects/lis/libs/sles-15.4/esmf/8.5.0_intel-2023.2.1_impi-2021.11/lib/libO/Linux.intel.64.intelmpi.default +set def_lvt_proj /discover/nobackup/projects/lis/libs/sles-15.4/proj/9.3.0_intel-2023.2.1 +set def_ldt_libgeotiff /discover/nobackup/projects/lis/libs/sles-15.4/geotiff/1.7.1_intel-2023.2.1 +set def_lvt_gdal /discover/nobackup/projects/lis/libs/sles-15.4/gdal/3.7.2_intel-2023.2.1 +set def_lvt_fortrangis /discover/nobackup/projects/lis/libs/sles-15.4/fortrangis/3.0-1_intel-2023.2.1 +set def_lis_petsc /discover/nobackup/projects/lis/libs/sles-15.4/petsc/3.20.0_intel-2023.2.1_impi-2021.11 +set def_lis_minpack /discover/nobackup/projects/lis/libs/minpack/intel_11_1_038 +set def_lis_crtm /discover/nobackup/projects/lis/libs/JCSDA_CRTM/REL-2.0.2.Surface-rev_intel_18_0_3_222 +set def_lis_crtm_prof /discover/nobackup/projects/lis/libs/CRTM_Profile_Utility/intel_18_0_3_222 +set def_lis_cmem /discover/nobackup/projects/lis/libs/LIS-MEM/intel_18_0_3_222 +set def_lis_lapack /discover/nobackup/projects/lis/libs/lapack/3.6.0_intel_14_0_3_174 + +setenv DEV_ENV LISF_7_5_INTEL_2023_2_1 +setenv LIS_ARCH linux_ifc +setenv LIS_SPMD parallel +setenv LIS_FC mpiifort +setenv LIS_CC mpicc +setenv LIS_RPC $def_lis_rpc +setenv LIS_OPENJPEG $def_lis_openjpeg +setenv LIS_ECCODES $def_lis_eccodes +setenv LIS_NETCDF $def_lis_netcdf +setenv LIS_HDF4 $def_lis_hdf4 +setenv LIS_HDFEOS $def_lis_hdfeos +setenv LIS_HDF5 $def_lis_hdf5 +setenv LIS_MODESMF $def_lis_modesmf +setenv LIS_LIBESMF $def_lis_libesmf +setenv LIS_MINPACK $def_lis_minpack +setenv LIS_CRTM $def_lis_crtm +setenv LIS_CRTM_PROF $def_lis_crtm_prof +setenv LIS_CMEM $def_lis_cmem +setenv LIS_LAPACK $def_lis_lapack +setenv LIS_PETSC $def_lis_petsc + +setenv LDT_ARCH linux_ifc +setenv LDT_FC mpiifort +setenv LDT_CC mpicc +setenv LDT_RPC $def_lis_rpc +setenv LDT_OPENJPEG $def_lis_openjpeg +setenv LDT_ECCODES $def_lis_eccodes +setenv LDT_NETCDF $def_lis_netcdf +setenv LDT_HDF4 $def_lis_hdf4 +setenv LDT_HDFEOS $def_lis_hdfeos +setenv LDT_HDF5 $def_lis_hdf5 +setenv LDT_MODESMF $def_lis_modesmf +setenv LDT_LIBESMF $def_lis_libesmf +setenv LDT_GDAL $def_lvt_gdal +setenv LDT_FORTRANGIS $def_lvt_fortrangis +setenv LDT_LIBGEOTIFF $def_ldt_libgeotiff + + +setenv LVT_ARCH linux_ifc +setenv LVT_FC mpiifort +setenv LVT_CC mpicc +setenv LVT_RPC $def_lis_rpc +setenv LVT_OPENJPEG $def_lis_openjpeg +setenv LVT_ECCODES $def_lis_eccodes +setenv LVT_NETCDF $def_lis_netcdf +setenv LVT_HDF4 $def_lis_hdf4 +setenv LVT_HDFEOS $def_lis_hdfeos +setenv LVT_HDF5 $def_lis_hdf5 +setenv LVT_MODESMF $def_lis_modesmf +setenv LVT_LIBESMF $def_lis_libesmf +setenv LVT_GDAL $def_lvt_gdal +setenv LVT_FORTRANGIS $def_lvt_fortrangis + + +prepend-path LD_LIBRARY_PATH "$def_lis_openjpeg/lib" +prepend-path LD_LIBRARY_PATH "$def_ldt_libgeotiff/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_proj/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_gdal/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf4/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf5/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_libesmf" +prepend-path LD_LIBRARY_PATH "$def_lis_netcdf/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_eccodes/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_petsc/lib" +prepend-path PATH "$def_lis_netcdf/bin:$def_lis_eccodes/bin" From 298d3c42d4e62ed6a9958f5ca3683da23ee35b54 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 23 Jan 2024 17:33:26 -0500 Subject: [PATCH 291/328] Fixed preprocessing statements for HDF4 function calls. --- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index ef34d2326..f87b8d2de 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -68,7 +68,7 @@ SUBROUTINE AVHRR_NDVI(ssid,lon_ind,lat_ind,avg_NDVI) !sd_id = sfstart(trim(filename),DFACC) !ssid = sfselect(sd_id, 0) -#if (defined USE_HDF5) +#if (defined USE_HDF4) status = sfrdata(ssid,start, stride,edges, data) #endif !PRINT *, "Filename", filename @@ -99,7 +99,7 @@ SUBROUTINE AVHRR_NDVI_MATRIX(ssid,lon_ind,lat_ind, NDVI_MAT) !DFACC=1 !Read Only Access !sd_id = sfstart(trim(filename),DFACC) !ssid = sfselect(sd_id, 0) -#if (defined USE_HDF5) +#if (defined USE_HDF4) status = sfrdata(ssid,start, stride,edges, data) #endif NDVI_MAT=-9999 From 06a2f79c141c760eb1f61e2a62fecce630bff499 Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Wed, 24 Jan 2024 14:17:08 -0500 Subject: [PATCH 292/328] update codes for precpitation bias-correction --- lis/metforcing/mogreps_g/get_cdf_params.F90 | 209 ++++++++++++++++++ lis/metforcing/mogreps_g/get_mogrepsg.F90 | 48 +++- .../mogreps_g/mogrepsg_forcingMod.F90 | 34 ++- lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 | 18 ++ .../mogreps_g/timeinterp_mogrepsg.F90 | 23 +- 5 files changed, 325 insertions(+), 7 deletions(-) create mode 100644 lis/metforcing/mogreps_g/get_cdf_params.F90 diff --git a/lis/metforcing/mogreps_g/get_cdf_params.F90 b/lis/metforcing/mogreps_g/get_cdf_params.F90 new file mode 100644 index 000000000..7baec6b5f --- /dev/null +++ b/lis/metforcing/mogreps_g/get_cdf_params.F90 @@ -0,0 +1,209 @@ +!-----------------------BEGIN NOTICE -- DO NOT EDIT----------------------- +! NASA Goddard Space Flight Center +! Land Information System Framework (LISF) +! Version 7.3 +! +! Copyright (c) 2020 United States Government as represented by the +! Administrator of the National Aeronautics and Space Administration. +! All Rights Reserved. +!-------------------------END NOTICE -- DO NOT EDIT----------------------- +#include "LIS_misc.h" +!BOP +! +! !ROUTINE: get_cdf_params +! \label{get_cdf_params} +! +! !REVISION HISTORY: +! 01 May 2023: Yeosang Yoon, initial code +! +! !INTERFACE: +subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) + + !USES: + use LIS_coreMod + use LIS_logMod + use mogrepsg_forcingMod, only : mogrepsg_struc +#if (defined USE_NETCDF3 || defined USE_NETCDF4) + use netcdf +#endif + + implicit none + + !ARGUMENTS: + integer, intent(in) :: n + character(len=*), intent(in) :: fname + integer, intent(in) :: month ! month of year (1-12) + + !EOP + logical :: file_exists + integer :: ftn + integer :: param_a_id, param_b_id, mean_id, std_id, ngrid_id, nlead_id + integer :: ngrid, nlead + integer :: r, c, nc, c1, r1, gid, l + real,allocatable :: param_hires(:,:) + real,allocatable :: param_hires_2d(:,:) + real :: param_a(LIS_rc%ngrid(n),8) !8: lead time + real :: param_b(LIS_rc%ngrid(n),8) + real :: mean(LIS_rc%ngrid(n),8) + real :: std(LIS_rc%ngrid(n),8) + + ! check file + inquire(file=fname, exist=file_exists) + if(.not. file_exists) then + write(LIS_logunit,*) '[ERR] ',trim(fname)//' does not exist' + call LIS_endrun() + endif + + write(LIS_logunit,*)'[INFO] Getting MOGREPS-G bias correction parameters ', trim(fname) + call LIS_verify(nf90_open(path=trim(fname), mode=NF90_NOWRITE, & + ncid=ftn), 'nf90_open failed in get_cdf_params') + + call LIS_verify(nf90_inq_dimid(ftn, "ngrid", ngrid_id), & + 'nf90_inq_dimid failed for ngrid in get_cdf_params') + call LIS_verify(nf90_inquire_dimension(ftn, ngrid_id, len=ngrid),& + 'nf90_inquire_dimension failed for ngrid in get_cdf_params') + + if(LIS_rc%gnc(n)*LIS_rc%gnr(n) .ne. ngrid) then + write(LIS_logunit,*) 'The input dimensions of the '//trim(fname) + write(LIS_logunit,*) '(',ngrid,')' + write(LIS_logunit,*) 'does not match the dimensions in the LIS parameter file' + write(LIS_logunit,*) '(',LIS_rc%gnc(n)*LIS_rc%gnr(n),')' + call LIS_endrun() + endif + + call LIS_verify(nf90_inq_dimid(ftn, "lead_time", nlead_id), & + 'nf90_inq_dimid failed for nlead in get_cdf_params') + call LIS_verify(nf90_inquire_dimension(ftn, nlead_id, len=nlead),& + 'nf90_inquire_dimension failed for nlead in get_cdf_params') + + allocate(param_hires(LIS_rc%gnc(n)*LIS_rc%gnr(n),nlead)) + allocate(param_hires_2d(LIS_rc%gnc(n),LIS_rc%gnr(n))) + + param_hires = -9999.0 + param_hires_2d = -9999.0 + + ! read param_a + call LIS_verify(nf90_inq_varid(ftn,'cdf_param_a',param_a_id), & + 'nf90_inq_varid failed for cdf_param_a in get_cdf_params') + call LIS_verify(nf90_get_var(ftn, param_a_id, param_hires, & + start=(/1,1,month/), count=(/ngrid,nlead,1/)),& + 'nf90_get_var failed for cdf_param_a in get_cdf_params') + + do l=1,nlead + ! 1D -> 2D + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + enddo + enddo + + !subsets the data for each processor's domain + nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 + do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) + do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + gid = LIS_domain(n)%gindex(c1,r1) + if(gid.ne.-1) then + param_a(gid,l) = param_hires_2d(c,r) + endif + enddo + enddo + enddo + + ! read param_b + call LIS_verify(nf90_inq_varid(ftn,'cdf_param_b',param_b_id), & + 'nf90_inq_varid failed for cdf_param_b in get_cdf_params') + call LIS_verify(nf90_get_var(ftn, param_b_id, param_hires, & + start=(/1,1,month/), count=(/ngrid,nlead,1/)),& + 'nf90_get_var failed for cdf_param_b in get_cdf_params') + + do l=1,nlead + ! 1D -> 2D + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + enddo + enddo + + !subsets the data for each processor's domain + nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 + do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) + do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + gid = LIS_domain(n)%gindex(c1,r1) + if(gid.ne.-1) then + param_b(gid,l) = param_hires_2d(c,r) + endif + enddo + enddo + enddo + + ! read mean + call LIS_verify(nf90_inq_varid(ftn,'mean',mean_id), & + 'nf90_inq_varid failed for mean in get_cdf_params') + call LIS_verify(nf90_get_var(ftn, mean_id, param_hires, & + start=(/1,1,month/), count=(/ngrid,nlead,1/)),& + 'nf90_get_var failed for mean in get_cdf_params') + + do l=1,nlead + ! 1D -> 2D + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + enddo + enddo + + !subsets the data for each processor's domain + nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 + do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) + do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + gid = LIS_domain(n)%gindex(c1,r1) + if(gid.ne.-1) then + mean(gid,l) = param_hires_2d(c,r) + endif + enddo + enddo + enddo + + ! read std + call LIS_verify(nf90_inq_varid(ftn,'std',std_id), & + 'nf90_inq_varid failed for std in get_cdf_params') + call LIS_verify(nf90_get_var(ftn, std_id, param_hires, & + start=(/1,1,month/), count=(/ngrid,nlead,1/)),& + 'nf90_get_var failed for std in get_cdf_params') + + do l=1,nlead + ! 1D -> 2D + do r=1,LIS_rc%gnr(n) + do c=1,LIS_rc%gnc(n) + param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + enddo + enddo + + !subsets the data for each processor's domain + nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 + do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) + do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + gid = LIS_domain(n)%gindex(c1,r1) + if(gid.ne.-1) then + std(gid,l) = param_hires_2d(c,r) + endif + enddo + enddo + enddo + + deallocate(param_hires) + deallocate(param_hires_2d) + + call LIS_verify(nf90_close(ftn),'failed to close in get_cdf_params') + + write(LIS_logunit,*) 'Done reading MOGREPS-G bias correction parameters data ' + +end subroutine get_cdf_params + diff --git a/lis/metforcing/mogreps_g/get_mogrepsg.F90 b/lis/metforcing/mogreps_g/get_mogrepsg.F90 index 7f4169c3e..9877b0599 100644 --- a/lis/metforcing/mogreps_g/get_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/get_mogrepsg.F90 @@ -16,6 +16,7 @@ ! !REVISION HISTORY: ! 26 Jan 2023: Yeosang Yoon, initial code ! 13 Mar 2023: Yeosang Yoon, update codes to fit new format +! 01 Jan 2024; Yeosang Yoon; update codes for precpi. bias-correction ! ! !INTERFACE: subroutine get_mogrepsg(n, findex) @@ -43,7 +44,7 @@ subroutine get_mogrepsg(n, findex) ! the current model timestep. !EOP - integer :: order, ferror, m + integer :: order, ferror, m, t character(len=LIS_CONST_PATH_LEN) :: fname integer :: yr1, mo1, da1, hr1, mn1, ss1, doy1 integer :: yr2, mo2, da2, hr2, mn2, ss2, doy2 @@ -55,6 +56,10 @@ subroutine get_mogrepsg(n, findex) integer :: fcsthr_intv integer :: openfile + ! precipitation bias correction + real :: pcp1, pcp2 + integer :: lead_time + external :: get_mogrepsg_filename external :: read_mogrepsg @@ -172,6 +177,47 @@ subroutine get_mogrepsg(n, findex) mogrepsg_struc(n)%metdata2(4,m,:) = mogrepsg_struc(n)%metdata1(4,m,:) endif endif + + ! apply precipitation bias correction (cdf from difference bewteen NAPFA and MOGREPS-G) + if (mogrepsg_struc(n)%bc == 1) then + lead_time=floor((float(mogrepsg_struc(n)%fcst_hour))/24)+1 + + if (lead_time > 8) then + lead_time = 8 + endif + + do t=1, LIS_rc%ngrid(n) + if(mogrepsg_struc(n)%metdata2(8,m,t).ne.LIS_rc%udef) then + ! only for land pixels + if (mogrepsg_struc(n)%bc_param_a(t,lead_time) .ne. LIS_rc%udef) then + ! perform centering and scaling + pcp1=mogrepsg_struc(n)%metdata2(8,m,t)-mogrepsg_struc(n)%metdata1(8,m,t) + if (mogrepsg_struc(n)%bc_std(t,lead_time) .ne. 0) then + pcp2=(pcp1-mogrepsg_struc(n)%bc_mean(t,lead_time))/& + mogrepsg_struc(n)%bc_std(t,lead_time) + else + pcp2=pcp1 + endif + + ! apply cdf params + pcp2=pcp2*mogrepsg_struc(n)%bc_param_a(t,lead_time)+mogrepsg_struc(n)%bc_param_b(t,lead_time) + ! check for negative precipitation; if the corrected value has negative, keep the original value. + if(pcp2 >= 0) then + mogrepsg_struc(n)%pcp_bc(m,t)=pcp2 + else + mogrepsg_struc(n)%pcp_bc(m,t)=pcp1 + endif + ! additionally, avoid bias correction for values that are too samll to reduce abnormal noise. + if(pcp1 < 0.01) then + mogrepsg_struc(n)%pcp_bc(m,t)=pcp1 + endif + else ! for water pixels + mogrepsg_struc(n)%pcp_bc(m,t)=mogrepsg_struc(n)%metdata2(8,m,t)-mogrepsg_struc(n)%metdata1(8,m,t) + endif + endif + enddo + endif + enddo endif openfile=0 diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 index 180162578..e90cb40b5 100644 --- a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -19,6 +19,7 @@ module mogrepsg_forcingMod ! REVISION HISTORY: ! 26 Jan 2023; Yeosang Yoon; Initial Specification +! 01 Jan 2024; Yeosang Yoon; update codes for precpi. bias-correction ! !USES: use LIS_constantsMod, only : LIS_CONST_PATH_LEN @@ -89,6 +90,15 @@ module mogrepsg_forcingMod integer, allocatable :: nv113(:) + ! precipitation bias correction + integer :: bc !option for bias correction + character(len=LIS_CONST_PATH_LEN) :: cdf_fname !MOGREPS-G model CDF file name + real, allocatable :: pcp_bc(:,:) + real, allocatable :: bc_param_a(:,:) + real, allocatable :: bc_param_b(:,:) + real, allocatable :: bc_mean(:,:) + real, allocatable :: bc_std(:,:) + end type mogrepsg_type_dec type(mogrepsg_type_dec), allocatable :: mogrepsg_struc(:) @@ -160,7 +170,7 @@ subroutine init_mogrepsg(findex) ! Check if starting hour of LIS run matches 00/06/12/18 UTC: if((LIS_rc%shr .ne. 0) .and. (LIS_rc%shr .ne. 6) .and. & (LIS_rc%shr .ne. 12) .and. (LIS_rc%shr .ne. 18)) then - write(LIS_logunit,*) "[ERR] GALWEM forecast type begins" + write(LIS_logunit,*) "[ERR] MOGREPS-G forecast type begins" write(LIS_logunit,*) "[ERR] at 00/12Z for a forecast window, so the " write(LIS_logunit,*) "[ERR] 'Starting hour:' should be set to 0/12 in" write(LIS_logunit,*) "[ERR] your lis.config file.." @@ -340,5 +350,27 @@ subroutine init_mogrepsg(findex) endif enddo + ! precipitation bias correction + do n=1,LIS_rc%nnest + if (mogrepsg_struc(n)%bc == 1) then + allocate(mogrepsg_struc(n)%pcp_bc(mogrepsg_struc(n)%max_ens_members,LIS_rc%ngrid(n))) + allocate(mogrepsg_struc(n)%bc_param_a(LIS_rc%ngrid(n),8)) !8: lead time + allocate(mogrepsg_struc(n)%bc_param_b(LIS_rc%ngrid(n),8)) + allocate(mogrepsg_struc(n)%bc_mean(LIS_rc%ngrid(n),8)) + allocate(mogrepsg_struc(n)%bc_std(LIS_rc%ngrid(n),8)) + + mogrepsg_struc(n)%pcp_bc = 0 + mogrepsg_struc(n)%bc_param_a = 0 + mogrepsg_struc(n)%bc_param_b = 0 + mogrepsg_struc(n)%bc_mean = 0 + mogrepsg_struc(n)%bc_std = 0 + + ! read cdf parameters + call get_cdf_params(n,mogrepsg_struc(n)%cdf_fname,LIS_rc%mo,& + mogrepsg_struc(n)%bc_param_a, mogrepsg_struc(n)%bc_param_b,& + mogrepsg_struc(n)%bc_mean, mogrepsg_struc(n)%bc_std) + endif + enddo + end subroutine init_mogrepsg end module mogrepsg_forcingMod diff --git a/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 index 07777f8f6..0ab191a4a 100644 --- a/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 @@ -14,6 +14,7 @@ ! ! !REVISION HISTORY: ! 26 Jan 2023; Yeosang Yoon, Initial Code +! 01 Jan 2024; Yeosang Yoon; update codes for precpi. bias-correction ! ! !INTERFACE: subroutine readcrd_mogrepsg() @@ -52,11 +53,28 @@ subroutine readcrd_mogrepsg() call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%max_ens_members,rc=rc) enddo + call ESMF_ConfigFindLabel(LIS_config,"Apply MOGREPS-G precipitation bias correction:",rc=rc) + call LIS_verify(rc, 'Apply MOGREPS-G precipitation bias correction: not defined') + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%bc,rc=rc) + enddo + + call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G model CDF file:",rc=rc) + call LIS_verify(rc, 'MOGREPS-G model CDF file: not defined') + do n=1,LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%cdf_fname,rc=rc) + enddo + do n=1,LIS_rc%nnest write(LIS_logunit,*) '[INFO] Using MOGREPS-G forecast forcing' write(LIS_logunit,*) '[INFO] MOGREPS-G forecast forcing directory: ', trim(mogrepsg_struc(n)%odir) write(LIS_logunit,*) '[INFO] MOGREPS-G forecast run mode: ',mogrepsg_struc(n)%runmode write(LIS_logunit,*) '[INFO] MOGREPS-G forecast number of ensemble members:',& mogrepsg_struc(n)%max_ens_members + write(LIS_logunit,*) '[INFO] Using MOGREPS-G precipitation bias correction:',& + mogrepsg_struc(n)%bc + if (mogrepsg_struc(n)%bc == 1) then + write(LIS_logunit,*) '[INFO] MOGREPS-G model CDF file: ', trim(mogrepsg_struc(n)%cdf_fname) + endif enddo end subroutine readcrd_mogrepsg diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 index 846260b0f..efb0b4d8f 100644 --- a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -15,6 +15,7 @@ ! !REVISION HISTORY: ! ! 26 Jan 2023: Yeosang Yoon, Initial specification +! 01 Jan 2024; Yeosang Yoon; update codes for precpi. bias-correction ! ! !INTERFACE: subroutine timeinterp_mogrepsg(n,findex) @@ -239,13 +240,25 @@ subroutine timeinterp_mogrepsg(n,findex) tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k index1 = LIS_domain(n)%tile(tid)%index - if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then - ! account for the accum fields - pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/real(3600*3) - if(pcp(tid).lt.0) then - pcp(tid) = 0.0 + ! apply precipitation bias correction + if (mogrepsg_struc(n)%bc == 1) then !1 - use; or 0 + if(mogrepsg_struc(n)%pcp_bc(m,index1).ne.LIS_rc%udef) then + ! account for the accum fields + pcp(tid)=mogrepsg_struc(n)%pcp_bc(m,index1)/(3600*3) + if(pcp(tid).lt.0) then + pcp(tid) = 0.0 + endif + endif + else !don't apply bias correction + if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then + ! account for the accum fields + pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/(3600*3) + if(pcp(tid).lt.0) then + pcp(tid) = 0.0 + endif endif endif + enddo enddo enddo From 4123781490ab8ac32018fcb8b43cfe9b601cc2be Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 26 Jan 2024 13:16:37 -0500 Subject: [PATCH 293/328] Added first cut of SMAP_E_OPL automation scripts. --- .../customize_ldt_smapeopl_config.py | 127 +++++++++++++ .../SMAP_E_OPL/run_smap_e_opl_discover.sh | 169 ++++++++++++++++++ 2 files changed, 296 insertions(+) create mode 100755 ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py create mode 100755 ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh diff --git a/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py b/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py new file mode 100755 index 000000000..074671132 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py @@ -0,0 +1,127 @@ +#!/usr/bin/env python3 + +""" +SCRIPT: customize_ldt_smapeopl_config.py + +Creates a customized ldt.config file for generating SMAP_E_OPL soil +moisture retrieval with LDT. + +User must provide template ldt.config file, valid date/time, and +filelist suffix number via command line arguments. + +To see usage statement, run script on command line w/o arguments. + +REVISION HISTORY: +25 Jan 2024: Eric Kemp. Initial specification. +26 Jan 2024: Eric Kemp. Added filelist suffix number. +""" + +import datetime +import os +import sys + +def _usage(): + """Prints usage statement for script""" + stmt = f"USAGE: {sys.argv[0]} YYYYMMDDHH ldt_config_tmpl_name" + stmt += " filelist_suffix_number" + print(stmt) + +def _proc_valid_datetime(): + """Process command line argument for valid time""" + if len(sys.argv[1]) != 10: + print("ERR, invalid date/time for SMAP_E_OPL!") + print(f"ERR, received {sys.argv[1]}") + _usage() + sys.exit(1) + + yyyymmddhh = sys.argv[1] + try: + yyyy = int(yyyymmddhh[0:4]) + mm = int(yyyymmddhh[4:6]) + dd = int(yyyymmddhh[6:8]) + hh = int(yyyymmddhh[8:]) + validdt = \ + datetime.datetime(year=yyyy, + month=mm, + day=dd, + hour=hh) + except (TypeError, ValueError): + print("ERR, invalid date/time for SMAP_E_OPL!") + print(f"ERR, received {sys.argv[1]}") + _usage() + sys.exit(1) + + return validdt + +def _proc_ldt_config_tmpl_name(): + """Process command line for ldt config template file name""" + ldt_config_tmpl = sys.argv[2] + if not os.path.exists(ldt_config_tmpl): + print(f"ERR, cannot file template file {ldt_config_tmpl}") + _usage() + sys.exit(1) + return ldt_config_tmpl + +def _proc_filelist_suffix_number(): + """Process command line for filelist suffix number""" + suffix_number = sys.argv[3] + try: + int_value = int(suffix_number) + except ValueError: + print("ERR, did not receive valid filelist suffix number!") + _usage() + sys.exit(1) + if int_value < 0: + print("ERR, filelist suffix must be nonnegative!") + _usage() + sys.exit(1) + return int_value + +def _proc_cmd_line(): + """Process command line and return valid datetime for SMAP_E_OPL""" + if len(sys.argv) != 4: + print("ERR, invalid number of command line arguments!") + _usage() + sys.exit(1) + validdt = _proc_valid_datetime() + ldt_config_tmpl = _proc_ldt_config_tmpl_name() + filelist_suffix_number = _proc_filelist_suffix_number() + return validdt, ldt_config_tmpl, filelist_suffix_number + +def _create_new_ldt_config(validdt, ldt_config_tmpl, \ + filelist_suffix_number): + """Create new ldt.config customized to valid date""" + with open(ldt_config_tmpl, "r", encoding='ascii') as file: + lines = file.readlines() + yyyymmddhh = f"{validdt.year:04d}{validdt.month:02d}" + \ + f"{validdt.day:02d}{validdt.hour:02d}" + newfile = f"ldt.config.smapeopl.{yyyymmddhh}" + with open(newfile, "w", encoding='ascii') as file: + for line in lines: + if "SMAP_E_OPL valid date (YYYYMMDDHH):" in line: + newline = "SMAP_E_OPL valid date (YYYYMMDDHH): " + newline += f"{yyyymmddhh}\n" + file.write(newline) + continue + if "LDT diagnostic file:" in line: + newline = "LDT diagnostic file: " + newline += f"ldtlog.{yyyymmddhh}\n" + file.write(newline) + continue + if "SMAP_E_OPL filelist suffix number:" in line: + newline = "SMAP_E_OPL filelist suffix number: " + newline += f"{filelist_suffix_number}\n" + file.write(newline) + continue + # Pass through all other lines + file.write(line) + continue + +def _main(): + """Main driver""" + validdt, ldt_config_tmpl, filelist_suffix_number = _proc_cmd_line() + _create_new_ldt_config(validdt, ldt_config_tmpl, \ + filelist_suffix_number) + +if __name__ == "__main__": + _main() diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh new file mode 100755 index 000000000..31218d5d6 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -0,0 +1,169 @@ +#!/bin/sh +#SBATCH --job-name=smapeopl +#SBATCH --time=0:20:00 +#SBATCH --account s1189 +#SBATCH --output smapeopl.slurm.out +#SBATCH --ntasks=13 --ntasks-per-node=1 +#SBATCH --mail-type=ALL +#SBATCH --qos=debug +#-------------------------------------------------------------------------- +# +# SCRIPT: run_smap_e_opl_discover.sh +# +# Batch script for running LDT to generate SMAP_E_OPL retrievals with +# LDT. Customized for NASA Discover supercomputer running SLURM batch +# queueing system. +# +# USAGE: run_smap_e_opl_discover.sh $startdate $starthour $enddate \ +# $endhour +# where $startdate and $enddate specify the inclusive UTC +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD), +# and $starthour and $endhour specify the hours of the respective +# dates (formatted HH). +# +# Based on Korn shell script provided by Pang-Wei Liu. +# +# REVISION HISTORY: +# 25 Jan 2024: Eric Kemp. Initial specification. +# 26 Jan 2024: Eric Kemp. Added in-script parallelization following +# autotuning scripts. +# +#-------------------------------------------------------------------------- + +ulimit -s unlimited + +# When a batch script is started, it starts in the user's home directory. +# Change to the directory where job was submitted. +if [ ! -z $SLURM_SUBMIT_DIR ] ; then + cd $SLURM_SUBMIT_DIR || exit 1 +fi + +# Environment +module purge +unset LD_LIBRARY_PATH +module use --append /home/emkemp/privatemodules +module load lisf_7.5_intel_2021.4.0_s2s + +# Paths on local system +SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/scripts +BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/bin +TMPLDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/tmpl + +# Get the command line arguments to specify the training period +if [ -z "$1" ] ; then + echo "ERROR, Missing start date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$2" ] ; then + echo "ERROR, Missing start hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$3" ] ; then + echo "ERROR, Missing end date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$4" ] ; then + echo "ERROR, Missing end hour for SMAP_E_OPL retrievals!" + exit 1 +fi + +# Use the command line arguments to set start and end datetime limits. +# Sanity check and report errors if found. + +istart="$1 $2" +iend="$3 $4" +start_dt=$(date "+%F %H" -d "$istart") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad startdate and hour" && exit 1 +fi +end_dt=$(date "+%F %H" -d "$iend") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad enddate and hour" && exit 1 +fi +d="$start_dt" +cur_yyyymmddhh=$(date -d "$start_dt" +%Y%m%d%H) +end_yyyymmddhh=$(date -d "$end_dt" +%Y%m%d%H) + +# Other sanity checks +if [ ! -e $TMPLDIR/ldt.config.smapeopl.tmpl ] ; then + echo "ERR, $TMPLDIR/ldt.config.smap.tmpl not found!" && exit 1 +fi +if [ ! -e $BINDIR/LDT ] ; then + echo "ERR, $BINDIR/LDT does not exist!" && exit 1 +fi +if [ ! -e $SCRIPTDIR/customize_ldt_smapeopl_config.py ] ; then + echo "ERR, $SCRIPTDIR/customize_ldt_smapeopl_config.py not found!" + exit 1 +fi + +# Loop through all times. This requires parallel invocations using +# srun. +echo "INFO, started SMAP_E_OPL retrievals at `date`" +i=0 +while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do + + echo "INFO, working on $cur_yyyymmddhh at `date`" + + # Update ldt.config file + $SCRIPTDIR/customize_ldt_smapeopl_config.py "$cur_yyyymmddhh" \ + $TMPLDIR/ldt.config.smapeopl.tmpl $i || exit 1 + + # Run LDT + srun --ntasks=1 --nodes=1 --exclusive \ + $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + PIDS+=($!) + actives+=(1) + yyyymmddhh+=("$cur_yyyymmddhh") + ((i+=1)) + sleep 1 # Don't overwhelm SLURM + + # Update valid time + d=$(date -d "$d + 1 hours") + cur_yyyymmddhh=$(date -d "$d" +%Y%m%d%H) + +done + +# Wait until all the jobs complete +count=$i +echo "INFO, waiting for $count task(s) to complete..." +while true; do + for i in "${!PIDS[@]}"; do + if [ "${actives[$i]}" -eq 0 ] ; then + continue + fi + pid="${PIDS[$i]}" + # See if pid is still running + ps --pid "$pid" > /dev/null + if [ "$?" -ne 0 ] ; then # ps doesn't see it, so it terminated + wait "$pid" + return_code="$?" + actives[$i]=0 + count=$((count-1)) + if [ "${return_code}" -ne 0 ] ; then + echo "WARN, SMAP_E_OPL ${yyyymmddhh[$i]} failed around `date`" + else + echo "INFO, SMAP_E_OPL ${yyyymmddhh[$i]} finished with no reported error at `date`" + fi + if [ "$count" -gt 0 ] ; then + echo "INFO, Waiting for $count task(s) to complete..." + fi + fi + done + # See if we are all done. Assume we are, and correct if we are not. + alldone=1 + for i in "${!actives[@]}"; do + if [ "${actives[$i]}" -eq 1 ] ; then + alldone=0 + fi + done + if [ "${alldone}" -eq 1 ] ; then + break + fi +done +unset PIDS +unset actives +unset yyyymmddhh + +# The end +exit 0 + From 432b127f0081b8b509a94ee373eea4afe9f930be Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Fri, 26 Jan 2024 14:10:33 -0500 Subject: [PATCH 294/328] update lis.config.adoc --- lis/configs/lis.config.adoc | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index c775615a8..031d04caf 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -6559,7 +6559,7 @@ MRMS mask directory: ./input/MASKS/ AWRAL forcing directory: ./INPUT/AWRAL.FORCING AWRAL domain x-dimension size: 841 AWRAL domain y-dimension size: 681 -.... +...` specifies the . [[sssec_plumber2forcing,PLUMBER2]] ==== PLUMBER2 @@ -6650,11 +6650,25 @@ run mode. Currently, only the forecast mode is supported. `MOGREPS-G forecast number of ensemble members:` specifies the number of ensembles of the MOGREPS-G forecast forcing data. +`Apply MOGREPS-G precipitation bias correction:` specifies whether to enable the +precipitation bias correction. Acceptable values are: + +|==== +|Value | Description + +|0 | Do not enable +|1 | Enable +|==== + +`MOGREPS-G model CDF file:` specifies the location of the MOGREPS-G model CDF file. + .Example _lis.config_ entry .... MOGREPS-G forecast forcing directory: ./MOGREPS-G MOGREPS-G forecast run mode: forecast # forecast | analysis MOGREPS-G forecast number of ensemble members: 18 +Apply MOGREPS-G precipitation bias correction: 1 #enter 1 - use; or 0 +MOGREPS-G model CDF file: ./input/cdf/MOGREPS_G_leadtime_cdf_10km.nc .... [[ssec_lsm,Land surface models]] From 90f91f69697e707a88f944d709257e9bf454b79f Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Fri, 26 Jan 2024 14:18:13 -0500 Subject: [PATCH 295/328] fix lis.config.adoc --- lis/configs/lis.config.adoc | 239 ++---------------------------------- 1 file changed, 10 insertions(+), 229 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 031d04caf..3f9ed1881 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -189,33 +189,6 @@ Land surface model: Noah.2.7.1 .... -`Number of subLSMs:` specifies the number of sub-level LSMs -or specialized models that may interface with other LSMs in LIS. -Entry here can be set to 1 with having a surface model type -specified, such as "LSM", and set to 1. - -.Example _lis.config_ entry -.... -Number of subLSMs: 1 -.... - -`subLSM models:` specifies the sub-level land surface model to run. -Acceptable values are: - -|==== -|Value | Description - -|none | template lsm -|Crocus8.1 | Crocus version 8.1 snow model -|SnowModel | Glen Liston's SnowModel snow model -|==== - -.Example _lis.config_ entry -.... -subLSM models: "Crocus8.1" -.... - - `Lake model:` specifies the lake model to run. Acceptable values are: @@ -351,7 +324,6 @@ Acceptable values for the sources are: |"`GLDAS`" | GLDAS |"`GFS`" | GFS |"`MERRA2`" | MERRA2 -|"`GEOS-IT`" | GEOS-IT |"`CMAP`" | CMAP |"`TRMM 3B42RT`" | TRMM 3B42RT |"`TRMM 3B42RTV7`" | TRMM 3B42RTV7 @@ -414,8 +386,6 @@ Acceptable values are: |"`none`" | Do not apply topographic correction for forcing |"`lapse-rate`" | Use lapse rate correction for forcing |"`slope-aspect`" | Apply slope-aspect correction for forcing -|"`lapse-rate and slope-aspect`" | Apply both lapse-rate and slope-aspect corrections -|"`micromet`" | Apply Glen Liston's MicroMet corrections to forcing fields |==== .Example _lis.config_ entry @@ -666,18 +636,6 @@ AGRMET area of data: GLOBAL .... ==== -`Number of dimensions in the lat/lon output fields:` specifies the number of dimensions to use when writing the latitude and longitude fields of the LIS output. This is an optional entry. If this entry is not used, LIS will attempt to write the lat/lon fields in 1D. If the projection being used is not compatible with 1D, LIS will write in 2D. -Acceptable values are: -|==== -|Value | Description -|"1D" | 1 dimensional latitude and longitude output - (Note: Only the latlon projection supports 1D output) -|"2D" | 2 dimensional latitude and longitude output -|==== -.Example _lis.config_ entry -.... -Number of dimensions in the lat/lon output fields: "1D" -.... `Enable output statistics:` specifies whether to write the ASCII statistics file for the output data. @@ -3062,12 +3020,10 @@ whether the observation error standard deviation is to be scaled using model and observation standard deviation. `SMAP(NASA) model CDF file:` specifies the name of the model CDF file -(observations will be scaled into this climatology). -Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. +(observations will be scaled into this climatology). `SMAP(NASA) observation CDF file:` specifies the name of the observation CDF file. -Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. `SMAP(NASA) soil moisture number of bins in the CDF:` specifies the number of bins in the CDF. @@ -3143,33 +3099,6 @@ SMAP(NRT) CDF read option: .... -[[sssec_cdftransfersmda,Transfering stratified CDFs from one domain to another]] -==== Transfering stratified CDFs from one domain to another - -`Use CDF transfer for soil moisture data assimilation:` specifies -whether to use CDF transfer method. - -`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory. - -`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory. - -`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF. - -`Reference domain precipitation climatology data source:` specifies the reference domain precipitation climatology generated by LVT. - -`Target domain precipitation climatology data source:` specifies the target domain precipitation climatology generated by LVT. - - -.Example _lis.config_ entry -.... -Use CDF transfer for soil moisture data assimilation: -Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc -Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc -Number of bins in the soil moisture CDF: 100 -Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc -Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc -.... - [[sssec_smapnasavodda,SMAP (NASA) vegetation optical depth assimilation]] ==== SMAP (NASA) vegetation optical depth assimilation @@ -5649,6 +5578,7 @@ GFS domain y-dimension size: 256 GFS number of forcing variables: 10 .... + [[sssec_forcings_MERRA2,MERRA2]] ==== MERRA2 @@ -5704,50 +5634,6 @@ MERRA2 use 2m wind fields: 0 MERRA2 use corrected total precipitation: 1 .... -[[sssec_forcings_GEOS-IT,GEOS-IT]] -==== GEOS-IT - -`GEOS-IT forcing directory:` specifies the location of -the GEOS-IT forcing files. - -Please note that GEOS-IT is currently in production and is -not complete for all calendar years. Also, it is not yet -available outside of NASA`'s NCCS computing platforms. -Also, the topographic or elevation correction option is -supported through the MERRA-2 geopotential terrain height -file. Please also see the latest LDT notes for updates on -how to use this option. - -`GEOS-IT use lowest model level forcing:` specifies whether -to use the lowest model level forcing. -Acceptable values are: - -|==== -|Value | Description - -|0 | Do not use the lowest model level forcing. -|1 | Use the lowest model level forcing. -|==== - -`GEOS-IT use 2m wind fields:` specifies whether to use the -2m diagnosed wind fields. This option will only work if -the lowest model level forcing option is turned off. -Acceptable values are: - -|==== -|Value | Description - -|0 | Do not use the 2m diagnosed wind speed fields. -|1 | Use the 2m diagnosed wind speed fields. -|==== - -.Example _lis.config_ entry -.... -GEOS-IT forcing directory: ./GEOS-IT -GEOS-IT use lowest model level forcing: 1 -GEOS-IT use 2m wind fields: 0 -.... - [[sssec_forcings_ERA5,ERA5]] ==== ERA5 @@ -6002,18 +5888,8 @@ default to the "`final`" product of GPM IMERG. `IMERG version:` specifies the version of the GPM IMERG precipitation forcing files. If no version is specified, -the reader will default to "`V06B`". - -The supported versions of GPM IMERG are: - -|==== -|Version | Product - -|V06B | early, late, final -|V06C | early, late, final -|V06D | early, late, final -|V07A | preliminary support for final -|==== +the reader will default to the latest version of GPM IMERG. +(Currently V06B). .Example _lis.config_ entry .... @@ -6559,7 +6435,7 @@ MRMS mask directory: ./input/MASKS/ AWRAL forcing directory: ./INPUT/AWRAL.FORCING AWRAL domain x-dimension size: 841 AWRAL domain y-dimension size: 681 -...` specifies the . +.... [[sssec_plumber2forcing,PLUMBER2]] ==== PLUMBER2 @@ -6650,8 +6526,8 @@ run mode. Currently, only the forecast mode is supported. `MOGREPS-G forecast number of ensemble members:` specifies the number of ensembles of the MOGREPS-G forecast forcing data. -`Apply MOGREPS-G precipitation bias correction:` specifies whether to enable the -precipitation bias correction. Acceptable values are: +`Apply MOGREPS-G precipitation bias correction:` specifies whether to enable the precipitation +bias correction. Acceptable values are: |==== |Value | Description @@ -6660,7 +6536,7 @@ precipitation bias correction. Acceptable values are: |1 | Enable |==== -`MOGREPS-G model CDF file:` specifies the location of the MOGREPS-G model CDF file. +`MOGREPS-G model CDF file:` specifies the location of the MOGREPS-G model CDF file. .Example _lis.config_ entry .... @@ -9673,103 +9549,6 @@ AWRAL600 initial sd: 0.5 0.5 AWRAL600 initial mleaf: 0.67 0.2 .... - -[[ssec_sublsm,Sublevel land surface models]] -=== Sublevel land surface models - - -[[sssec_sublsm_snowmodel,SnowModel]] -==== SnowModel, Liston - -`SnowModel model timestep:` specifies the timestep for the run. - -See Section <> for a description -of how to specify a time interval. - -`SnowModel restart output interval:` defines the restart -writing interval for Glen Liston's SnowModel model. The typical -value used in the LIS runs is 24 hours (1da). - -See Section <> for a description -of how to specify a time interval. - -`SnowModel restart file:` specifies the SnowModel active -restart file. - -`SnowModel restart file format:` specifies the restart file -format for SnowModel. - -`SnowModel parameter file:` specifies the main SnowModel-specific -input and option parameter configuration file, which is needed -to run SnowModel. - -`SnowModel parameters source option:` specifies if SnowModel will -read in its native binary parameter files from within the SnowModel -code or what is preprocessed in LDT. LDT option supports parallel runs -Acceptable values are: - -|==== -|Value | Description - -|SnowModel | Use SnowModel built-in routines to read in -|LDT | Use the LIS SnowModel main driver to load parameters from LDT. -|==== - -`SnowModel MicroMet input source:` specifies if SnowModel will -read in its own specifically formatted binary or ASCII table forcing -files, or if LIS meteorological forcing fields will be passed in, -with the option to turn on MicroMet topographic-downscaling options -on the LIS metforcing layer side. To turn on "micromet" option in LIS, -set Topographic correction method (met forcing) to micromet. -Acceptable values are: - -|==== -|Value | Description - -|SnowModel | Readin specific SnowModel forcing files -|LIS | LIS-based meteorological forcing fields -|==== - -`SnowModel preprocess code option:` specifies the turning on -of the SnowModel built-in preprocess code module, which performs -initial preprocessing of gridded data for running the model. -Currently, only option supported is 1 (on). - -`Write out SnowModel forcing file fields:` specifies if you -want to write out SnowModel forcing fields generated by reading -in SnowModel-specific forcing files. This option is mainly -used when SnowModel MicroMet input source is set to SnowModel -and you run SnowModel in offline subLSM mode (no other LSMs or models -run with this submodel). Selecting 1 activates this option, and -0 indicates off. - -`SnowModel number of snow layers:` specifies the number of snow -layers that would be allowed to build within the SnowModel runtime. -This option is currently set to 1 within LIS, and must also be -activated and increased by setting the multiple layer snow model -scheme in the SnowModel option parameter file (snowmodel.par). - -`SnowModel initial snow water equivalent:` specifies the initial -snow water equivalent (SWE) value. This is currently set to -default values found in the coldstart mode for model restart reads, -based on a SnowModel initialization approach. - -.Example _lis.config_ entry -.... -SnowModel model timestep: 1hr -SnowModel restart file: ./none -SnowModel restart output interval: 1mo -SnowModel restart file format: "netcdf" -SnowModel parameter file: ./snowmodel.par -SnowModel parameters source option: LDT -SnowModel MicroMet input source: LIS -Write out SnowModel forcing file fields: 1 -SnowModel preprocess code option: 1 -SnowModel number of snow layers: 1 -SnowModel initial snow water equivalent: 0.0 -.... - - [[ssec_lakes,Lake models]] === Lake models @@ -10792,6 +10571,7 @@ Acceptable values are: `CROCUS81 initial SNOWMAK_dz:` specifies the initial depth from snow making process. + .Example _lis.config_ entry .... CROCUS81 model timestep: 15mn @@ -11073,6 +10853,7 @@ sample MODEL_OUTPUT_LIST.TBL file for the complete specification. Model output attributes file: './MODEL_OUTPUT_LIST.TBL' .... + [[ssec_timeinterval,Defining a time interval]] === Defining a time interval From 6ca659123b1d832c6a5035a3b88e70e8a7b3e4e1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 29 Jan 2024 11:35:09 -0500 Subject: [PATCH 296/328] Modified script to support three LSMs. --- .../SMAP_E_OPL/run_smap_e_opl_discover.sh | 35 ++++++++++++++----- 1 file changed, 26 insertions(+), 9 deletions(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 31218d5d6..654c97344 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -15,11 +15,12 @@ # queueing system. # # USAGE: run_smap_e_opl_discover.sh $startdate $starthour $enddate \ -# $endhour +# $endhour $lsm # where $startdate and $enddate specify the inclusive UTC -# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD), -# and $starthour and $endhour specify the hours of the respective -# dates (formatted HH). +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD); +# $starthour and $endhour specify the hours of the respective +# dates (formatted HH); and $lsm is the LSM name, used to select +# the ldt.config template file. # # Based on Korn shell script provided by Pang-Wei Liu. # @@ -66,6 +67,9 @@ if [ -z "$4" ] ; then echo "ERROR, Missing end hour for SMAP_E_OPL retrievals!" exit 1 fi +if [ -z "$5" ] ; then + echo "ERROR, missing LSM option!" && exit 1 +fi # Use the command line arguments to set start and end datetime limits. # Sanity check and report errors if found. @@ -84,10 +88,24 @@ d="$start_dt" cur_yyyymmddhh=$(date -d "$start_dt" +%Y%m%d%H) end_yyyymmddhh=$(date -d "$end_dt" +%Y%m%d%H) -# Other sanity checks -if [ ! -e $TMPLDIR/ldt.config.smapeopl.tmpl ] ; then - echo "ERR, $TMPLDIR/ldt.config.smap.tmpl not found!" && exit 1 +# Use the LSM command line argument to select the appropriate ldt.config +# template. +lsm="$5" +if [ "$lsm" = "noah" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noah.tmpl" +elif [ "$lsm" = "noahmp" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noahmp.tmpl" +elif [ "$lsm" = "jules" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.jules.tmpl" +else + echo "ERR, invalid LSM option, must be noah, noahmp, or jules" + exit 1 +fi +if [ ! -e $tmplfile ] ; then + echo "ERR, $tmplfile not found!" && exit 1 fi + +# Other sanity checks if [ ! -e $BINDIR/LDT ] ; then echo "ERR, $BINDIR/LDT does not exist!" && exit 1 fi @@ -106,7 +124,7 @@ while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do # Update ldt.config file $SCRIPTDIR/customize_ldt_smapeopl_config.py "$cur_yyyymmddhh" \ - $TMPLDIR/ldt.config.smapeopl.tmpl $i || exit 1 + "$tmplfile" $i || exit 1 # Run LDT srun --ntasks=1 --nodes=1 --exclusive \ @@ -166,4 +184,3 @@ unset yyyymmddhh # The end exit 0 - From ded64080e6d4648e4ec3bc6b31bbba585e2d027f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 29 Jan 2024 11:36:18 -0500 Subject: [PATCH 297/328] Added first-guess templates for SMAP_E_OPL retrievals. --- .../SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl | 53 ++++++++++++++++++ .../SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl | 55 +++++++++++++++++++ .../ldt.config.smapeopl.noahmp.tmpl | 53 ++++++++++++++++++ 3 files changed, 161 insertions(+) create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl new file mode 100755 index 000000000..f692e8636 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl @@ -0,0 +1,53 @@ +# == LDT Main Entry Options == + +LDT running mode: "OPL E SMAP soil moisture retrieval" #"LSM parameter processing" # LDT type of run-mode (top-level option) +LDT diagnostic file: ldtlog.2021070200 + + +# Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021070200 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +SMAP_E_OPL LIS soil temperature directory: input/jules50/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/jules50/dec2021 +#SMAP_E_OPL LIS soil temperature directory: input/Jules50_OL + +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/jules50_daily_statistics_15obs.nc +SMAP_E_OPL LIS snow directory: input/USAFSI +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 1 + +# Legacy settings that must be in config file +Processed LSM parameter filename: lis_input.10k.global.ps41.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT output directory: LDTOUT +Undefined value: -9999.0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl new file mode 100755 index 000000000..0bd086692 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl @@ -0,0 +1,55 @@ + +LDT running mode: "OPL E SMAP soil moisture retrieval" +LDT diagnostic file: ldtlog.2021071519 + +#Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021071519 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +#SMAP_E_OPL L1B data directory: input/SMAP_L1B_historical +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +#SMAP_E_OPL L1B data directory: input/SMAP_L1B_fake +#SMAP_E_OPL L1B data type: 2 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) + +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +#SMAP_E_OPL LIS soil temperature directory: input/Noah39_OL +SMAP_E_OPL LIS soil temperature directory: input/noah39/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/noah39/dec2021 +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/noah39_daily_statistics_15obs.nc +#SMAP_E_OPL LIS snow directory: input/Noah39_snow +SMAP_E_OPL LIS snow directory: input/USAFSI +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 0 + +# Legacy settings that must in the config file. +Processed LSM parameter filename: input/lis_input.global.noah39.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT output directory: LDTOUT +Undefined value: -9999.0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl new file mode 100755 index 000000000..dfb0c594f --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl @@ -0,0 +1,53 @@ +#Overall driver options +LDT running mode: "OPL E SMAP soil moisture retrieval" + +#Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021071519 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +SMAP_E_OPL LIS soil temperature directory: input/noahmp401/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/noahmp401/dec2021 +#SMAP_E_OPL LIS soil temperature directory: input/Noahmp401_OL + +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/noahmp401_daily_statistics_15obs.nc +SMAP_E_OPL LIS snow directory: input/USAFSI + +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 1 + +# Legacy entries that must be in the file. +Processed LSM parameter filename: ./output/lis_input.global.noahmp401.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT diagnostic file: ldtlog.2021071519 +LDT output directory: LDTOUT +Undefined value: -9999.0 From b5baf444313209447d636956b44649063feca7bc Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 29 Jan 2024 12:15:47 -0500 Subject: [PATCH 298/328] Updated comments. It turns out YYYYMMDD works as an input startdate or enddate. --- ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 654c97344..5dfc1a333 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -17,10 +17,10 @@ # USAGE: run_smap_e_opl_discover.sh $startdate $starthour $enddate \ # $endhour $lsm # where $startdate and $enddate specify the inclusive UTC -# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD); -# $starthour and $endhour specify the hours of the respective -# dates (formatted HH); and $lsm is the LSM name, used to select -# the ldt.config template file. +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD +# or YYYYMMDD); $starthour and $endhour specify the hours of the +# respective dates (formatted HH); and $lsm is the LSM name, used +# to select the ldt.config template file. # # Based on Korn shell script provided by Pang-Wei Liu. # From 139bf07afa7fb1773a55ddfe963786d41ad87244 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Mon, 29 Jan 2024 13:18:02 -0500 Subject: [PATCH 299/328] Updated error message for bad LSM selection. --- ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 5dfc1a333..4bd2c6b97 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -98,7 +98,7 @@ elif [ "$lsm" = "noahmp" ] ; then elif [ "$lsm" = "jules" ] ; then tmplfile="$TMPLDIR/ldt.config.smapeopl.jules.tmpl" else - echo "ERR, invalid LSM option, must be noah, noahmp, or jules" + echo "ERR, invalid LSM option, expected noah, noahmp, or jules; got $lsm" exit 1 fi if [ ! -e $tmplfile ] ; then From f545dc3679f841cfc93de9d925c20bc9671be2ee Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 1 Feb 2024 10:13:46 -0500 Subject: [PATCH 300/328] Tweaks to satisfy GNU and Intel compilers with strict checks. --- lis/metforcing/mogreps_g/get_cdf_params.F90 | 1 - lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 | 1 + lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 | 4 ++-- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/lis/metforcing/mogreps_g/get_cdf_params.F90 b/lis/metforcing/mogreps_g/get_cdf_params.F90 index 7baec6b5f..b63fb041e 100644 --- a/lis/metforcing/mogreps_g/get_cdf_params.F90 +++ b/lis/metforcing/mogreps_g/get_cdf_params.F90 @@ -22,7 +22,6 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) !USES: use LIS_coreMod use LIS_logMod - use mogrepsg_forcingMod, only : mogrepsg_struc #if (defined USE_NETCDF3 || defined USE_NETCDF4) use netcdf #endif diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 index e90cb40b5..98dc9d04a 100644 --- a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -137,6 +137,7 @@ subroutine init_mogrepsg(findex) external :: bilinear_interp_input external :: conserv_interp_input external :: neighbor_interp_input + external :: get_cdf_params write(LIS_logunit,*) "[INFO] Initializing the MOGREPS-G forecast inputs " diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 index efb0b4d8f..ea6537c25 100644 --- a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -244,7 +244,7 @@ subroutine timeinterp_mogrepsg(n,findex) if (mogrepsg_struc(n)%bc == 1) then !1 - use; or 0 if(mogrepsg_struc(n)%pcp_bc(m,index1).ne.LIS_rc%udef) then ! account for the accum fields - pcp(tid)=mogrepsg_struc(n)%pcp_bc(m,index1)/(3600*3) + pcp(tid)=mogrepsg_struc(n)%pcp_bc(m,index1)/real(3600*3) if(pcp(tid).lt.0) then pcp(tid) = 0.0 endif @@ -252,7 +252,7 @@ subroutine timeinterp_mogrepsg(n,findex) else !don't apply bias correction if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then ! account for the accum fields - pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/(3600*3) + pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/real(3600*3) if(pcp(tid).lt.0) then pcp(tid) = 0.0 endif From 663ae0b16b3a15e237bd19cdda750f4e96d1c055 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 1 Feb 2024 10:51:16 -0500 Subject: [PATCH 301/328] Restored earlier lis.config entries unrelated to MOGREPS-G. --- lis/configs/lis.config.adoc | 224 +++++++++++++++++++++++++++++++++++- 1 file changed, 222 insertions(+), 2 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 3f9ed1881..47a5991ea 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -188,6 +188,33 @@ endif::devonly[] Land surface model: Noah.2.7.1 .... +`Number of subLSMs:` specifies the number of sub-level LSMs +or specialized models that may interface with other LSMs in LIS. +Entry here can be set to 1 with having a surface model type +specified, such as "LSM", and set to 1. + +.Example _lis.config_ entry +.... +Number of subLSMs: 1 +.... + +`subLSM models:` specifies the sub-level land surface model to run. +Acceptable values are: + +|==== +|Value | Description + +|none | template lsm +|Crocus8.1 | Crocus version 8.1 snow model +|SnowModel | Glen Liston's SnowModel snow model +|==== + +.Example _lis.config_ entry +.... +subLSM models: "Crocus8.1" +.... + + `Lake model:` specifies the lake model to run. Acceptable values are: @@ -324,6 +351,7 @@ Acceptable values for the sources are: |"`GLDAS`" | GLDAS |"`GFS`" | GFS |"`MERRA2`" | MERRA2 +|"`GEOS-IT`" | GEOS-IT |"`CMAP`" | CMAP |"`TRMM 3B42RT`" | TRMM 3B42RT |"`TRMM 3B42RTV7`" | TRMM 3B42RTV7 @@ -386,6 +414,8 @@ Acceptable values are: |"`none`" | Do not apply topographic correction for forcing |"`lapse-rate`" | Use lapse rate correction for forcing |"`slope-aspect`" | Apply slope-aspect correction for forcing +|"`lapse-rate and slope-aspect`" | Apply both lapse-rate and slope-aspect corrections +|"`micromet`" | Apply Glen Liston's MicroMet corrections to forcing fields |==== .Example _lis.config_ entry @@ -636,6 +666,18 @@ AGRMET area of data: GLOBAL .... ==== +`Number of dimensions in the lat/lon output fields:` specifies the number of dimensions to use when writing the latitude and longitude fields of the LIS output. This is an optional entry. If this entry is not used, LIS will attempt to write the lat/lon fields in 1D. If the projection being used is not compatible with 1D, LIS will write in 2D. +Acceptable values are: +|==== +|Value | Description +|"1D" | 1 dimensional latitude and longitude output + (Note: Only the latlon projection supports 1D output) +|"2D" | 2 dimensional latitude and longitude output +|==== +.Example _lis.config_ entry +.... +Number of dimensions in the lat/lon output fields: "1D" +.... `Enable output statistics:` specifies whether to write the ASCII statistics file for the output data. @@ -3021,9 +3063,11 @@ and observation standard deviation. `SMAP(NASA) model CDF file:` specifies the name of the model CDF file (observations will be scaled into this climatology). +Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. `SMAP(NASA) observation CDF file:` specifies the name of the observation CDF file. +Note: Soil moisture CDF grouped (stratified) by land cover or precipitation climatology or both simultaneously also can be used here. `SMAP(NASA) soil moisture number of bins in the CDF:` specifies the number of bins in the CDF. @@ -3054,6 +3098,32 @@ SMAP(NASA) soil moisture number of bins in the CDF: SMAP(NASA) CDF read option: .... +[[sssec_cdftransfersmda,Transfering stratified CDFs from one domain to another]] +==== Transfering stratified CDFs from one domain to another + +`Use CDF transfer for soil moisture data assimilation:` specifies +whether to use CDF transfer method. + +`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory. + +`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory. + +`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF. + +`Reference domain precipitation climatology data source:` specifies the reference domain precipitation climatology generated by LVT. + +`Target domain precipitation climatology data source:` specifies the target domain precipitation climatology generated by LVT. + + +.Example _lis.config_ entry +.... +Use CDF transfer for soil moisture data assimilation: +Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc +Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc +Number of bins in the soil moisture CDF: 100 +Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc +Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc +.... [[sssec_smapnrtsmda,SMAP (NRT) soil moisture assimilation]] ==== SMAP (NRT) soil moisture assimilation @@ -5634,6 +5704,50 @@ MERRA2 use 2m wind fields: 0 MERRA2 use corrected total precipitation: 1 .... +[[sssec_forcings_GEOS-IT,GEOS-IT]] +==== GEOS-IT + +`GEOS-IT forcing directory:` specifies the location of +the GEOS-IT forcing files. + +Please note that GEOS-IT is currently in production and is +not complete for all calendar years. Also, it is not yet +available outside of NASA`'s NCCS computing platforms. +Also, the topographic or elevation correction option is +supported through the MERRA-2 geopotential terrain height +file. Please also see the latest LDT notes for updates on +how to use this option. + +`GEOS-IT use lowest model level forcing:` specifies whether +to use the lowest model level forcing. +Acceptable values are: + +|==== +|Value | Description + +|0 | Do not use the lowest model level forcing. +|1 | Use the lowest model level forcing. +|==== + +`GEOS-IT use 2m wind fields:` specifies whether to use the +2m diagnosed wind fields. This option will only work if +the lowest model level forcing option is turned off. +Acceptable values are: + +|==== +|Value | Description + +|0 | Do not use the 2m diagnosed wind speed fields. +|1 | Use the 2m diagnosed wind speed fields. +|==== + +.Example _lis.config_ entry +.... +GEOS-IT forcing directory: ./GEOS-IT +GEOS-IT use lowest model level forcing: 1 +GEOS-IT use 2m wind fields: 0 +.... + [[sssec_forcings_ERA5,ERA5]] ==== ERA5 @@ -5888,8 +6002,18 @@ default to the "`final`" product of GPM IMERG. `IMERG version:` specifies the version of the GPM IMERG precipitation forcing files. If no version is specified, -the reader will default to the latest version of GPM IMERG. -(Currently V06B). +the reader will default to "`V06B`". + +The supported versions of GPM IMERG are: + +|==== +|Version | Product + +|V06B | early, late, final +|V06C | early, late, final +|V06D | early, late, final +|V07A | preliminary support for final +|==== .Example _lis.config_ entry .... @@ -9549,6 +9673,102 @@ AWRAL600 initial sd: 0.5 0.5 AWRAL600 initial mleaf: 0.67 0.2 .... +[[ssec_sublsm,Sublevel land surface models]] +=== Sublevel land surface models + + +[[sssec_sublsm_snowmodel,SnowModel]] +==== SnowModel, Liston + +`SnowModel model timestep:` specifies the timestep for the run. + +See Section <> for a description +of how to specify a time interval. + +`SnowModel restart output interval:` defines the restart +writing interval for Glen Liston's SnowModel model. The typical +value used in the LIS runs is 24 hours (1da). + +See Section <> for a description +of how to specify a time interval. + +`SnowModel restart file:` specifies the SnowModel active +restart file. + +`SnowModel restart file format:` specifies the restart file +format for SnowModel. + +`SnowModel parameter file:` specifies the main SnowModel-specific +input and option parameter configuration file, which is needed +to run SnowModel. + +`SnowModel parameters source option:` specifies if SnowModel will +read in its native binary parameter files from within the SnowModel +code or what is preprocessed in LDT. LDT option supports parallel runs +Acceptable values are: + +|==== +|Value | Description + +|SnowModel | Use SnowModel built-in routines to read in +|LDT | Use the LIS SnowModel main driver to load parameters from LDT. +|==== + +`SnowModel MicroMet input source:` specifies if SnowModel will +read in its own specifically formatted binary or ASCII table forcing +files, or if LIS meteorological forcing fields will be passed in, +with the option to turn on MicroMet topographic-downscaling options +on the LIS metforcing layer side. To turn on "micromet" option in LIS, +set Topographic correction method (met forcing) to micromet. +Acceptable values are: + +|==== +|Value | Description + +|SnowModel | Readin specific SnowModel forcing files +|LIS | LIS-based meteorological forcing fields +|==== + +`SnowModel preprocess code option:` specifies the turning on +of the SnowModel built-in preprocess code module, which performs +initial preprocessing of gridded data for running the model. +Currently, only option supported is 1 (on). + +`Write out SnowModel forcing file fields:` specifies if you +want to write out SnowModel forcing fields generated by reading +in SnowModel-specific forcing files. This option is mainly +used when SnowModel MicroMet input source is set to SnowModel +and you run SnowModel in offline subLSM mode (no other LSMs or models +run with this submodel). Selecting 1 activates this option, and +0 indicates off. + +`SnowModel number of snow layers:` specifies the number of snow +layers that would be allowed to build within the SnowModel runtime. +This option is currently set to 1 within LIS, and must also be +activated and increased by setting the multiple layer snow model +scheme in the SnowModel option parameter file (snowmodel.par). + +`SnowModel initial snow water equivalent:` specifies the initial +snow water equivalent (SWE) value. This is currently set to +default values found in the coldstart mode for model restart reads, +based on a SnowModel initialization approach. + +.Example _lis.config_ entry +.... +SnowModel model timestep: 1hr +SnowModel restart file: ./none +SnowModel restart output interval: 1mo +SnowModel restart file format: "netcdf" +SnowModel parameter file: ./snowmodel.par +SnowModel parameters source option: LDT +SnowModel MicroMet input source: LIS +Write out SnowModel forcing file fields: 1 +SnowModel preprocess code option: 1 +SnowModel number of snow layers: 1 +SnowModel initial snow water equivalent: 0.0 +.... + + [[ssec_lakes,Lake models]] === Lake models From 47c1e6183d7b20f6eee31abeb92ad02fbfdd27d6 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 1 Feb 2024 10:54:05 -0500 Subject: [PATCH 302/328] Fixed cut-and-paste. --- lis/configs/lis.config.adoc | 52 ++++++++++++++++++------------------- 1 file changed, 26 insertions(+), 26 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 47a5991ea..9f5fdac6f 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -3098,32 +3098,6 @@ SMAP(NASA) soil moisture number of bins in the CDF: SMAP(NASA) CDF read option: .... -[[sssec_cdftransfersmda,Transfering stratified CDFs from one domain to another]] -==== Transfering stratified CDFs from one domain to another - -`Use CDF transfer for soil moisture data assimilation:` specifies -whether to use CDF transfer method. - -`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory. - -`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory. - -`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF. - -`Reference domain precipitation climatology data source:` specifies the reference domain precipitation climatology generated by LVT. - -`Target domain precipitation climatology data source:` specifies the target domain precipitation climatology generated by LVT. - - -.Example _lis.config_ entry -.... -Use CDF transfer for soil moisture data assimilation: -Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc -Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc -Number of bins in the soil moisture CDF: 100 -Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc -Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc -.... [[sssec_smapnrtsmda,SMAP (NRT) soil moisture assimilation]] ==== SMAP (NRT) soil moisture assimilation @@ -3168,6 +3142,32 @@ SMAP(NRT) soil moisture number of bins in the CDF: SMAP(NRT) CDF read option: .... +[[sssec_cdftransfersmda,Transfering stratified CDFs from one domain to another]] +==== Transfering stratified CDFs from one domain to another + +`Use CDF transfer for soil moisture data assimilation:` specifies +whether to use CDF transfer method. + +`Reference domain model CDF file:` specifies the reference domain model CDF name and data directory. + +`Reference domain obs CDF file:` specifies the reference domain obs CDF name and data directory. + +`Number of bins in the soil moisture CDF:` specifies the number of bins in the CDF. + +`Reference domain precipitation climatology data source:` specifies the reference domain precipitation climatology generated by LVT. + +`Target domain precipitation climatology data source:` specifies the target domain precipitation climatology generated by LVT. + + +.Example _lis.config_ entry +.... +Use CDF transfer for soil moisture data assimilation: +Reference domain model CDF file: ref_model_cdf_forcing_diff/stratified_cdf_noahmp401.nc +Reference domain obs CDF file: ref_obs_cdf_forcing_diff/stratified_cdf_smapobs.nc +Number of bins in the soil moisture CDF: 100 +Reference domain precipitation climatology data source: Precip.climo.us.nldas2/LVT_MEAN_FINAL.202201010000.d01.nc +Target domain precipitation climatology data source: Precip.climo.eu.merra/LVT_MEAN_FINAL.202201010000.d01.nc +.... [[sssec_smapnasavodda,SMAP (NASA) vegetation optical depth assimilation]] ==== SMAP (NASA) vegetation optical depth assimilation From bb1a6f33acdb0d2850584efafa389bdadb5ccdc7 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 1 Feb 2024 10:57:22 -0500 Subject: [PATCH 303/328] Further tweaks to ldt.config.adoc. --- lis/configs/lis.config.adoc | 4 ---- 1 file changed, 4 deletions(-) diff --git a/lis/configs/lis.config.adoc b/lis/configs/lis.config.adoc index 9f5fdac6f..39cb41f6c 100644 --- a/lis/configs/lis.config.adoc +++ b/lis/configs/lis.config.adoc @@ -215,7 +215,6 @@ subLSM models: "Crocus8.1" .... - `Lake model:` specifies the lake model to run. Acceptable values are: @@ -5648,7 +5647,6 @@ GFS domain y-dimension size: 256 GFS number of forcing variables: 10 .... - [[sssec_forcings_MERRA2,MERRA2]] ==== MERRA2 @@ -10791,7 +10789,6 @@ Acceptable values are: `CROCUS81 initial SNOWMAK_dz:` specifies the initial depth from snow making process. - .Example _lis.config_ entry .... CROCUS81 model timestep: 15mn @@ -11073,7 +11070,6 @@ sample MODEL_OUTPUT_LIST.TBL file for the complete specification. Model output attributes file: './MODEL_OUTPUT_LIST.TBL' .... - [[ssec_timeinterval,Defining a time interval]] === Defining a time interval From 82f8083c5e9561254a951c20bb9f65fef639a429 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 1 Feb 2024 15:05:19 -0500 Subject: [PATCH 304/328] Some style updates to make the code easier to read. Identical results are given to older GNU and Intel compiler runs. --- lis/metforcing/mogreps_g/get_cdf_params.F90 | 144 ++++---- lis/metforcing/mogreps_g/get_mogrepsg.F90 | 202 +++++++----- .../mogreps_g/mogrepsg_forcingMod.F90 | 58 ++-- lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 | 75 +++-- .../mogreps_g/timeinterp_mogrepsg.F90 | 308 ++++++++++-------- 5 files changed, 438 insertions(+), 349 deletions(-) diff --git a/lis/metforcing/mogreps_g/get_cdf_params.F90 b/lis/metforcing/mogreps_g/get_cdf_params.F90 index b63fb041e..5d9c0fc07 100644 --- a/lis/metforcing/mogreps_g/get_cdf_params.F90 +++ b/lis/metforcing/mogreps_g/get_cdf_params.F90 @@ -28,82 +28,85 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) implicit none - !ARGUMENTS: + !ARGUMENTS: integer, intent(in) :: n character(len=*), intent(in) :: fname integer, intent(in) :: month ! month of year (1-12) - !EOP - logical :: file_exists - integer :: ftn - integer :: param_a_id, param_b_id, mean_id, std_id, ngrid_id, nlead_id - integer :: ngrid, nlead - integer :: r, c, nc, c1, r1, gid, l - real,allocatable :: param_hires(:,:) - real,allocatable :: param_hires_2d(:,:) - real :: param_a(LIS_rc%ngrid(n),8) !8: lead time - real :: param_b(LIS_rc%ngrid(n),8) - real :: mean(LIS_rc%ngrid(n),8) - real :: std(LIS_rc%ngrid(n),8) - - ! check file + !EOP + logical :: file_exists + integer :: ftn + integer :: param_a_id, param_b_id, mean_id, & + std_id, ngrid_id, nlead_id + integer :: ngrid, nlead + integer :: r, c, nc, c1, r1, gid, l + real, allocatable :: param_hires(:,:) + real, allocatable :: param_hires_2d(:,:) + real :: param_a(LIS_rc%ngrid(n),8) !8:lead time + real :: param_b(LIS_rc%ngrid(n),8) + real :: mean(LIS_rc%ngrid(n),8) + real :: std(LIS_rc%ngrid(n),8) + + ! check file inquire(file=fname, exist=file_exists) - if(.not. file_exists) then - write(LIS_logunit,*) '[ERR] ',trim(fname)//' does not exist' + if (.not. file_exists) then + write(LIS_logunit,*) '[ERR] ', trim(fname) // ' does not exist' call LIS_endrun() endif - write(LIS_logunit,*)'[INFO] Getting MOGREPS-G bias correction parameters ', trim(fname) + write(LIS_logunit,*) & + '[INFO] Getting MOGREPS-G bias correction parameters ', trim(fname) call LIS_verify(nf90_open(path=trim(fname), mode=NF90_NOWRITE, & ncid=ftn), 'nf90_open failed in get_cdf_params') call LIS_verify(nf90_inq_dimid(ftn, "ngrid", ngrid_id), & - 'nf90_inq_dimid failed for ngrid in get_cdf_params') + 'nf90_inq_dimid failed for ngrid in get_cdf_params') call LIS_verify(nf90_inquire_dimension(ftn, ngrid_id, len=ngrid),& - 'nf90_inquire_dimension failed for ngrid in get_cdf_params') + 'nf90_inquire_dimension failed for ngrid in get_cdf_params') - if(LIS_rc%gnc(n)*LIS_rc%gnr(n) .ne. ngrid) then - write(LIS_logunit,*) 'The input dimensions of the '//trim(fname) + if (LIS_rc%gnc(n)*LIS_rc%gnr(n) .ne. ngrid) then + write(LIS_logunit,*) '[ERR] The input dimensions of the '//trim(fname) write(LIS_logunit,*) '(',ngrid,')' - write(LIS_logunit,*) 'does not match the dimensions in the LIS parameter file' + write(LIS_logunit,*) & + 'does not match the dimensions in the LIS parameter file' write(LIS_logunit,*) '(',LIS_rc%gnc(n)*LIS_rc%gnr(n),')' call LIS_endrun() endif call LIS_verify(nf90_inq_dimid(ftn, "lead_time", nlead_id), & - 'nf90_inq_dimid failed for nlead in get_cdf_params') + 'nf90_inq_dimid failed for nlead in get_cdf_params') call LIS_verify(nf90_inquire_dimension(ftn, nlead_id, len=nlead),& - 'nf90_inquire_dimension failed for nlead in get_cdf_params') + 'nf90_inquire_dimension failed for nlead in get_cdf_params') - allocate(param_hires(LIS_rc%gnc(n)*LIS_rc%gnr(n),nlead)) + allocate(param_hires(LIS_rc%gnc(n)*LIS_rc%gnr(n),nlead)) allocate(param_hires_2d(LIS_rc%gnc(n),LIS_rc%gnr(n))) param_hires = -9999.0 param_hires_2d = -9999.0 - + ! read param_a - call LIS_verify(nf90_inq_varid(ftn,'cdf_param_a',param_a_id), & + call LIS_verify(nf90_inq_varid(ftn, 'cdf_param_a', param_a_id), & 'nf90_inq_varid failed for cdf_param_a in get_cdf_params') call LIS_verify(nf90_get_var(ftn, param_a_id, param_hires, & - start=(/1,1,month/), count=(/ngrid,nlead,1/)),& + start=(/1,1,month/), count=(/ngrid,nlead,1/)), & 'nf90_get_var failed for cdf_param_a in get_cdf_params') - - do l=1,nlead + + do l = 1, nlead ! 1D -> 2D - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + do r = 1, LIS_rc%gnr(n) + do c = 1, LIS_rc%gnc(n) + param_hires_2d(c,r) = param_hires(c+(r-1)*LIS_rc%gnc(n),l) enddo enddo !subsets the data for each processor's domain nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 - do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) - do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) - c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 - r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + do r = LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) + do c = LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c - LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r - LIS_nss_halo_ind(n,LIS_localPet+1)+1 gid = LIS_domain(n)%gindex(c1,r1) - if(gid.ne.-1) then + if (gid .ne. -1) then param_a(gid,l) = param_hires_2d(c,r) endif enddo @@ -111,28 +114,28 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) enddo ! read param_b - call LIS_verify(nf90_inq_varid(ftn,'cdf_param_b',param_b_id), & + call LIS_verify(nf90_inq_varid(ftn, 'cdf_param_b', param_b_id), & 'nf90_inq_varid failed for cdf_param_b in get_cdf_params') call LIS_verify(nf90_get_var(ftn, param_b_id, param_hires, & start=(/1,1,month/), count=(/ngrid,nlead,1/)),& 'nf90_get_var failed for cdf_param_b in get_cdf_params') - do l=1,nlead + do l = 1, nlead ! 1D -> 2D - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + do r = 1, LIS_rc%gnr(n) + do c = 1,LIS_rc%gnc(n) + param_hires_2d(c,r) = param_hires(c+(r-1)*LIS_rc%gnc(n),l) enddo enddo !subsets the data for each processor's domain nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 - do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) - do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) - c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 - r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + do r = LIS_nss_halo_ind(n,LIS_localPet+1), LIS_nse_halo_ind(n,LIS_localPet+1) + do c = LIS_ews_halo_ind(n,LIS_localPet+1), LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c - LIS_ews_halo_ind(n,LIS_localPet+1) + 1 + r1 = r - LIS_nss_halo_ind(n,LIS_localPet+1) + 1 gid = LIS_domain(n)%gindex(c1,r1) - if(gid.ne.-1) then + if (gid.ne.-1) then param_b(gid,l) = param_hires_2d(c,r) endif enddo @@ -140,28 +143,28 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) enddo ! read mean - call LIS_verify(nf90_inq_varid(ftn,'mean',mean_id), & + call LIS_verify(nf90_inq_varid(ftn, 'mean', mean_id), & 'nf90_inq_varid failed for mean in get_cdf_params') call LIS_verify(nf90_get_var(ftn, mean_id, param_hires, & start=(/1,1,month/), count=(/ngrid,nlead,1/)),& 'nf90_get_var failed for mean in get_cdf_params') - do l=1,nlead + do l = 1, nlead ! 1D -> 2D - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + do r = 1, LIS_rc%gnr(n) + do c = 1, LIS_rc%gnc(n) + param_hires_2d(c,r) = param_hires(c+(r-1)*LIS_rc%gnc(n),l) enddo enddo !subsets the data for each processor's domain nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 - do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) - do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) - c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 - r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + do r = LIS_nss_halo_ind(n,LIS_localPet+1), LIS_nse_halo_ind(n,LIS_localPet+1) + do c = LIS_ews_halo_ind(n,LIS_localPet+1), LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c - LIS_ews_halo_ind(n,LIS_localPet+1)+1 + r1 = r - LIS_nss_halo_ind(n,LIS_localPet+1)+1 gid = LIS_domain(n)%gindex(c1,r1) - if(gid.ne.-1) then + if (gid.ne.-1) then mean(gid,l) = param_hires_2d(c,r) endif enddo @@ -169,28 +172,28 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) enddo ! read std - call LIS_verify(nf90_inq_varid(ftn,'std',std_id), & + call LIS_verify(nf90_inq_varid(ftn, 'std', std_id), & 'nf90_inq_varid failed for std in get_cdf_params') call LIS_verify(nf90_get_var(ftn, std_id, param_hires, & start=(/1,1,month/), count=(/ngrid,nlead,1/)),& 'nf90_get_var failed for std in get_cdf_params') - do l=1,nlead + do l = 1, nlead ! 1D -> 2D - do r=1,LIS_rc%gnr(n) - do c=1,LIS_rc%gnc(n) - param_hires_2d(c,r)=param_hires(c+(r-1)*LIS_rc%gnc(n),l) + do r = 1, LIS_rc%gnr(n) + do c = 1, LIS_rc%gnc(n) + param_hires_2d(c,r) =param_hires(c+(r-1)*LIS_rc%gnc(n),l) enddo enddo !subsets the data for each processor's domain nc = (LIS_ewe_halo_ind(n,LIS_localPet+1)-LIS_ews_halo_ind(n,LIS_localPet+1))+1 - do r=LIS_nss_halo_ind(n,LIS_localPet+1),LIS_nse_halo_ind(n,LIS_localPet+1) - do c=LIS_ews_halo_ind(n,LIS_localPet+1),LIS_ewe_halo_ind(n,LIS_localPet+1) - c1 = c-LIS_ews_halo_ind(n,LIS_localPet+1)+1 - r1 = r-LIS_nss_halo_ind(n,LIS_localPet+1)+1 + do r = LIS_nss_halo_ind(n,LIS_localPet+1), LIS_nse_halo_ind(n,LIS_localPet+1) + do c = LIS_ews_halo_ind(n,LIS_localPet+1), LIS_ewe_halo_ind(n,LIS_localPet+1) + c1 = c - LIS_ews_halo_ind(n,LIS_localPet+1) + 1 + r1 = r - LIS_nss_halo_ind(n,LIS_localPet+1) + 1 gid = LIS_domain(n)%gindex(c1,r1) - if(gid.ne.-1) then + if (gid.ne.-1) then std(gid,l) = param_hires_2d(c,r) endif enddo @@ -202,7 +205,8 @@ subroutine get_cdf_params (n, fname, month, param_a, param_b, mean, std) call LIS_verify(nf90_close(ftn),'failed to close in get_cdf_params') - write(LIS_logunit,*) 'Done reading MOGREPS-G bias correction parameters data ' + write(LIS_logunit,*) & + '[INFO] Done reading MOGREPS-G bias correction parameters data ' end subroutine get_cdf_params diff --git a/lis/metforcing/mogreps_g/get_mogrepsg.F90 b/lis/metforcing/mogreps_g/get_mogrepsg.F90 index 9877b0599..610802273 100644 --- a/lis/metforcing/mogreps_g/get_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/get_mogrepsg.F90 @@ -64,134 +64,156 @@ subroutine get_mogrepsg(n, findex) external :: read_mogrepsg ! MOGREPS-G cycles every 6 hours; ecch cycle provide up to 192 hours (8 days; 3-hour interval) forecast - if(LIS_rc%ts.gt.10800) then - write(LIS_logunit,*) '[WARN] The model timestep is > forcing data timestep ...' - write(LIS_logunit,*) '[WARN] LIS does not support this mode currently.' + if (LIS_rc%ts .gt. 10800) then + write(LIS_logunit,*) '[ERR] The model timestep is > forcing data timestep ...' + write(LIS_logunit,*) '[ERR] LIS does not support this mode currently.' call LIS_endrun() endif - openfile=0 + openfile = 0 - if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then !beginning of run + if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then !beginning of run LIS_rc%rstflag(n) = 0 endif ! First timestep of run - if(LIS_rc%tscount(n).eq.1 .or.LIS_rc%rstflag(n).eq.1) then - ! Bookend-time record 1 + if (LIS_rc%tscount(n) .eq. 1 .or. LIS_rc%rstflag(n) .eq. 1) then + ! Bookend-time record 1 yr1 = LIS_rc%yr - mo1=LIS_rc%mo - da1=LIS_rc%da - hr1=LIS_rc%hr - mn1=0 - ss1=0 - ts1=0 - call LIS_tick(time1,doy1,gmt1,yr1,mo1,da1,hr1,mn1,ss1,ts1) + mo1 = LIS_rc%mo + da1 = LIS_rc%da + hr1 = LIS_rc%hr + mn1 = 0 + ss1 = 0 + ts1 = 0 + call LIS_tick(time1, doy1, gmt1, yr1, mo1, da1, hr1, mn1, ss1, ts1) ! Bookend-time record 2 - yr2=LIS_rc%yr !next hour - mo2=LIS_rc%mo - da2=LIS_rc%da - hr2=3 - mn2=0 - ss2=0 - ts2=0 - call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + yr2 = LIS_rc%yr !next hour + mo2 = LIS_rc%mo + da2 = LIS_rc%da + hr2 = 3 + mn2 = 0 + ss2 = 0 + ts2 = 0 + call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, ts2) openfile=1 endif - ! 3 hourly interval + ! 3 hourly interval fcsthr_intv = 3 valid_hour = fcsthr_intv * (LIS_rc%hr/fcsthr_intv) - if((valid_hour==LIS_rc%hr .and. LIS_rc%mn==0) .or. & + if ((valid_hour == LIS_rc%hr .and. LIS_rc%mn == 0) .or. & openfile == 1) then ! Forecast hour condition within each file: - mogrepsg_struc(n)%fcst_hour = mogrepsg_struc(n)%fcst_hour + fcsthr_intv - + mogrepsg_struc(n)%fcst_hour = & + mogrepsg_struc(n)%fcst_hour + fcsthr_intv + ! Check if local forecast hour exceeds max grib file forecast hour: - if(mogrepsg_struc(n)%fcst_hour > 195 ) then + if (mogrepsg_struc(n)%fcst_hour > 195 ) then write(LIS_logunit,*) & - "[INFO] MOGREPS-G Forecast hour has exceeded the grib file's final" + "[ERR] MOGREPS-G Forecast hour has exceeded the grib file's final" write(LIS_logunit,*) & ' forecast hour (record). Run will end here for now ... ' call LIS_endrun endif - + ! Update bookend-time record 2: - if(LIS_rc%tscount(n).ne.1) then - mogrepsg_struc(n)%fcsttime1=mogrepsg_struc(n)%fcsttime2 - mogrepsg_struc(n)%metdata1(:,:,:)=mogrepsg_struc(n)%metdata2(:,:,:) - - yr2=LIS_rc%yr - mo2=LIS_rc%mo - da2=LIS_rc%da - hr2=valid_hour - mn2=fcsthr_intv*60 ! Backward looking - ss2=0 - ts2=0 - call LIS_tick(time2,doy2,gmt2,yr2,mo2,da2,hr2,mn2,ss2,ts2) + if (LIS_rc%tscount(n) .ne. 1) then + mogrepsg_struc(n)%fcsttime1 = mogrepsg_struc(n)%fcsttime2 + mogrepsg_struc(n)%metdata1(:,:,:) = & + mogrepsg_struc(n)%metdata2(:,:,:) + + yr2 = LIS_rc%yr + mo2 = LIS_rc%mo + da2 = LIS_rc%da + hr2 = valid_hour + mn2 = fcsthr_intv * 60 ! Backward looking + ss2 = 0 + ts2 = 0 + call LIS_tick(time2, doy2, gmt2, yr2, mo2, da2, hr2, mn2, ss2, & + ts2) endif - do m=1,mogrepsg_struc(n)%max_ens_members + do m = 1, mogrepsg_struc(n)%max_ens_members ! Read in file contents: - if(LIS_rc%tscount(n) == 1) then ! Read in first two book-ends - ferror=0 - order=1 - call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& - mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& - 0,m,fname) - - write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file1 ... ',trim(fname) + if (LIS_rc%tscount(n) == 1) then ! Read in first two book-ends + ferror = 0 + order = 1 + call get_mogrepsg_filename(mogrepsg_struc(n)%odir, & + mogrepsg_struc(n)%init_yr, & + mogrepsg_struc(n)%init_mo, & + mogrepsg_struc(n)%init_da, & + mogrepsg_struc(n)%init_hr, & + 0, m, fname) + + write(LIS_logunit,*)& + '[INFO] Getting MOGREPS-G forecast file1 ... ', & + trim(fname) call read_mogrepsg(n, m, findex, order, fname, ferror) - if(ferror.ge.1) mogrepsg_struc(n)%fcsttime1=time1 - - ferror=0 - order=2 - call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& - mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& - mogrepsg_struc(n)%fcst_hour,m,fname) - - write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file2 ... ',trim(fname) + if (ferror .ge. 1) mogrepsg_struc(n)%fcsttime1 = time1 + + ferror = 0 + order = 2 + call get_mogrepsg_filename(mogrepsg_struc(n)%odir, & + mogrepsg_struc(n)%init_yr, & + mogrepsg_struc(n)%init_mo, & + mogrepsg_struc(n)%init_da, & + mogrepsg_struc(n)%init_hr, & + mogrepsg_struc(n)%fcst_hour, m, fname) + + write(LIS_logunit,*) & + '[INFO] Getting MOGREPS-G forecast file2 ... ', & + trim(fname) call read_mogrepsg(n, m, findex, order, fname, ferror) - if(ferror.ge.1) mogrepsg_struc(n)%fcsttime2=time2 + if (ferror .ge. 1) mogrepsg_struc(n)%fcsttime2 = time2 - !only for T+0 due to mssing LW varaible - mogrepsg_struc(n)%metdata1(4,m,:) = mogrepsg_struc(n)%metdata2(4,m,:) + !only for T+0 due to mssing LW variable + mogrepsg_struc(n)%metdata1(4,m,:) = & + mogrepsg_struc(n)%metdata2(4,m,:) else - ferror=0 - order=2 + ferror = 0 + order = 2 ! met forcings except for pcp - call get_mogrepsg_filename(mogrepsg_struc(n)%odir,mogrepsg_struc(n)%init_yr,& - mogrepsg_struc(n)%init_mo,mogrepsg_struc(n)%init_da,mogrepsg_struc(n)%init_hr,& - mogrepsg_struc(n)%fcst_hour,m,fname) - - write(LIS_logunit,*)'[INFO] Getting MOGREPS-G forecast file2 ... ',trim(fname) + call get_mogrepsg_filename(mogrepsg_struc(n)%odir, & + mogrepsg_struc(n)%init_yr, & + mogrepsg_struc(n)%init_mo, & + mogrepsg_struc(n)%init_da, & + mogrepsg_struc(n)%init_hr, & + mogrepsg_struc(n)%fcst_hour, m, fname) + + write(LIS_logunit,*) & + '[INFO] Getting MOGREPS-G forecast file2 ... ', & + trim(fname) call read_mogrepsg(n, m, findex, order, fname, ferror) - if(ferror.ge.1) mogrepsg_struc(n)%fcsttime2=time2 + if (ferror .ge. 1) mogrepsg_struc(n)%fcsttime2 = time2 !only for T+141 due to mssing LW varaible - if(mogrepsg_struc(n)%fcst_hour == 141) then - mogrepsg_struc(n)%metdata2(4,m,:) = mogrepsg_struc(n)%metdata1(4,m,:) + if (mogrepsg_struc(n)%fcst_hour == 141) then + mogrepsg_struc(n)%metdata2(4,m,:) = & + mogrepsg_struc(n)%metdata1(4,m,:) endif endif ! apply precipitation bias correction (cdf from difference bewteen NAPFA and MOGREPS-G) if (mogrepsg_struc(n)%bc == 1) then - lead_time=floor((float(mogrepsg_struc(n)%fcst_hour))/24)+1 + lead_time=floor((float(mogrepsg_struc(n)%fcst_hour))/24) + 1 if (lead_time > 8) then lead_time = 8 endif - do t=1, LIS_rc%ngrid(n) - if(mogrepsg_struc(n)%metdata2(8,m,t).ne.LIS_rc%udef) then + do t = 1, LIS_rc%ngrid(n) + if (mogrepsg_struc(n)%metdata2(8,m,t) .ne. LIS_rc%udef) then ! only for land pixels if (mogrepsg_struc(n)%bc_param_a(t,lead_time) .ne. LIS_rc%udef) then ! perform centering and scaling - pcp1=mogrepsg_struc(n)%metdata2(8,m,t)-mogrepsg_struc(n)%metdata1(8,m,t) + pcp1= & + mogrepsg_struc(n)%metdata2(8,m,t) - & + mogrepsg_struc(n)%metdata1(8,m,t) if (mogrepsg_struc(n)%bc_std(t,lead_time) .ne. 0) then pcp2=(pcp1-mogrepsg_struc(n)%bc_mean(t,lead_time))/& mogrepsg_struc(n)%bc_std(t,lead_time) @@ -200,27 +222,29 @@ subroutine get_mogrepsg(n, findex) endif ! apply cdf params - pcp2=pcp2*mogrepsg_struc(n)%bc_param_a(t,lead_time)+mogrepsg_struc(n)%bc_param_b(t,lead_time) + pcp2 = pcp2 * & + mogrepsg_struc(n)%bc_param_a(t,lead_time)+mogrepsg_struc(n)%bc_param_b(t,lead_time) ! check for negative precipitation; if the corrected value has negative, keep the original value. - if(pcp2 >= 0) then - mogrepsg_struc(n)%pcp_bc(m,t)=pcp2 + if (pcp2 >= 0) then + mogrepsg_struc(n)%pcp_bc(m,t) = pcp2 else - mogrepsg_struc(n)%pcp_bc(m,t)=pcp1 + mogrepsg_struc(n)%pcp_bc(m,t) = pcp1 endif ! additionally, avoid bias correction for values that are too samll to reduce abnormal noise. if(pcp1 < 0.01) then - mogrepsg_struc(n)%pcp_bc(m,t)=pcp1 + mogrepsg_struc(n)%pcp_bc(m,t) = pcp1 endif else ! for water pixels - mogrepsg_struc(n)%pcp_bc(m,t)=mogrepsg_struc(n)%metdata2(8,m,t)-mogrepsg_struc(n)%metdata1(8,m,t) + mogrepsg_struc(n)%pcp_bc(m,t) = & + mogrepsg_struc(n)%metdata2(8,m,t) - & + mogrepsg_struc(n)%metdata1(8,m,t) endif endif enddo endif - enddo endif - openfile=0 + openfile = 0 end subroutine get_mogrepsg @@ -230,7 +254,8 @@ end subroutine get_mogrepsg ! \label{get_mogrepsg_filename} ! ! !INTERFACE: -subroutine get_mogrepsg_filename(rootdir,yr,mo,da,hr,fc_hr,ens_id,filename) +subroutine get_mogrepsg_filename(rootdir, yr, mo, da, hr, fc_hr, & + ens_id, filename) use LIS_logMod, only: LIS_endrun implicit none @@ -248,12 +273,11 @@ subroutine get_mogrepsg_filename(rootdir,yr,mo,da,hr,fc_hr,ens_id,filename) character(8) :: ftime character(2) :: chr character(3) :: fchr - character(2) :: ens - + character(2) :: ens character(len=36) :: fname write (UNIT=chr, FMT='(i2.2)') hr ! cycle 00/06/12/18 - write (UNIT=fchr, FMT='(i3.3)') fc_hr ! forecast time + write (UNIT=fchr, FMT='(i3.3)') fc_hr ! forecast time write (UNIT=ftime, FMT='(i4, i2.2, i2.2)') yr, mo, da fname = 'prods_op_mogreps-g_' @@ -265,7 +289,7 @@ subroutine get_mogrepsg_filename(rootdir,yr,mo,da,hr,fc_hr,ens_id,filename) else if (ens_id == 1) then write (UNIT=ens, FMT='(i2.2)') ens_id-1 ! start 00 - else + else write (UNIT=ens, FMT='(i2.2)') ens_id+16 ! start 18-34 endif endif diff --git a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 index 98dc9d04a..dd27a7bab 100644 --- a/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 +++ b/lis/metforcing/mogreps_g/mogrepsg_forcingMod.F90 @@ -47,14 +47,14 @@ module mogrepsg_forcingMod integer, allocatable :: gindex(:,:) integer :: mi - + integer, allocatable :: n111(:) integer, allocatable :: n121(:) integer, allocatable :: n211(:) integer, allocatable :: n221(:) real, allocatable :: w111(:),w121(:) real, allocatable :: w211(:),w221(:) - + integer, allocatable :: n112(:,:) integer, allocatable :: n122(:,:) integer, allocatable :: n212(:,:) @@ -63,14 +63,14 @@ module mogrepsg_forcingMod real, allocatable :: w212(:,:),w222(:,:) integer, allocatable :: n113(:) - + integer :: findtime1, findtime2 integer :: fcst_hour integer :: init_yr, init_mo, init_da, init_hr - real, allocatable :: metdata1(:,:,:) + real, allocatable :: metdata1(:,:,:) real, allocatable :: metdata2(:,:,:) - - integer :: nmodels + + integer :: nmodels ! only for v-wind due to difference resolution integer :: nrv @@ -78,15 +78,15 @@ module mogrepsg_forcingMod integer, allocatable :: nv121(:) integer, allocatable :: nv211(:) integer, allocatable :: nv221(:) - real, allocatable :: wv111(:),wv121(:) - real, allocatable :: wv211(:),wv221(:) + real, allocatable :: wv111(:), wv121(:) + real, allocatable :: wv211(:), wv221(:) integer, allocatable :: nv112(:,:) integer, allocatable :: nv122(:,:) integer, allocatable :: nv212(:,:) integer, allocatable :: nv222(:,:) - real, allocatable :: wv112(:,:),wv122(:,:) - real, allocatable :: wv212(:,:),wv222(:,:) + real, allocatable :: wv112(:,:), wv122(:,:) + real, allocatable :: wv212(:,:), wv222(:,:) integer, allocatable :: nv113(:) @@ -109,19 +109,19 @@ module mogrepsg_forcingMod ! ! !ROUTINE: init_mogrepsg ! \label{init_mogrepsg} -! +! ! !INTERFACE: subroutine init_mogrepsg(findex) -! !USES: +! !USES: use LIS_coreMod, only : LIS_rc use LIS_timeMgrMod, only : LIS_update_timestep use LIS_logMod, only : LIS_logunit, LIS_endrun implicit none -! !USES: +! !USES: integer, intent(in) :: findex -! -! !DESCRIPTION: +! +! !DESCRIPTION: ! Defines the native resolution of the input forcing for MOGREPS-G ! data. The grid description arrays are based on the decoding ! schemes used by NCEP and followed in the LIS interpolation @@ -139,12 +139,15 @@ subroutine init_mogrepsg(findex) external :: neighbor_interp_input external :: get_cdf_params - write(LIS_logunit,*) "[INFO] Initializing the MOGREPS-G forecast inputs " + write(LIS_logunit,*) & + "[INFO] Initializing the MOGREPS-G forecast inputs " ! Forecast mode -- NOT Available at this time for this forcing reader: if( LIS_rc%forecastMode.eq.1 ) then - write(LIS_logunit,*) '[ERR] Currently the MOGREPS-G forecast forcing reader' - write(LIS_logunit,*) '[ERR] is not set up to run in forecast mode.' + write(LIS_logunit,*) & + '[ERR] Currently the MOGREPS-G forecast forcing reader' + write(LIS_logunit,*) & + '[ERR] is not set up to run in forecast mode.' write(LIS_logunit,*) '[ERR] LIS forecast run-time ending.' call LIS_endrun() endif @@ -164,10 +167,10 @@ subroutine init_mogrepsg(findex) enddo ! 8 - key met field - LIS_rc%met_nf(findex) = 8 + LIS_rc%met_nf(findex) = 8 + + do n = 1, LIS_rc%nnest - do n=1,LIS_rc%nnest - ! Check if starting hour of LIS run matches 00/06/12/18 UTC: if((LIS_rc%shr .ne. 0) .and. (LIS_rc%shr .ne. 6) .and. & (LIS_rc%shr .ne. 12) .and. (LIS_rc%shr .ne. 18)) then @@ -177,10 +180,10 @@ subroutine init_mogrepsg(findex) write(LIS_logunit,*) "[ERR] your lis.config file.." call LIS_endrun() endif - + ! Allocate and initialize MOGREPS-G metforcing data structures: LIS_rc%met_nensem(findex) = mogrepsg_struc(n)%max_ens_members - + allocate(mogrepsg_struc(n)%metdata1(LIS_rc%met_nf(findex),& mogrepsg_struc(n)%max_ens_members,LIS_rc%ngrid(n))) allocate(mogrepsg_struc(n)%metdata2(LIS_rc%met_nf(findex),& @@ -196,7 +199,7 @@ subroutine init_mogrepsg(findex) mogrepsg_struc(n)%metdata1 = 0 mogrepsg_struc(n)%metdata2 = 0 gridDesci = 0 - + gridDesci(n,1) = 0 gridDesci(n,2) = real(mogrepsg_struc(n)%nc) !gnc gridDesci(n,3) = real(mogrepsg_struc(n)%nr) !gnr @@ -352,7 +355,7 @@ subroutine init_mogrepsg(findex) enddo ! precipitation bias correction - do n=1,LIS_rc%nnest + do n = 1, LIS_rc%nnest if (mogrepsg_struc(n)%bc == 1) then allocate(mogrepsg_struc(n)%pcp_bc(mogrepsg_struc(n)%max_ens_members,LIS_rc%ngrid(n))) allocate(mogrepsg_struc(n)%bc_param_a(LIS_rc%ngrid(n),8)) !8: lead time @@ -367,8 +370,9 @@ subroutine init_mogrepsg(findex) mogrepsg_struc(n)%bc_std = 0 ! read cdf parameters - call get_cdf_params(n,mogrepsg_struc(n)%cdf_fname,LIS_rc%mo,& - mogrepsg_struc(n)%bc_param_a, mogrepsg_struc(n)%bc_param_b,& + call get_cdf_params(n,mogrepsg_struc(n)%cdf_fname,LIS_rc%mo, & + mogrepsg_struc(n)%bc_param_a, & + mogrepsg_struc(n)%bc_param_b, & mogrepsg_struc(n)%bc_mean, mogrepsg_struc(n)%bc_std) endif enddo diff --git a/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 index 0ab191a4a..38cd984b4 100644 --- a/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/readcrd_mogrepsg.F90 @@ -16,7 +16,7 @@ ! 26 Jan 2023; Yeosang Yoon, Initial Code ! 01 Jan 2024; Yeosang Yoon; update codes for precpi. bias-correction ! -! !INTERFACE: +! !INTERFACE: subroutine readcrd_mogrepsg() ! !USES: use LIS_logMod @@ -26,55 +26,72 @@ subroutine readcrd_mogrepsg() ! ! !DESCRIPTION: ! -! This routine reads the options specific to MOGREPS-G forecast forcing from -! the LIS configuration file. -! +! This routine reads the options specific to MOGREPS-G forecast forcing from +! the LIS configuration file. +! !EOP implicit none - integer :: n,rc + integer :: n, rc - call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast forcing directory:",rc=rc) - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%odir,rc=rc) - call LIS_verify(rc,'MOGREPS-G forecast forcing directory: not defined') + call ESMF_ConfigFindLabel(LIS_config, & + "MOGREPS-G forecast forcing directory:", rc=rc) + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, mogrepsg_struc(n)%odir, & + rc=rc) + call LIS_verify(rc, & + 'MOGREPS-G forecast forcing directory: not defined') enddo - call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast run mode:",rc=rc) + call ESMF_ConfigFindLabel(LIS_config, "MOGREPS-G forecast run mode:", & + rc=rc) call LIS_verify(rc, 'MOGREPS-G forecast run mode: not defined ') - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%runmode,rc=rc) + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + mogrepsg_struc(n)%runmode, rc=rc) enddo - call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G forecast number of ensemble members:",rc=rc) - call LIS_verify(rc, 'MOGREPS-G forecast number of ensemble members: not defined') - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%max_ens_members,rc=rc) + call ESMF_ConfigFindLabel(LIS_config, & + "MOGREPS-G forecast number of ensemble members:", rc=rc) + call LIS_verify(rc, & + 'MOGREPS-G forecast number of ensemble members: not defined') + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + mogrepsg_struc(n)%max_ens_members, rc=rc) enddo - call ESMF_ConfigFindLabel(LIS_config,"Apply MOGREPS-G precipitation bias correction:",rc=rc) - call LIS_verify(rc, 'Apply MOGREPS-G precipitation bias correction: not defined') - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%bc,rc=rc) + call ESMF_ConfigFindLabel(LIS_config, & + "Apply MOGREPS-G precipitation bias correction:", rc=rc) + call LIS_verify(rc, & + 'Apply MOGREPS-G precipitation bias correction: not defined') + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, mogrepsg_struc(n)%bc, rc=rc) enddo - call ESMF_ConfigFindLabel(LIS_config,"MOGREPS-G model CDF file:",rc=rc) + call ESMF_ConfigFindLabel(LIS_config, "MOGREPS-G model CDF file:", rc=rc) call LIS_verify(rc, 'MOGREPS-G model CDF file: not defined') - do n=1,LIS_rc%nnest - call ESMF_ConfigGetAttribute(LIS_config,mogrepsg_struc(n)%cdf_fname,rc=rc) + do n = 1, LIS_rc%nnest + call ESMF_ConfigGetAttribute(LIS_config, & + mogrepsg_struc(n)%cdf_fname, rc=rc) enddo - do n=1,LIS_rc%nnest + do n = 1, LIS_rc%nnest write(LIS_logunit,*) '[INFO] Using MOGREPS-G forecast forcing' - write(LIS_logunit,*) '[INFO] MOGREPS-G forecast forcing directory: ', trim(mogrepsg_struc(n)%odir) - write(LIS_logunit,*) '[INFO] MOGREPS-G forecast run mode: ',mogrepsg_struc(n)%runmode - write(LIS_logunit,*) '[INFO] MOGREPS-G forecast number of ensemble members:',& + write(LIS_logunit,*) & + '[INFO] MOGREPS-G forecast forcing directory: ', & + trim(mogrepsg_struc(n)%odir) + write(LIS_logunit,*) '[INFO] MOGREPS-G forecast run mode: ', & + mogrepsg_struc(n)%runmode + write(LIS_logunit,*) & + '[INFO] MOGREPS-G forecast number of ensemble members:', & mogrepsg_struc(n)%max_ens_members - write(LIS_logunit,*) '[INFO] Using MOGREPS-G precipitation bias correction:',& + write(LIS_logunit,*) & + '[INFO] Using MOGREPS-G precipitation bias correction:',& mogrepsg_struc(n)%bc if (mogrepsg_struc(n)%bc == 1) then - write(LIS_logunit,*) '[INFO] MOGREPS-G model CDF file: ', trim(mogrepsg_struc(n)%cdf_fname) + write(LIS_logunit,*) '[INFO] MOGREPS-G model CDF file: ', & + trim(mogrepsg_struc(n)%cdf_fname) endif enddo end subroutine readcrd_mogrepsg diff --git a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 index ea6537c25..c647d1c1a 100644 --- a/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 +++ b/lis/metforcing/mogreps_g/timeinterp_mogrepsg.F90 @@ -59,150 +59,172 @@ subroutine timeinterp_mogrepsg(n,findex) real :: wt1, wt2, swt1, swt2 real :: gmt1, gmt2 integer :: t,index1 - integer :: bdoy,byr,bmo,bda,bhr,bmn - real*8 :: btime,newtime1,newtime2 - real :: tempgmt1,tempgmt2,tempbts - integer :: tempbdoy,tempbyr,tempbmo,tempbda,tempbhr,tempbmn,tempbss + integer :: bdoy, byr, bmo, bda, bhr, bmn + real*8 :: btime, newtime1, newtime2 + real :: tempgmt1, tempgmt2, tempbts + integer :: tempbdoy, tempbyr, tempbmo, tempbda, tempbhr, tempbmn, tempbss integer :: status - type(ESMF_Field) :: tmpField,q2Field,uField,vField,swdField,lwdField - type(ESMF_Field) :: psurfField,pcpField - real,pointer :: tmp(:),q2(:),uwind(:),vwind(:) - real,pointer :: swd(:),lwd(:),psurf(:),pcp(:) + type(ESMF_Field) :: tmpField, q2Field, uField, vField, swdField, & + lwdField + type(ESMF_Field) :: psurfField, pcpField + real, pointer :: tmp(:), q2(:), uwind(:), vwind(:) + real, pointer :: swd(:), lwd(:), psurf(:), pcp(:) integer :: mfactor, m, k, tid external :: zterp ! ________________________________________ btime=mogrepsg_struc(n)%fcsttime1 - call LIS_time2date(btime,bdoy,gmt1,byr,bmo,bda,bhr,bmn) - - tempbdoy=bdoy - tempgmt1=gmt1 - tempbyr=byr - tempbmo=bmo - tempbda=bda - tempbhr=bhr - if (tempbhr.eq.24) tempbhr=0 - tempbmn=bmn - tempbss=0 - tempbts=0 - call LIS_tick(newtime1,tempbdoy,tempgmt1,& - tempbyr,tempbmo,tempbda,tempbhr,tempbmn, & - tempbss,tempbts) - - btime=mogrepsg_struc(n)%fcsttime2 - call LIS_time2date(btime,bdoy,gmt2,byr,bmo,bda,bhr,bmn) - - tempbdoy=bdoy - tempgmt2=gmt2 - tempbyr=byr - tempbmo=bmo - tempbda=bda - tempbhr=bhr - if (tempbhr.eq.24) tempbhr=0 - tempbmn=bmn - tempbss=0 - tempbts=0 - call LIS_tick(newtime2,tempbdoy,tempgmt2,& - tempbyr,tempbmo,tempbda,tempbhr,tempbmn,& - tempbss,tempbts) + call LIS_time2date(btime, bdoy, gmt1, byr, bmo, bda, bhr, bmn) + + tempbdoy = bdoy + tempgmt1 = gmt1 + tempbyr = byr + tempbmo = bmo + tempbda = bda + tempbhr = bhr + if (tempbhr.eq.24) tempbhr = 0 + tempbmn = bmn + tempbss = 0 + tempbts = 0 + call LIS_tick(newtime1, tempbdoy, tempgmt1, & + tempbyr, tempbmo, tempbda, tempbhr, tempbmn, & + tempbss, tempbts) + + btime = mogrepsg_struc(n)%fcsttime2 + call LIS_time2date(btime, bdoy, gmt2, byr, bmo, bda, bhr, bmn) + + tempbdoy = bdoy + tempgmt2 = gmt2 + tempbyr = byr + tempbmo = bmo + tempbda = bda + tempbhr = bhr + if (tempbhr.eq.24) tempbhr = 0 + tempbmn = bmn + tempbss = 0 + tempbts = 0 + call LIS_tick(newtime2, tempbdoy, tempgmt2,& + tempbyr, tempbmo, tempbda, tempbhr, tempbmn,& + tempbss, tempbts) !Interpolate Data in Time - wt1=real((mogrepsg_struc(n)%fcsttime2-LIS_rc%time)/ & + wt1 =real((mogrepsg_struc(n)%fcsttime2-LIS_rc%time)/ & (mogrepsg_struc(n)%fcsttime2-mogrepsg_struc(n)%fcsttime1)) - wt2=1.0-wt1 - swt1=real((newtime2-LIS_rc%time)/(newtime2-newtime1)) - swt2=1.0-swt1 + wt2 = 1.0 - wt1 + swt1 = real((newtime2-LIS_rc%time)/(newtime2-newtime1)) + swt2 = 1.0 - swt1 - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Tair%varname(1),tmpField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Tair%varname(1), tmpField,& rc=status) - call LIS_verify(status, 'Error: Enable Tair in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Tair in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Qair%varname(1),q2Field,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Qair%varname(1), q2Field, & rc=status) - call LIS_verify(status, 'Error: Enable Qair in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Qair in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_SWdown%varname(1),swdField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_SWdown%varname(1), swdField, & rc=status) - call LIS_verify(status, 'Error: Enable SWdown in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable SWdown in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_LWdown%varname(1),lwdField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_LWdown%varname(1), lwdField, & rc=status) - call LIS_verify(status, 'Error: Enable LWdown in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable LWdown in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Wind_E%varname(1),uField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Wind_E%varname(1), uField, & rc=status) - call LIS_verify(status, 'Error: Enable Wind_E in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Wind_E in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Wind_N%varname(1),vField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Wind_N%varname(1), vField, & rc=status) - call LIS_verify(status, 'Error: Enable Wind_N in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Wind_N in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Psurf%varname(1),psurfField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Psurf%varname(1), psurfField,& rc=status) - call LIS_verify(status, 'Error: Enable Psurf in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Psurf in the forcing variables list') - call ESMF_StateGet(LIS_FORC_Base_State(n,findex),LIS_FORC_Rainf%varname(1),pcpField,& + call ESMF_StateGet(LIS_FORC_Base_State(n,findex), & + LIS_FORC_Rainf%varname(1), pcpField, & rc=status) - call LIS_verify(status, 'Error: Enable Rainf in the forcing variables list') + call LIS_verify(status, & + 'Error: Enable Rainf in the forcing variables list') - - call ESMF_FieldGet(tmpField,localDE=0,farrayPtr=tmp,rc=status) + call ESMF_FieldGet(tmpField, localDE=0, farrayPtr=tmp, rc=status) call LIS_verify(status) - call ESMF_FieldGet(q2Field,localDE=0,farrayPtr=q2,rc=status) + call ESMF_FieldGet(q2Field, localDE=0, farrayPtr=q2, rc=status) call LIS_verify(status) - call ESMF_FieldGet(swdField,localDE=0,farrayPtr=swd,rc=status) + call ESMF_FieldGet(swdField, localDE=0, farrayPtr=swd, rc=status) call LIS_verify(status) - call ESMF_FieldGet(lwdField,localDE=0,farrayPtr=lwd,rc=status) + call ESMF_FieldGet(lwdField, localDE=0, farrayPtr=lwd, rc=status) call LIS_verify(status) - call ESMF_FieldGet(uField,localDE=0,farrayPtr=uwind,rc=status) + call ESMF_FieldGet(uField, localDE=0, farrayPtr=uwind, rc=status) call LIS_verify(status) - call ESMF_FieldGet(vField,localDE=0,farrayPtr=vwind,rc=status) + call ESMF_FieldGet(vField, localDE=0, farrayPtr=vwind, rc=status) call LIS_verify(status) - call ESMF_FieldGet(psurfField,localDE=0,farrayPtr=psurf,rc=status) + call ESMF_FieldGet(psurfField, localDE=0, farrayPtr=psurf, rc=status) call LIS_verify(status) - call ESMF_FieldGet(pcpField,localDE=0,farrayPtr=pcp,rc=status) + call ESMF_FieldGet(pcpField, localDE=0, farrayPtr=pcp, rc=status) call LIS_verify(status) ! Metforcing ensemble member count factor - mfactor = LIS_rc%nensem(n)/mogrepsg_struc(n)%max_ens_members + mfactor = LIS_rc%nensem(n) / mogrepsg_struc(n)%max_ens_members ! Downward shortwave radiation (average): - do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) - do m=1,mogrepsg_struc(n)%max_ens_members - do k=1,mfactor - tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + do t = 1, LIS_rc%ntiles(n) / LIS_rc%nensem(n) + do m = 1, mogrepsg_struc(n)%max_ens_members + do k = 1, mfactor + tid = (t - 1) * LIS_rc%nensem(n)+(m-1)*mfactor + k index1 = LIS_domain(n)%tile(tid)%index - zdoy=LIS_rc%doy + zdoy = LIS_rc%doy ! Compute and apply zenith angle weights - call zterp(1,LIS_domain(n)%grid(index1)%lat,& - LIS_domain(n)%grid(index1)%lon,& - gmt1,gmt2,LIS_rc%gmt,zdoy,zw1,zw2,czb,cze,czm,LIS_rc) - - if(mogrepsg_struc(n)%metdata1(3,m,index1).ne.LIS_rc%udef.and.& - mogrepsg_struc(n)%metdata2(3,m,index1).ne.LIS_rc%udef) then - swd(tid) = mogrepsg_struc(n)%metdata1(3,m,index1)*zw1+& - mogrepsg_struc(n)%metdata2(3,m,index1)*zw2 + call zterp(1, LIS_domain(n)%grid(index1)%lat, & + LIS_domain(n)%grid(index1)%lon, & + gmt1, gmt2, LIS_rc%gmt, zdoy, zw1, zw2, czb, cze, czm, & + LIS_rc) + + if (mogrepsg_struc(n)%metdata1(3,m,index1) .ne. LIS_rc%udef & + .and. & + mogrepsg_struc(n)%metdata2(3,m,index1).ne. LIS_rc%udef) & + then + swd(tid) = mogrepsg_struc(n)%metdata1(3,m,index1) * zw1 + & + mogrepsg_struc(n)%metdata2(3,m,index1) * zw2 !swd(tid) = zw1 * mogrepsg_struc(n)%metdata2(3,m,index1) ! In cases of small cos(zenith) angles, use linear weighting to avoid overly large weights - if((swd(tid).gt.mogrepsg_struc(n)%metdata1(3,m,index1).and. & - swd(tid).gt.mogrepsg_struc(n)%metdata2(3,m,index1)).and. & - (czb.lt.0.1.or.cze.lt.0.1))then + if ((swd(tid) .gt. mogrepsg_struc(n)%metdata1(3,m,index1) & + .and. & + swd(tid) .gt. mogrepsg_struc(n)%metdata2(3,m,index1)) & + .and. & + (czb .lt. 0.1 .or. cze .lt. 0.1)) then swd(tid) = mogrepsg_struc(n)%metdata1(3,m,index1)*swt1+ & mogrepsg_struc(n)%metdata2(3,m,index1)*swt2 endif if (swd(t).gt.LIS_CONST_SOLAR) then - write(unit=LIS_logunit,fmt=*)'[WARN] sw radiation too high!!' + write(unit=LIS_logunit,fmt=*) & + '[WARN] sw radiation too high!!' write(unit=LIS_logunit,fmt=*)'[WARN] it is',swd(t) write(unit=LIS_logunit,fmt=*)'[WARN] mogrepsgdata1=',& mogrepsg_struc(n)%metdata1(3,m,index1) @@ -210,22 +232,24 @@ subroutine timeinterp_mogrepsg(n,findex) mogrepsg_struc(n)%metdata2(3,m,index1) write(unit=LIS_logunit,fmt=*)'[WARN] zw1=',zw1,'zw2=',zw2 swd(t) = LIS_CONST_SOLAR - write(unit=LIS_logunit,fmt=*)'[WARN] forcing set to ',swd(t) + write(unit=LIS_logunit,fmt=*) & + '[WARN] forcing set to ',swd(t) endif endif - if ((swd(t).ne.LIS_rc%udef).and.(swd(t).lt.0)) then - if (swd(t).gt.-0.00001) then + if ((swd(t) .ne. LIS_rc%udef) .and. (swd(t) .lt. 0)) then + if (swd(t) .gt. -0.00001) then swd(t) = 0.0 else - write(LIS_logunit,*) '[ERR] timeinterp_mogrepsg -- Stopping because ', & + write(LIS_logunit,*) & + '[ERR] timeinterp_mogrepsg -- Stopping because ', & 'forcing not udef but lt 0,' write(LIS_logunit,*)'[ERR] timeinterp_mogrepsg -- ', & - t,swd(t),mogrepsg_struc(n)%metdata2(3,m,index1), & - ' (',LIS_localPet,')' + t,swd(t),mogrepsg_struc(n)%metdata2(3,m,index1), & + ' (',LIS_localPet,')' call LIS_endrun endif - endif + endif enddo enddo enddo @@ -234,31 +258,35 @@ subroutine timeinterp_mogrepsg(n,findex) ! precip variable Block Interpolation !----------------------------------------------------------------------- ! Total precipitation field (accumulated): - do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) - do m=1,mogrepsg_struc(n)%max_ens_members - do k=1,mfactor - tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + do t = 1, LIS_rc%ntiles(n) / LIS_rc%nensem(n) + do m = 1, mogrepsg_struc(n)%max_ens_members + do k = 1, mfactor + tid = (t - 1) * LIS_rc%nensem(n) + (m - 1) * mfactor + k index1 = LIS_domain(n)%tile(tid)%index ! apply precipitation bias correction if (mogrepsg_struc(n)%bc == 1) then !1 - use; or 0 - if(mogrepsg_struc(n)%pcp_bc(m,index1).ne.LIS_rc%udef) then + if (mogrepsg_struc(n)%pcp_bc(m,index1) .ne. & + LIS_rc%udef) then ! account for the accum fields - pcp(tid)=mogrepsg_struc(n)%pcp_bc(m,index1)/real(3600*3) - if(pcp(tid).lt.0) then + pcp(tid) = mogrepsg_struc(n)%pcp_bc(m,index1) / & + real(3600*3) + if (pcp(tid) .lt. 0) then pcp(tid) = 0.0 endif endif else !don't apply bias correction - if(mogrepsg_struc(n)%metdata2(8,m,index1).ne.LIS_rc%udef) then + if (mogrepsg_struc(n)%metdata2(8,m,index1) .ne. & + LIS_rc%udef) then ! account for the accum fields - pcp(tid)=(mogrepsg_struc(n)%metdata2(8,m,index1)-mogrepsg_struc(n)%metdata1(8,m,index1))/real(3600*3) - if(pcp(tid).lt.0) then + pcp(tid) = (mogrepsg_struc(n)%metdata2(8,m,index1) - & + mogrepsg_struc(n)%metdata1(8,m,index1)) / & + real(3600*3) + if (pcp(tid) .lt. 0) then pcp(tid) = 0.0 endif endif endif - enddo enddo enddo @@ -266,47 +294,59 @@ subroutine timeinterp_mogrepsg(n,findex) !----------------------------------------------------------------------- ! Linearly interpolate everything else !----------------------------------------------------------------------- - do t=1,LIS_rc%ntiles(n)/LIS_rc%nensem(n) - do m=1,mogrepsg_struc(n)%max_ens_members - do k=1,mfactor - tid = (t-1)*LIS_rc%nensem(n)+(m-1)*mfactor+k + do t = 1, LIS_rc%ntiles(n) / LIS_rc%nensem(n) + do m = 1, mogrepsg_struc(n)%max_ens_members + do k = 1, mfactor + tid = (t - 1)*LIS_rc%nensem(n) + (m - 1) * mfactor + k index1 = LIS_domain(n)%tile(tid)%index - + ! 2-meter air temp - if((mogrepsg_struc(n)%metdata1(1,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(1,m,index1).ne.LIS_rc%udef)) then - tmp(tid) = mogrepsg_struc(n)%metdata1(1,m,index1)*wt1 + & - mogrepsg_struc(n)%metdata2(1,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(1,m,index1) .ne. LIS_rc%udef) & + .and. & + (mogrepsg_struc(n)%metdata2(1,m,index1) .ne. & + LIS_rc%udef)) then + tmp(tid) = mogrepsg_struc(n)%metdata1(1,m,index1) * wt1 + & + mogrepsg_struc(n)%metdata2(1,m,index1) * wt2 endif ! Specific humidity - if((mogrepsg_struc(n)%metdata1(2,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(2,m,index1).ne.LIS_rc%udef)) then - q2(tid) = mogrepsg_struc(n)%metdata1(2,m,index1)*wt1 + & - mogrepsg_struc(n)%metdata2(2,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(2,m,index1) .ne. LIS_rc%udef) & + .and. & + (mogrepsg_struc(n)%metdata2(2,m,index1) .ne. & + LIS_rc%udef)) then + q2(tid) = mogrepsg_struc(n)%metdata1(2,m,index1) * wt1 + & + mogrepsg_struc(n)%metdata2(2,m,index1) * wt2 endif ! Downward longwave field - if((mogrepsg_struc(n)%metdata1(4,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(4,m,index1).ne.LIS_rc%udef)) then - lwd(tid) = mogrepsg_struc(n)%metdata1(4,m,index1)*wt1 + & - mogrepsg_struc(n)%metdata2(4,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(4,m,index1) .ne. & + LIS_rc%udef) .and. & + (mogrepsg_struc(n)%metdata2(4,m,index1) .ne. & + LIS_rc%udef)) then + lwd(tid) = mogrepsg_struc(n)%metdata1(4,m,index1) * wt1 + & + mogrepsg_struc(n)%metdata2(4,m,index1) * wt2 endif ! U-wind component - if((mogrepsg_struc(n)%metdata1(5,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(5,m,index1).ne.LIS_rc%udef)) then - uwind(tid) = mogrepsg_struc(n)%metdata1(5,m,index1)*wt1+& - mogrepsg_struc(n)%metdata2(5,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(5,m,index1) .ne. LIS_rc%udef) & + .and. & + (mogrepsg_struc(n)%metdata2(5,m,index1) .ne. & + LIS_rc%udef)) then + uwind(tid) = mogrepsg_struc(n)%metdata1(5,m,index1) * wt1 & + + mogrepsg_struc(n)%metdata2(5,m,index1) * wt2 endif ! V-wind component - if((mogrepsg_struc(n)%metdata1(6,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(6,m,index1).ne.LIS_rc%udef)) then - vwind(tid) = mogrepsg_struc(n)%metdata1(6,m,index1)*wt1 + & - mogrepsg_struc(n)%metdata2(6,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(6,m,index1) .ne. LIS_rc%udef) & + .and. & + (mogrepsg_struc(n)%metdata2(6,m,index1) .ne. & + LIS_rc%udef)) then + vwind(tid) = mogrepsg_struc(n)%metdata1(6,m,index1) * wt1 & + + mogrepsg_struc(n)%metdata2(6,m,index1) * wt2 endif ! Surface pressure field - if((mogrepsg_struc(n)%metdata1(7,m,index1).ne.LIS_rc%udef).and.& - (mogrepsg_struc(n)%metdata2(7,m,index1).ne.LIS_rc%udef)) then - psurf(tid) = mogrepsg_struc(n)%metdata1(7,m,index1)*wt1 + & - mogrepsg_struc(n)%metdata2(7,m,index1)*wt2 + if ((mogrepsg_struc(n)%metdata1(7,m,index1) .ne. LIS_rc%udef) & + .and. & + (mogrepsg_struc(n)%metdata2(7,m,index1) .ne. & + LIS_rc%udef)) then + psurf(tid) = mogrepsg_struc(n)%metdata1(7,m,index1) * wt1 & + + mogrepsg_struc(n)%metdata2(7,m,index1) * wt2 endif enddo enddo From d7dae628af92d8bb2d8c1fc37a0464090e31c41f Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 6 Feb 2024 11:21:28 -0500 Subject: [PATCH 305/328] Update documentation --- env/discover/sles15/lisf_7.5_intel_2023.2.1 | 3 +++ 1 file changed, 3 insertions(+) diff --git a/env/discover/sles15/lisf_7.5_intel_2023.2.1 b/env/discover/sles15/lisf_7.5_intel_2023.2.1 index 3fb5657e1..9a7999312 100644 --- a/env/discover/sles15/lisf_7.5_intel_2023.2.1 +++ b/env/discover/sles15/lisf_7.5_intel_2023.2.1 @@ -11,6 +11,7 @@ proc ModulesHelp { } { puts stderr "\t\tLIS_SPMD" puts stderr "\t\tLIS_FC" puts stderr "\t\tLIS_CC" + puts stderr "\t\tLIS_RPC" puts stderr "\t\tLIS_OPENJPEG" puts stderr "\t\tLIS_ECCODES" puts stderr "\t\tLIS_NETCDF" @@ -28,6 +29,7 @@ proc ModulesHelp { } { puts stderr "\t\tLDT_ARCH" puts stderr "\t\tLDT_FC" puts stderr "\t\tLDT_CC" + puts stderr "\t\tLDT_RPC" puts stderr "\t\tLDT_OPENJPEG" puts stderr "\t\tLDT_ECCODES" puts stderr "\t\tLDT_NETCDF" @@ -42,6 +44,7 @@ proc ModulesHelp { } { puts stderr "\t\tLVT_ARCH" puts stderr "\t\tLVT_FC" puts stderr "\t\tLVT_CC" + puts stderr "\t\tLVT_RPC" puts stderr "\t\tLVT_OPENJPEG" puts stderr "\t\tLVT_ECCODES" puts stderr "\t\tLVT_NETCDF" From f4ec302262394de5c3680c668cf1416dee6bf708 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 6 Feb 2024 11:22:10 -0500 Subject: [PATCH 306/328] Add new lisf_7.5_intel_2023.2.1_openmpi_5.0.0 modulefile for discover SCU 17 (SLES 15.4) This uses the Intel compilers and the OpenMPI library. --- .../lisf_7.5_intel_2023.2.1_openmpi_5.0.0 | 164 ++++++++++++++++++ 1 file changed, 164 insertions(+) create mode 100644 env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 diff --git a/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 b/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 new file mode 100644 index 000000000..beb7cf2d4 --- /dev/null +++ b/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 @@ -0,0 +1,164 @@ +#%Module1.0################################################################### + +proc ModulesHelp { } { + puts stderr "\t[module-info name] - loads the LISF_7_5_INTEL_2023_2_1_OPENMPI_5_0_0 env" + puts stderr "" + puts stderr "This is for use on NCCS' discover system running SLES 15.4." + puts stderr "" + puts stderr "\tThe following env variables are set:" + puts stderr "\t\tDEV_ENV" + puts stderr "\t\tLIS_ARCH" + puts stderr "\t\tLIS_SPMD" + puts stderr "\t\tLIS_FC" + puts stderr "\t\tLIS_CC" + puts stderr "\t\tLIS_RPC" + puts stderr "\t\tLIS_OPENJPEG" + puts stderr "\t\tLIS_ECCODES" + puts stderr "\t\tLIS_NETCDF" + puts stderr "\t\tLIS_HDF4" + puts stderr "\t\tLIS_HDFEOS" + puts stderr "\t\tLIS_HDF5" + puts stderr "\t\tLIS_MODESMF" + puts stderr "\t\tLIS_LIBESMF" + puts stderr "\t\tLIS_MINPACK" + puts stderr "\t\tLIS_CRTM" + puts stderr "\t\tLIS_CRTM_PROF" + puts stderr "\t\tLIS_CMEM" + puts stderr "\t\tLIS_LAPACK" + puts stderr "\t\tLIS_PETSC" + puts stderr "\t\tLDT_ARCH" + puts stderr "\t\tLDT_FC" + puts stderr "\t\tLDT_CC" + puts stderr "\t\tLDT_RPC" + puts stderr "\t\tLDT_OPENJPEG" + puts stderr "\t\tLDT_ECCODES" + puts stderr "\t\tLDT_NETCDF" + puts stderr "\t\tLDT_HDF4" + puts stderr "\t\tLDT_HDFEOS" + puts stderr "\t\tLDT_HDF5" + puts stderr "\t\tLDT_MODESMF" + puts stderr "\t\tLDT_LIBESMF" + puts stderr "\t\tLDT_GDAL" + puts stderr "\t\tLDT_FORTRANGIS" + puts stderr "\t\tLDT_LIBGEOTIFF" + puts stderr "\t\tLVT_ARCH" + puts stderr "\t\tLVT_FC" + puts stderr "\t\tLVT_CC" + puts stderr "\t\tLVT_RPC" + puts stderr "\t\tLVT_OPENJPEG" + puts stderr "\t\tLVT_ECCODES" + puts stderr "\t\tLVT_NETCDF" + puts stderr "\t\tLVT_HDF4" + puts stderr "\t\tLVT_HDFEOS" + puts stderr "\t\tLVT_HDF5" + puts stderr "\t\tLVT_MODESMF" + puts stderr "\t\tLVT_LIBESMF" + puts stderr "\t\tLVT_GDAL" + puts stderr "\t\tLVT_FORTRANGIS" + puts stderr "" + puts stderr "\tThe following modules are loaded:" + puts stderr "\t\tcomp/gcc/12.3.0" + puts stderr "\t\tcomp/intel/2023.2.1" + puts stderr "\t\tgit/2.42.0" + puts stedrr "\t\tmpi/openmpi/5.0.0/intel-2023.2.1 (GMAO)" + puts stderr "" +} + +conflict comp mpi + +module-whatis "loads the [module-info name] environment" + +set modname [module-info name] +set modmode [module-info mode] + +module load comp/gcc/12.3.0 +module load comp/intel/2023.2.1 +module load git/2.42.0 +module use -a /discover/swdev/gmao_SIteam/modulefiles-SLES15 +module load mpi/openmpi/5.0.0/intel-2023.2.1 + +set def_lis_rpc /usr/lib64/libtirpc.so +set def_lis_hdf5 /discover/nobackup/projects/lis/libs/sles-15.4/hdf5/1.14.2_gnu-12.3.0_intel-2023.2.1 +set def_lis_netcdf /discover/nobackup/projects/lis/libs/sles-15.4/netcdf/4.9.2_gnu-12.3.0_intel-2023.2.1 +set def_lis_openjpeg /discover/nobackup/projects/lis/libs/sles-15.4/openjpeg/2.3.0-150000.3.13.1.x86_64/usr +set def_lis_eccodes /discover/nobackup/projects/lis/libs/sles-15.4/eccodes/2.32.0_gnu-12.3.0_intel-2023.2.1 +set def_lis_hdf4 /discover/nobackup/projects/lis/libs/sles-15.4/hdf4/4.2.16-2_gnu-12.3.0_intel-2023.2.1 +set def_lis_hdfeos /discover/nobackup/projects/lis/libs/sles-15.4/hdfeos2/3.0_gnu-12.3.0_intel-2023.2.1 +set def_lis_modesmf /discover/nobackup/projects/lis/libs/sles-15.4/esmf/8.5.0_gnu-12.3.0_intel-2023.2.1_openmpi-5.0.0/mod/modO/Linux.intel.64.openmpi.default +set def_lis_libesmf /discover/nobackup/projects/lis/libs/sles-15.4/esmf/8.5.0_gnu-12.3.0_intel-2023.2.1_openmpi-5.0.0/lib/libO/Linux.intel.64.openmpi.default +set def_lvt_proj /discover/nobackup/projects/lis/libs/sles-15.4/proj/9.3.0_gnu-12.3.0_intel-2023.2.1 +set def_ldt_libgeotiff /discover/nobackup/projects/lis/libs/sles-15.4/geotiff/1.7.1_gnu-12.3.0_intel-2023.2.1 +set def_lvt_gdal /discover/nobackup/projects/lis/libs/sles-15.4/gdal/3.7.2_gnu-12.3.0_intel-2023.2.1 +set def_lvt_fortrangis /discover/nobackup/projects/lis/libs/sles-15.4/fortrangis/3.0-1_gnu-12.3.0_intel-2023.2.1 +set def_lis_petsc /discover/nobackup/projects/lis/libs/sles-15.4/petsc/3.20.0_gnu-12.3.0_intel-2023.2.1_openmpi-5.0.0 +set def_lis_minpack /discover/nobackup/projects/lis/libs/minpack/intel_11_1_038 +set def_lis_crtm /discover/nobackup/projects/lis/libs/JCSDA_CRTM/REL-2.0.2.Surface-rev_intel_18_0_3_222 +set def_lis_crtm_prof /discover/nobackup/projects/lis/libs/CRTM_Profile_Utility/intel_18_0_3_222 +set def_lis_cmem /discover/nobackup/projects/lis/libs/LIS-MEM/intel_18_0_3_222 +set def_lis_lapack /discover/nobackup/projects/lis/libs/lapack/3.6.0_intel_14_0_3_174 + +setenv DEV_ENV LISF_7_5_INTEL_2023_2_1_OPENMPI_5_0_0 +setenv LIS_ARCH linux_ifc +setenv LIS_SPMD parallel +setenv LIS_FC mpif90 +setenv LIS_CC mpicc +setenv LIS_RPC $def_lis_rpc +setenv LIS_OPENJPEG $def_lis_openjpeg +setenv LIS_ECCODES $def_lis_eccodes +setenv LIS_NETCDF $def_lis_netcdf +setenv LIS_HDF4 $def_lis_hdf4 +setenv LIS_HDFEOS $def_lis_hdfeos +setenv LIS_HDF5 $def_lis_hdf5 +setenv LIS_MODESMF $def_lis_modesmf +setenv LIS_LIBESMF $def_lis_libesmf +setenv LIS_MINPACK $def_lis_minpack +setenv LIS_CRTM $def_lis_crtm +setenv LIS_CRTM_PROF $def_lis_crtm_prof +setenv LIS_CMEM $def_lis_cmem +setenv LIS_LAPACK $def_lis_lapack +setenv LIS_PETSC $def_lis_petsc + +setenv LDT_ARCH linux_ifc +setenv LDT_FC mpif90 +setenv LDT_CC mpicc +setenv LDT_RPC $def_lis_rpc +setenv LDT_OPENJPEG $def_lis_openjpeg +setenv LDT_ECCODES $def_lis_eccodes +setenv LDT_NETCDF $def_lis_netcdf +setenv LDT_HDF4 $def_lis_hdf4 +setenv LDT_HDFEOS $def_lis_hdfeos +setenv LDT_HDF5 $def_lis_hdf5 +setenv LDT_MODESMF $def_lis_modesmf +setenv LDT_LIBESMF $def_lis_libesmf +setenv LDT_GDAL $def_lvt_gdal +setenv LDT_FORTRANGIS $def_lvt_fortrangis +setenv LDT_LIBGEOTIFF $def_ldt_libgeotiff + + +setenv LVT_ARCH linux_ifc +setenv LVT_FC mpif90 +setenv LVT_CC mpicc +setenv LVT_RPC $def_lis_rpc +setenv LVT_OPENJPEG $def_lis_openjpeg +setenv LVT_ECCODES $def_lis_eccodes +setenv LVT_NETCDF $def_lis_netcdf +setenv LVT_HDF4 $def_lis_hdf4 +setenv LVT_HDFEOS $def_lis_hdfeos +setenv LVT_HDF5 $def_lis_hdf5 +setenv LVT_MODESMF $def_lis_modesmf +setenv LVT_LIBESMF $def_lis_libesmf +setenv LVT_GDAL $def_lvt_gdal +setenv LVT_FORTRANGIS $def_lvt_fortrangis + + +prepend-path LD_LIBRARY_PATH "$def_lis_openjpeg/lib" +prepend-path LD_LIBRARY_PATH "$def_ldt_libgeotiff/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_proj/lib" +prepend-path LD_LIBRARY_PATH "$def_lvt_gdal/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf4/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_hdf5/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_libesmf" +prepend-path LD_LIBRARY_PATH "$def_lis_netcdf/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_eccodes/lib" +prepend-path LD_LIBRARY_PATH "$def_lis_petsc/lib" +prepend-path PATH "$def_lis_netcdf/bin:$def_lis_eccodes/bin" From fc6ef9c2cc7417d26bada1d620c385b98d7d5278 Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Tue, 6 Feb 2024 15:44:54 -0500 Subject: [PATCH 307/328] Correct typo --- env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 b/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 index beb7cf2d4..495afba37 100644 --- a/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 +++ b/env/discover/sles15/lisf_7.5_intel_2023.2.1_openmpi_5.0.0 @@ -60,7 +60,7 @@ proc ModulesHelp { } { puts stderr "\t\tcomp/gcc/12.3.0" puts stderr "\t\tcomp/intel/2023.2.1" puts stderr "\t\tgit/2.42.0" - puts stedrr "\t\tmpi/openmpi/5.0.0/intel-2023.2.1 (GMAO)" + puts stderr "\t\tmpi/openmpi/5.0.0/intel-2023.2.1 (GMAO)" puts stderr "" } From f31808a2040531c9caedace4491a743c946bbb25 Mon Sep 17 00:00:00 2001 From: "Kristi R. Arsenault" Date: Tue, 13 Feb 2024 20:50:10 -0500 Subject: [PATCH 308/328] Fix to S2S NMME-CFSv2 Jan/Feb-2011 Case Updates made to the NMME hindcast data download and preprocessing scripts, include: - download_nmme_hindcasts.sh: Added NMME-CFSv2 data download for the the missing Jan-, Feb-2011 hindcast months. - nmme_reorg_h.py: Added conditional block for the unique CFSv2 Jan-, Feb-2011 hindcast lead months to be processed. --- .../s2s/s2s_app/download_nmme_hindcasts.sh | 16 ++++++++++++++ .../bcsd_fcst/bcsd_library/nmme_reorg_h.py | 22 +++++++++++++++---- 2 files changed, 34 insertions(+), 4 deletions(-) diff --git a/lis/utils/usaf/s2s/s2s_app/download_nmme_hindcasts.sh b/lis/utils/usaf/s2s/s2s_app/download_nmme_hindcasts.sh index f274b8fff..0283c963e 100644 --- a/lis/utils/usaf/s2s/s2s_app/download_nmme_hindcasts.sh +++ b/lis/utils/usaf/s2s/s2s_app/download_nmme_hindcasts.sh @@ -8,6 +8,7 @@ # AUTHOR: Shrad Shukla, UCSB, MAY-2016 # Edited: Abheera Hazra, NASA, MAR-2019 # Edited: Ryan Zamora, NASA, MAR-2022 +# Edited: KR Arsenault, NASA, FEB-2024; Added Jan-, Feb-2011 CFSv2 downloads # # SOURCE WEBSITE: https://iridl.ldeo.columbia.edu/SOURCES/.Models/.NMME/ # @@ -44,12 +45,27 @@ do if [ $model == 'NCEP-CFSv2' ]; then SYRA=1982 EYRA=2010 + SYRB=2011 EYRB=2021 + # Years: Jan-1982 to Dec-2010: strA="http://iridl.ldeo.columbia.edu/SOURCES/.Models/.NMME/."$model"/.HINDCAST/.MONTHLY/."$var"/S/%280000%201%20"$month"%20"$SYRA"-"$EYRA"%29VALUES/data.nc -o "$OUTDIR"/"$var"."$model".mon_"$month"_"$SYRA"_"$EYRA".nc" + + # Years: Mar-2011 to present: strB="http://iridl.ldeo.columbia.edu/SOURCES/.Models/.NMME/."$model"/.FORECAST/.EARLY_MONTH_SAMPLES/.MONTHLY/."$var"/S/%280000%201%20"$month"%20"$SYRB"-"$EYRB"%29VALUES/data.nc -o "$OUTDIR"/"$var"."$model".mon_"$month"_"$SYRB"_"$EYRB".nc" + # ABOVE DATASETS - MISSING: Jan- and Feb-2011: + # ... So must download separately here: + if [ $month == 'Jan' -o $month == 'Feb' ]; then + SYRC=2011 + EYRC=2011 + + strC="http://iridl.ldeo.columbia.edu/SOURCES/.Models/.NMME/."$model"/.HINDCAST/.PENTAD_SAMPLES/.MONTHLY/."$var"/S/%280000%201%20"$month"%20"$SYRC"-"$EYRC"%29VALUES/data.nc -o "$OUTDIR"/"$var"."$model".mon_"$month"_"$SYRC"_"$EYRC".nc" + echo $strC + curl -v $strC + fi + echo $strA curl -v $strA echo $strB diff --git a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py index 7479ab97b..af36ad435 100644 --- a/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py +++ b/lis/utils/usaf/s2s/s2s_modules/bcsd_fcst/bcsd_library/nmme_reorg_h.py @@ -15,6 +15,7 @@ #This module reorganizes #NMME preciptation forecasts #Date: May 06, 2021 +# Update: KR Arsenault; Feb-2024; CFSv2 Jan/Feb update """ from datetime import datetime @@ -129,10 +130,23 @@ def write_3d_netcdf(infile, var, varname, description, source, \ INFILE = INFILE_TEMP.format(NMME_DOWNLOAD_DIR, MODEL, MODEL, MON[MM], SYR1, EYR1) XPREC[0:29,:,:,:,:] = read_nc_files(INFILE, 'prec')[:, 0:LEAD_MON, 0:ENS_NUM, :, :] - SYR2 = 2011 - EYR2 = 2021 - INFILE = INFILE_TEMP.format(NMME_DOWNLOAD_DIR, MODEL, MODEL, MON[MM], SYR2, EYR2) - XPREC[29:40,:,:,:,:] = read_nc_files(INFILE, 'prec')[:, 0:LEAD_MON, 0:ENS_NUM, :, :] + if MON[MM] == 'Jan' or MON[MM] == 'Feb': + SYR2 = 2011 + EYR2 = 2011 + INFILE = INFILE_TEMP.format(NMME_DOWNLOAD_DIR, MODEL, MODEL, MON[MM], SYR2, EYR2) + XPREC[29,:,:,:,:] = read_nc_files(INFILE, 'prec')[:, 0:LEAD_MON, 0:ENS_NUM, :, :] + + SYR3 = 2011 + EYR3 = 2021 + INFILE = INFILE_TEMP.format(NMME_DOWNLOAD_DIR, MODEL, MODEL, MON[MM], SYR3, EYR3) + XPREC[30:40,:,:,:,:] = read_nc_files(INFILE, 'prec')[:, 0:LEAD_MON, 0:ENS_NUM, :, :] + + else: + SYR2 = 2011 + EYR2 = 2021 + INFILE = INFILE_TEMP.format(NMME_DOWNLOAD_DIR, MODEL, MODEL, MON[MM], SYR2, EYR2) + XPREC[29:40,:,:,:,:] = read_nc_files(INFILE, 'prec')[:, 0:LEAD_MON, 0:ENS_NUM, :, :] + elif NMME_MODEL == 'GEOSv2': MODEL = 'NASA-GEOSS2S' if MM == 0: From cd9e8f75d454082aae0e8c9c1524bcf525b13d0b Mon Sep 17 00:00:00 2001 From: "James V. Geiger" Date: Wed, 21 Feb 2024 13:41:06 +0000 Subject: [PATCH 309/328] Add GDAL and FortranGIS I was able to install GDAL (and thus FortranGIS) on narwhal. This commit completes this modulefile. --- env/narwhal/lisf_7.5_prgenv_intel_8.3.3 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/env/narwhal/lisf_7.5_prgenv_intel_8.3.3 b/env/narwhal/lisf_7.5_prgenv_intel_8.3.3 index a2a7cf09a..63d463f9f 100644 --- a/env/narwhal/lisf_7.5_prgenv_intel_8.3.3 +++ b/env/narwhal/lisf_7.5_prgenv_intel_8.3.3 @@ -121,8 +121,8 @@ set def_lis_hdf4 /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_202 set def_lis_hdfeos /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/hdfeos2/3.0_intel-2022.2.1 set def_ldt_libgeotiff /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/geotiff/1.7.1_intel-2022.2.1 set def_lvt_proj /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/proj/9.3.0_intel-2022.2.1 -set def_lvt_gdal /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/gdal/3.5.2_intel-2022.2.1 -set def_lvt_fortrangis /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/fortrangis/2.6_intel-2022.2.1 +set def_lvt_gdal /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/gdal/3.7.2_intel-2022.2.1 +set def_lvt_fortrangis /p/home/jim/local/lib/sles-15.4/prgenv-intel-8.3.3_2022.2.1/fortrangis/3.0-1_intel-2022.2.1 set def_lis_minpack "" set def_lis_crtm "" set def_lis_crtm_prof "" From 4c751309bbbd341fea04e9134367b84b30679ce2 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 28 Feb 2024 13:01:19 -0500 Subject: [PATCH 310/328] Now uses single node. --- .../usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 4bd2c6b97..6043b3062 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -3,9 +3,11 @@ #SBATCH --time=0:20:00 #SBATCH --account s1189 #SBATCH --output smapeopl.slurm.out -#SBATCH --ntasks=13 --ntasks-per-node=1 +##SBATCH --ntasks=13 --ntasks-per-node=1 +##SBATCH --ntasks=13 --ntasks-per-node=2 +#SBATCH --ntasks=13 --ntasks-per-node=13 #SBATCH --mail-type=ALL -#SBATCH --qos=debug +##SBATCH --qos=debug #-------------------------------------------------------------------------- # # SCRIPT: run_smap_e_opl_discover.sh @@ -127,8 +129,13 @@ while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do "$tmplfile" $i || exit 1 # Run LDT - srun --ntasks=1 --nodes=1 --exclusive \ + #srun --ntasks=1 --nodes=1 --exclusive \ + # $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + #srun --ntasks=1 --cpus-per-task=1 \ + # $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + srun --ntasks=1 --cpus-per-task=1 \ $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + PIDS+=($!) actives+=(1) yyyymmddhh+=("$cur_yyyymmddhh") @@ -183,4 +190,5 @@ unset actives unset yyyymmddhh # The end +touch smapeopl.job.done exit 0 From b054832793a6e66dadec0212e1876ff80042d65e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Wed, 28 Feb 2024 13:04:45 -0500 Subject: [PATCH 311/328] Minor clean-up. --- ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 6043b3062..954634065 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -3,8 +3,6 @@ #SBATCH --time=0:20:00 #SBATCH --account s1189 #SBATCH --output smapeopl.slurm.out -##SBATCH --ntasks=13 --ntasks-per-node=1 -##SBATCH --ntasks=13 --ntasks-per-node=2 #SBATCH --ntasks=13 --ntasks-per-node=13 #SBATCH --mail-type=ALL ##SBATCH --qos=debug @@ -30,6 +28,7 @@ # 25 Jan 2024: Eric Kemp. Initial specification. # 26 Jan 2024: Eric Kemp. Added in-script parallelization following # autotuning scripts. +# 28 Feb 2024: Eric Kemp. Now uses single node. # #-------------------------------------------------------------------------- @@ -129,10 +128,6 @@ while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do "$tmplfile" $i || exit 1 # Run LDT - #srun --ntasks=1 --nodes=1 --exclusive \ - # $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & - #srun --ntasks=1 --cpus-per-task=1 \ - # $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & srun --ntasks=1 --cpus-per-task=1 \ $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & From e0a2de873a2a689f007373d690012e7e5a6d9f73 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 12 Mar 2024 14:26:02 -0400 Subject: [PATCH 312/328] Disabled BackQC and SuperstatQC for non-gage data. Fixed typo in SuperstatQC. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 29 +- lis/metforcing/usaf/readagrmetpcpforcing.F90 | 294 ++++++++++--------- 2 files changed, 159 insertions(+), 164 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index c30d45715..99f4e191a 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -20,6 +20,8 @@ ! ........................................Eric Kemp/SSAI/NASA ! 03 Jun 2020 Removed Box-Cox transform in precipitation analysis ! ........................................Eric Kemp/SSAI/NASA +! 12 Mar 2024 Restrict BackQC and SuperstatQC to gage reports. Fixed +! typo in SuperstatQC threshold...........Eric Kemp/SSAI/NASA ! ! DESCRIPTION: ! @@ -34,7 +36,7 @@ ! ! Bratseth, A M, 1986: Statistical interpolation by means of successive ! corrections. Tellus, 38A, 439-447. -! Cressie, N A C, 1993: Statistics for Spatial Data. Revised Edition, +! Cressie, N A C, 1993: Statistics for Spatial Data. Revised Edition, ! Wiley, New York, 928 pp. ! Daley, R, 1991: Atmospheric Data Analysis. Cambridge University Press, ! Cambridge, UK, 457 pp. @@ -3271,7 +3273,7 @@ end subroutine check_grib_file ! ! This implementation is parallelized by distributing work among the ! different LIS ESMF PETs. - subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) + subroutine USAF_superstatQC(this,nest,new_name,silent_rejects) ! Imports use LIS_coreMod, only: LIS_domain, LIS_rc, LIS_localPet @@ -3285,7 +3287,6 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) type(USAF_ObsData), intent(inout) :: this integer,intent(in) :: nest character(len=32), intent(in) :: new_name - character(len=*), optional :: network logical,optional,intent(in) :: silent_rejects ! Local variables @@ -3405,20 +3406,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) ! Skip bad data if ( this%qc(j) .eq. QC_REJECT) cycle - ! Screen by type - if (present(network)) then - if (trim(network) .eq. "SSMI") then - if (.not. is_ssmi(this%net(j))) cycle - else if (trim(network) .eq. "GEOPRECIP") then - if (.not. is_geoprecip(this%net(j))) cycle - else if (trim(network) .eq. "CMORPH") then - if (.not. is_cmorph(this%net(j))) cycle - else if (trim(network) .eq. "IMERG") then - if (.not. is_imerg(this%net(j))) cycle - end if - else ! Gauges - if (.not. is_gauge(this%net(j))) cycle - end if + ! Screen by type. Only apply test to gauges + if ( .not. is_gauge(this%net(j)) ) cycle ! Now see which LIS grid box this is in. First, handle latitude. found = .false. @@ -3462,7 +3451,8 @@ subroutine USAF_superstatQC(this,nest,new_name,network,silent_rejects) if (means(gindex) .eq. MISSING) cycle icount = superob_count(gindex) - threshold = 3 * this%sigmaOSqr(j) * & + ! EMK 12 Mar 2024...Fixed typo in threshold eqn + threshold = 4 * sqrt(this%sigmaOSqr(j)) * & sqrt(real(icount) / real(icount-1)) if (abs(means(gindex) - this%obs(j)) .gt. threshold) then @@ -4178,6 +4168,9 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) ! Skip bad data if ( this%qc(r) .eq. QC_REJECT) cycle + ! Only apply to gauge data + if ( .not. is_gauge(this%net(r)) ) cycle + errorThresh = 4*sqrt(sigmaBSqr + this%sigmaOSqr(r)) absDiff = abs(this%obs(r) - this%back(r)) diff --git a/lis/metforcing/usaf/readagrmetpcpforcing.F90 b/lis/metforcing/usaf/readagrmetpcpforcing.F90 index f9c812901..083c15479 100644 --- a/lis/metforcing/usaf/readagrmetpcpforcing.F90 +++ b/lis/metforcing/usaf/readagrmetpcpforcing.F90 @@ -528,25 +528,25 @@ subroutine readagrmetpcpforcing(n,findex, order) silent_rejects=.true.) ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly SSMI obs, set ',ii - call USAF_backQC(precip_3hrly_ssmi_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + !if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly SSMI obs, set ',ii + ! call USAF_backQC(precip_3hrly_ssmi_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + !end if ! Create "superobservations" from close SSMI retrievals - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERSSMI" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly SSMI obs, set ',ii - call USAF_superstatQC(precip_3hrly_SSMI_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_ssmi_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + !if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERSSMI" + ! write(LIS_logunit,*) & + ! '[INFO] Running superstatQC on 3hrly SSMI obs, set ',ii + ! call USAF_superstatQC(precip_3hrly_SSMI_tmp(ii),n,new_name, & + ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_ssmi_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + !end if ! Filter out the bad obs nobs_good = USAF_countGoodObs(precip_3hrly_ssmi_tmp(ii)) @@ -613,26 +613,27 @@ subroutine readagrmetpcpforcing(n,findex, order) silent_rejects=.true.) ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly GEOPRECIP obs, set ',ii - call USAF_backQC(precip_3hrly_geop_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + !if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly GEOPRECIP obs, set ',ii + ! call USAF_backQC(precip_3hrly_geop_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + !end if ! Create "superobservations" from close obs - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERGEO" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly GEOPRECIP obs, set ',& - ii - call USAF_superstatQC(precip_3hrly_geop_tmp(ii),n,new_name,& - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_geop_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERGEO" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly GEOPRECIP obs, set ',& + ! ! ii + ! !call USAF_superstatQC(precip_3hrly_geop_tmp(ii),n,new_name,& + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_geop_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if + ! Filter the bad obs nobs_good = USAF_countGoodObs(precip_3hrly_geop_tmp(ii)) call USAF_createObsData(precip_3hrly_geop(ii),n, & @@ -697,26 +698,26 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_cmorph_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly CMORPH obs, set ',ii - call USAF_backQC(precip_3hrly_cmorph_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly CMORPH obs, set ',ii + ! call USAF_backQC(precip_3hrly_cmorph_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close CMORPH retrievals - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERCMRPH" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly CMORPH obs, set ',ii - call USAF_superstatQC(precip_3hrly_cmorph_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_cmorph_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERCMRPH" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly CMORPH obs, set ',ii + ! !call USAF_superstatQC(precip_3hrly_cmorph_tmp(ii),n,new_name, & + ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_cmorph_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if ! Filter out the bad obs nobs_good = USAF_countGoodObs(precip_3hrly_cmorph_tmp(ii)) @@ -787,26 +788,27 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_imerg_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly IMERG obs, set ',ii - call USAF_backQC(precip_3hrly_imerg_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly IMERG obs, set ',ii + ! call USAF_backQC(precip_3hrly_imerg_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close IMERG retrievals - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERIMERG" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly IMERG obs, set ',ii - call USAF_superstatQC(precip_3hrly_imerg_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_imerg_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERIMERG" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly IMERG obs, set ',ii + ! !call USAF_superstatQC(precip_3hrly_imerg_tmp(ii),n,new_name, & + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_imerg_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if + ! Filter out bad obs nobs_good = USAF_countGoodObs(precip_3hrly_imerg_tmp(ii)) call USAF_createObsData(precip_3hrly_imerg(ii),n, & @@ -1067,26 +1069,26 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_ssmi_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly SSMI obs, set ',ii - call USAF_backQC(precip_3hrly_ssmi_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly SSMI obs, set ',ii + ! call USAF_backQC(precip_3hrly_ssmi_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close SSMI reports - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERSSMI" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly SSMI obs, set ',ii - call USAF_superstatQC(precip_3hrly_ssmi_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_ssmi_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERSSMI" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly SSMI obs, set ',ii + ! !call USAF_superstatQC(precip_3hrly_ssmi_tmp(ii),n,new_name, & + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_ssmi_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if ! Filter out the bad obs nobs_good = USAF_countGoodObs(precip_3hrly_ssmi_tmp(ii)) @@ -1160,27 +1162,27 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_geop_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly GEOPRECIP obs, set ',ii - call USAF_backQC(precip_3hrly_geop_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly GEOPRECIP obs, set ',ii + ! call USAF_backQC(precip_3hrly_geop_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close GEOPRECIP reports - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERGEO" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly GEOPRECIP obs, set ',& - ii - call USAF_superstatQC(precip_3hrly_geop_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_geop_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERGEO" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly GEOPRECIP obs, set ',& + ! ! ii + ! !call USAF_superstatQC(precip_3hrly_geop_tmp(ii),n,new_name, & + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_geop_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if ! Filter out bad obs nobs_good = USAF_countGoodObs(precip_3hrly_geop_tmp(ii)) @@ -1252,27 +1254,27 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_cmorph_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly CMORPH obs, set ',ii - call USAF_backQC(precip_3hrly_cmorph_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly CMORPH obs, set ',ii + ! call USAF_backQC(precip_3hrly_cmorph_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close CMORPH reports - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERCMRPH" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly CMORPH obs, set ',& - ii - call USAF_superstatQC(precip_3hrly_cmorph_tmp(ii),n,new_name, & - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_cmorph_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERCMRPH" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly CMORPH obs, set ',& + ! ! ii + ! !call USAF_superstatQC(precip_3hrly_cmorph_tmp(ii),n,new_name, & + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_cmorph_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if ! Filter out bad obs nobs_good = USAF_countGoodObs(precip_3hrly_cmorph_tmp(ii)) @@ -1344,27 +1346,27 @@ subroutine readagrmetpcpforcing(n,findex, order) call USAF_snowDepthQC(precip_3hrly_imerg_tmp(ii),n, & silent_rejects=.true.) - ! Compare with background field - if (agrmet_struc(n)%skip_backqc .ne. 1) then - write(LIS_logunit,*) & - '[INFO] Running backQC on 3hrly IMERG obs, set ',ii - call USAF_backQC(precip_3hrly_imerg_tmp(ii),sigmaBSqr, & - silent_rejects=.true.) - end if + ! ! Compare with background field + ! if (agrmet_struc(n)%skip_backqc .ne. 1) then + ! write(LIS_logunit,*) & + ! '[INFO] Running backQC on 3hrly IMERG obs, set ',ii + ! call USAF_backQC(precip_3hrly_imerg_tmp(ii),sigmaBSqr, & + ! silent_rejects=.true.) + ! end if ! Create "superobservations" from close IMERG reports - if (agrmet_struc(n)%skip_superstatqc .ne. 1) then - new_name = "SUPERIMERG" - write(LIS_logunit,*) & - '[INFO] Running superstatQC on 3hrly IMERG obs, set ',& - ii - call USAF_superstatQC(precip_3hrly_imerg_tmp(ii),n,new_name,& - silent_rejects=.true.) - type = new_name - call USAF_interpBackToTypeObsData(precip_3hrly_imerg_tmp(ii),& - n, & - LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) - end if + ! if (agrmet_struc(n)%skip_superstatqc .ne. 1) then + ! new_name = "SUPERIMERG" + ! !write(LIS_logunit,*) & + ! ! '[INFO] Running superstatQC on 3hrly IMERG obs, set ',& + ! ! ii + ! !call USAF_superstatQC(precip_3hrly_imerg_tmp(ii),n,new_name,& + ! ! silent_rejects=.true.) + ! type = new_name + ! call USAF_interpBackToTypeObsData(precip_3hrly_imerg_tmp(ii),& + ! n, & + ! LIS_rc%gnc(n),LIS_rc%gnr(n),back4(:,:,ii),type) + ! end if ! Filter out the bad obs nobs_good = USAF_countGoodObs(precip_3hrly_imerg_tmp(ii)) From 03618dcc18c62cf5666868f7134cb8e88cc74c8a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 12 Mar 2024 15:28:00 -0400 Subject: [PATCH 313/328] Several updates to IMERG reader in LVT. * Fixed unit conversion to kg/m2. * Added support for V07x. * Now uses previous IMERG 30-min file, so LVT can get the 30-min accumulation ending at the LVT clock time. --- lvt/datastreams/IMERG/readIMERGdata.F90 | 55 ++++++++++++++++++------- 1 file changed, 39 insertions(+), 16 deletions(-) diff --git a/lvt/datastreams/IMERG/readIMERGdata.F90 b/lvt/datastreams/IMERG/readIMERGdata.F90 index 6764ef614..8f5f2c899 100644 --- a/lvt/datastreams/IMERG/readIMERGdata.F90 +++ b/lvt/datastreams/IMERG/readIMERGdata.F90 @@ -9,7 +9,7 @@ !-------------------------END NOTICE -- DO NOT EDIT----------------------- #include "LVT_misc.h" !------------------------------------------------------------------------------ -!NOTE: Currently only V05B IMERG data are supported. +!NOTE: Supports V06x and V07x subroutine readIMERGdata(source) ! Imports @@ -71,16 +71,21 @@ subroutine readIMERGdata(source) call ESMF_TimeSet(time1,yy=yr1, mm=mo1, dd=da1, & h=hr1,m=mn1,s=ss1,calendar=LVT_calendar,rc=status) call LVT_verify(status) - ! If it is 00Z, use previous day's time level - if (mod(currtime,86400.0).eq.0) then - call ESMF_TimeIntervalSet(lis_ts, s = 86400, & - rc=status) - call LVT_verify(status) - else - call ESMF_TimeIntervalSet(lis_ts, s = 0, & - rc=status) - call LVT_verify(status) - end if + !! If it is 00Z, use previous day's time level + !if (mod(currtime,86400.0).eq.0) then + ! call ESMF_TimeIntervalSet(lis_ts, s = 86400, & + ! rc=status) + ! call LVT_verify(status) + !else + ! call ESMF_TimeIntervalSet(lis_ts, s = 0, & + ! rc=status) + ! call LVT_verify(status) + !end if + ! Use previous IMERG file (IMERG accumulates forward in time) + call ESMF_TimeIntervalSet(lis_ts, s = 1800, & + rc=status) + call LVT_verify(status) + time2 = time1 - lis_ts call ESMF_TimeGet(time2,yy=yr2, mm=mo2, dd=da2, & h=hr2,m=mn2,s=ss2,calendar=LVT_calendar, & @@ -88,14 +93,17 @@ subroutine readIMERGdata(source) call LVT_verify(status) if (alarmCheck) then + !call create_IMERG_filename(imergdata(source)%odir, & + ! yr1,mo1,da1,hr1,mn1,filename,imergdata(source)%imergver) call create_IMERG_filename(imergdata(source)%odir, & - yr1,mo1,da1,hr1,mn1,filename,imergdata(source)%imergver) + yr2,mo2,da2,hr2,mn2,filename,imergdata(source)%imergver) inquire(file=trim(filename),exist=file_exists) if(file_exists) then write(LVT_logunit,*) '[INFO] Reading IMERG data ',trim(filename) call read_imerghdf(filename, imergdata(source)%nc, & - imergdata(source)%nr, prcp_in, ireaderr) + imergdata(source)%nr, imergdata(source)%imergver, & + prcp_in, ireaderr) if(ireaderr .eq. 0) then ! Use budget-bilinear interpolation if IMERG data are at ! coarser resolution than the analysis grid; otherwise, use @@ -163,7 +171,8 @@ subroutine readIMERGdata(source) do r=1,LVT_rc%lnr do c=1,LVT_rc%lnc if(prcp_final(c,r).ge.0) then - prcp_final(c,r) = prcp_final(c,r)*86400.0 !kg/m2 + !prcp_final(c,r) = prcp_final(c,r)*86400.0 !kg/m2 + prcp_final(c,r) = prcp_final(c,r)*1800. ! kg/m2 for 30 minutes else prcp_final(c,r) = LVT_rc%udef endif @@ -173,7 +182,7 @@ subroutine readIMERGdata(source) vlevel=1,units='kg/m2') end subroutine readIMERGdata !------------------------------------------------------------------------------ -subroutine read_imerghdf(filename, col, row, precipout, ireaderr) +subroutine read_imerghdf(filename, col, row, version, precipout, ireaderr) #if(defined USE_HDF5) use HDF5 #endif @@ -188,11 +197,15 @@ subroutine read_imerghdf(filename, col, row, precipout, ireaderr) character(len=*), intent(in) :: filename integer, intent(in) :: col, row + character*10, intent(in) :: version integer, intent(out) :: ireaderr real, intent(out) :: precipout(col,row) !Local variables integer :: xsize, ysize - character(len=40) :: dsetname='/Grid/precipitationCal' + !character(len=40) :: dsetname='/Grid/precipitationCal' + character(len=40) :: dsetname + character(len=40) :: dsetname6='/Grid/precipitationCal' ! V06x + character(len=40) :: dsetname7='/Grid/precipitation' ! V07x real :: precipin(row,col) logical :: bIsError integer :: istatus,i @@ -224,6 +237,16 @@ subroutine read_imerghdf(filename, col, row, precipout, ireaderr) return endif !open dataset + if (index(trim(version), "V06") .ne. 0) then + dsetname = dsetname6 + else if (index(trim(version), "V07") .ne. 0) then + dsetname = dsetname7 + else + write(LVT_logunit,*)'[ERR] Invalid IMERG version number!' + write(LVT_logunit,*)'[ERR] Expected V06x or V07x!' + write(LVT_logunit,*)'[ERR] Received ', trim(version) + stop + end if call h5dopen_f(fileid,dsetname,dsetid,istatus) if(istatus.ne.0) then bIsError=.true. From b72b0bd296502991c8bc23010bdbf128eac0ae0e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 12 Mar 2024 15:57:53 -0400 Subject: [PATCH 314/328] Updates to LVT AGRMET reader. Minute is now added to the logic for creating a filename. This is necessary when LVT is comparing AGRMET to another dataset with time interval of 30 minutes (e.g., IMERG). Before, LVT would use '00' as the minute and would erroneously read in AGRMET files valid at the top of the hour at 0030, 0330, etc. Now, LVT will search for files at the bottom of the hour, fail to find them, and gracefully mark the data values as "missing" for that time. --- lvt/datastreams/AGRMET/readAGRMETdata.F90 | 32 ++++++++++++++--------- 1 file changed, 20 insertions(+), 12 deletions(-) diff --git a/lvt/datastreams/AGRMET/readAGRMETdata.F90 b/lvt/datastreams/AGRMET/readAGRMETdata.F90 index 7f7f77903..98b157b4a 100644 --- a/lvt/datastreams/AGRMET/readAGRMETdata.F90 +++ b/lvt/datastreams/AGRMET/readAGRMETdata.F90 @@ -233,7 +233,7 @@ subroutine readAGRMETdata(source) mo1 = LVT_rc%dmo(source) da1 = LVT_rc%dda(source) hr1 = LVT_rc%dhr(source) - mn1 = 0 + mn1 = LVT_rc%dmn(source) ss1 = 0 swd = 0 @@ -307,7 +307,7 @@ subroutine readAGRMETdata(source) call LVT_verify(status) call create_agrmetdata_filename(source, & - yr2, mo2, da2, hr2, filename) + yr2, mo2, da2, hr2, mn2, filename) inquire(file=trim(filename),exist=file_exists) @@ -786,7 +786,8 @@ end subroutine interp_agrmetvar ! \label{create_agrmetdata_filename} ! ! !INTERFACE: -subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) +subroutine create_agrmetdata_filename(source, yr, mo, da, hr, mn, & + filename) ! !USES: use AGRMET_dataMod use LVT_logMod, only: LVT_endrun, LVT_logunit @@ -795,12 +796,13 @@ subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) ! !INPUT PARAMETERS: ! - integer, intent(in) :: source - integer :: yr - integer :: mo - integer :: da - integer :: hr - character(len=*) :: filename + integer, intent(in) :: source + integer, intent(in) :: yr + integer, intent(in) :: mo + integer, intent(in) :: da + integer, intent(in) :: hr + integer, intent(in) :: mn + character(len=*), intent(out) :: filename ! ! !DESCRIPTION: @@ -814,6 +816,7 @@ subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) ! \item[mo] month of data ! \item[da] day of data ! \item[hr] hour of data +! \item[mn] minute of data ! \item[filename] Name of the AGRMET file ! \end{description} ! @@ -827,11 +830,13 @@ subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) character*2 :: fmo character*2 :: fda character*2 :: fhr + character*2 :: fmn write(unit=fyr, fmt='(i4.4)') yr write(unit=fmo, fmt='(i2.2)') mo write(unit=fda, fmt='(i2.2)') da write(unit=fhr, fmt='(i2.2)') hr + write(unit=fmn, fmt='(i2.2)') mn if (trim(agrmetdata(source)%gridname) == "GLOBAL") then ! Old 0.25 deg deterministic run @@ -842,7 +847,9 @@ subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) '_DC.'//trim(agrmetdata(source)%data_category)//'_GP.LIS_GR'//& '.C0P25DEG_AR.'//trim(agrmetdata(source)%area_of_data)//& '_PA.03-HR-SUM_DD.'//& - trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)//'00_DF.GR1' + !trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)//'00_DF.GR1' + trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)// & + trim(fmn)//'_DF.GR1' else if (trim(agrmetdata(source)%gridname) == "n1280e") then ! In-house Bratseth run matching GALWEM n1280e domain filename = trim(agrmetdata(source)%odir)//'/'//trim(fyr)//trim(fmo)//trim(fda)//'/'& @@ -852,8 +859,9 @@ subroutine create_agrmetdata_filename(source, yr, mo, da, hr, filename) '_DC.'//trim(agrmetdata(source)%data_category)//'_GP.LIS_GR'//& '.C0P09DEG_AR.'//trim(agrmetdata(source)%area_of_data)//& '_PA.03-HR-SUM_DD.'//& - trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)//'00_DF.GR1' - + !trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)//'00_DF.GR1' + trim(fyr)//trim(fmo)//trim(fda)//'_DT.'//trim(fhr)// & + trim(fmn)//'_DF.GR1' else write(LVT_logunit,*) & '[ERR] Internal error, unknown AGRMET data gridname ', & From 7d30b33f59b629edf4c4fd512768b2c1addfc599 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 21 Mar 2024 12:08:24 -0400 Subject: [PATCH 315/328] Tweaked application of BackQC and SuperstatQC. Logic changed to specifically skip these tests for IMERG only. Earlier change excluded for all non-gauges, but this would impact T, RH, and wind speed analyses. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 99f4e191a..8be03d46a 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -3406,8 +3406,9 @@ subroutine USAF_superstatQC(this,nest,new_name,silent_rejects) ! Skip bad data if ( this%qc(j) .eq. QC_REJECT) cycle - ! Screen by type. Only apply test to gauges - if ( .not. is_gauge(this%net(j)) ) cycle + ! Do not apply to IMERG. But allow application to other + ! data sources. + if ( is_imerg(this%net(j)) ) cycle ! Now see which LIS grid box this is in. First, handle latitude. found = .false. @@ -4168,8 +4169,9 @@ subroutine USAF_backQC(this,sigmaBSqr,silent_rejects) ! Skip bad data if ( this%qc(r) .eq. QC_REJECT) cycle - ! Only apply to gauge data - if ( .not. is_gauge(this%net(r)) ) cycle + ! Do not apply to IMERG. But allow application to other data + ! sources. + if ( .not. is_imerg(this%net(r)) ) cycle errorThresh = 4*sqrt(sigmaBSqr + this%sigmaOSqr(r)) absDiff = abs(this%obs(r) - this%back(r)) From a400168f36828dfcd578c1934fb0e0c49fd6679b Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 21 Mar 2024 12:11:12 -0400 Subject: [PATCH 316/328] Updated comments. --- lis/metforcing/usaf/USAF_bratsethMod.F90 | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lis/metforcing/usaf/USAF_bratsethMod.F90 b/lis/metforcing/usaf/USAF_bratsethMod.F90 index 8be03d46a..82d50b5b2 100644 --- a/lis/metforcing/usaf/USAF_bratsethMod.F90 +++ b/lis/metforcing/usaf/USAF_bratsethMod.F90 @@ -22,6 +22,9 @@ ! ........................................Eric Kemp/SSAI/NASA ! 12 Mar 2024 Restrict BackQC and SuperstatQC to gage reports. Fixed ! typo in SuperstatQC threshold...........Eric Kemp/SSAI/NASA +! 21 Mar 2024 Changed internal BackQC and SuperstatQC logic to only +! skip for IMERG. This allows use with T, RH, and wind +! speed analyses..........................Eric Kemp/SSAI/NASA ! ! DESCRIPTION: ! From 810fb706d13774c124e4010e2108d1c69a94c86f Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 21 Mar 2024 12:52:16 -0400 Subject: [PATCH 317/328] Fixed LVT IMERG reader to support any order of data comparison. Earlier code assumed IMERG was data set 1. --- lvt/datastreams/IMERG/readIMERGdata.F90 | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/lvt/datastreams/IMERG/readIMERGdata.F90 b/lvt/datastreams/IMERG/readIMERGdata.F90 index 8f5f2c899..127a9c96b 100644 --- a/lvt/datastreams/IMERG/readIMERGdata.F90 +++ b/lvt/datastreams/IMERG/readIMERGdata.F90 @@ -96,7 +96,8 @@ subroutine readIMERGdata(source) !call create_IMERG_filename(imergdata(source)%odir, & ! yr1,mo1,da1,hr1,mn1,filename,imergdata(source)%imergver) call create_IMERG_filename(imergdata(source)%odir, & - yr2,mo2,da2,hr2,mn2,filename,imergdata(source)%imergver) + yr2,mo2,da2,hr2,mn2,filename,imergdata(source)%imergver, & + imergdata(source)%imergprd) inquire(file=trim(filename),exist=file_exists) if(file_exists) then @@ -294,7 +295,7 @@ subroutine read_imerghdf(filename, col, row, version, precipout, ireaderr) end subroutine read_imerghdf !------------------------------------------------------------------------------ subroutine create_IMERG_filename(odir, & - yr,mo,da,hr,mn,filename,imVer) + yr,mo,da,hr,mn,filename,imVer, imergprd) use IMERG_dataMod use LVT_logMod @@ -302,7 +303,7 @@ subroutine create_IMERG_filename(odir, & implicit none ! Arguments - character(len=*), intent(in) :: odir, imVer + character(len=*), intent(in) :: odir, imVer, imergprd integer, intent(in) :: yr, mo, da, hr, mn character(len=*), intent(out) :: filename @@ -332,13 +333,13 @@ subroutine create_IMERG_filename(odir, & write(cmnadd, '(I2.2)') umnadd write(cmnday, '(I4.4)')umnday - if(imergdata(1)%imergprd == 'early') then + if(imergprd == 'early') then fstem = '/3B-HHR-E.MS.MRG.3IMERG.' fext = '.RT-H5' - elseif(imergdata(1)%imergprd == 'late') then + elseif(imergprd == 'late') then fstem = '/3B-HHR-L.MS.MRG.3IMERG.' fext = '.RT-H5' - elseif(imergdata(1)%imergprd == 'final') then + elseif(imergprd == 'final') then fstem = '/3B-HHR.MS.MRG.3IMERG.' fext = '.HDF5' else From 81ee95df03445b60139efaa16c420e9a98c1e378 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 22 Mar 2024 11:02:41 -0400 Subject: [PATCH 318/328] Removed unnecessary unit conversion. --- lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 index e7bba7a26..cc202e5d3 100644 --- a/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 +++ b/lis/dataassim/obs/SMAP_E_OPLsm/read_SMAPEOPLsm.F90 @@ -649,7 +649,7 @@ subroutine read_SMAPEOPLsm_data(n, k,fname, smobs_inp, time) do c = 1, nlon if (tmp(c,r,1) >= 0 .and. & tmp(c,r,1) <= 1) then - sm_in(c + (r-1)*nc) = tmp(c,r,1)*100 + sm_in(c + (r-1)*nc) = tmp(c,r,1) sm_data_b(c + (r-1)*nc) = .true. end if end do From 2d68c7c6f930a613dc875e97a1c37e578dff5138 Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Fri, 5 Apr 2024 10:07:58 -0400 Subject: [PATCH 319/328] Fix bug slope value along the coastal area --- ldt/params/topo/read_MERIT1K_slope.F90 | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/ldt/params/topo/read_MERIT1K_slope.F90 b/ldt/params/topo/read_MERIT1K_slope.F90 index f3afcb554..8aae117c0 100755 --- a/ldt/params/topo/read_MERIT1K_slope.F90 +++ b/ldt/params/topo/read_MERIT1K_slope.F90 @@ -18,6 +18,7 @@ ! 01 Aug 2012: KR Arsenault; Expanded for elevation tiling ! 30 May 2017: KR Arsenault; Expanded for Antarctica ! 03 Mar 2020: Yeosang Yoon; Modify codes for MERIT DEM +! 04 Apr 2024: Yeosang Yoon; Fix bug slope value along the coastal area ! ! !INTERFACE: subroutine read_MERIT1K_slope( n, num_bins, fgrd, slopeave ) @@ -279,6 +280,11 @@ subroutine read_MERIT1K_slope( n, num_bins, fgrd, slopeave ) do r = 1, subpnr do c = 1, subpnc subset_elev(c,r) = yrev_elev(lon_line(c,r),lat_line(c,r)) + + ! for coastal areas + if (subset_elev(c,r) .eq. LDT_rc%udef) then + subset_elev(c,r) = 0. + endif enddo enddo deallocate( yrev_elev ) From 71c3b4cb987596c9a9742d3eee370ccad9f530c3 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 16 Apr 2024 10:08:01 -0400 Subject: [PATCH 320/328] Rewrote HDF5 subset reader for L1B files. Fixes crash noted on HPC11. --- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 601 ++++++++++++++++++++++++++++++------ 1 file changed, 512 insertions(+), 89 deletions(-) diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index f87b8d2de..70f7021f7 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -326,8 +326,9 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & character(100) :: dataset integer(HID_T) :: file_id, dataset_id, dspace_id integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: rank integer :: hdferr - logical :: exists, ishdf5 + logical :: exists, ishdf5, link_exists ierr = 0 m = 0 @@ -375,125 +376,536 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if - ! Find Tb_lat, plus dimensions + ! Get the data dataset = "/Brightness_Temperature/tb_lat/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call h5dget_space_f(dataset_id, dspace_id, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & - trim(dataset) - call h5dclose_f(dataset_id, hdferr) + call get_dataset_real_2d(file_id, dataset, n, m, tb_lat, ierr) + if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) - ierr = 1 + call freeall(ierr) return end if - call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & - trim(dataset) - call h5dclose_f(dataset_id, hdferr) + dataset = "/Brightness_Temperature/tb_lon/" + call get_dataset_real_2d(file_id, dataset, n, m, tb_lon, ierr) + if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) - ierr = 1 + call freeall(ierr) return end if - - ! We have the dimensions for the arrays, so let's allocate here. - n = dims(1) - m = dims(2) - allocate(tb_v_surface_corrected(n,m)); tb_v_surface_corrected = 0 - allocate(tb_time_seconds(n,m)); tb_time_seconds = 0 - allocate(tb_lat(n,m)) ; tb_lat = 0 - allocate(tb_lon(n,m)) ; tb_lon = 0 - allocate(tb_qual_flag_v(n,m)) ; tb_qual_flag_v = 0 - allocate(tb_qual_flag_h(n,m)) ; tb_qual_flag_h = 0 - allocate(sc_nadir_angle(n)) ; sc_nadir_angle = 0 - allocate(antenna_scan_angle(n,m)) ; antenna_scan_angle = 0 - - ! Get Tb_lat - call read_dataset_real(file_id, dataset, dataset_id, tb_lat, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_lon - dataset = "/Brightness_Temperature/tb_lon/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_lon, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_time_seconds dataset = "/Brightness_Temperature/tb_time_seconds/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, tb_time_seconds, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_qual_flag_v + call get_dataset_real_2d(file_id, dataset, n, m, tb_time_seconds, ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if dataset = "/Brightness_Temperature/tb_qual_flag_v/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_v, & - dims, ierr) - if (ierr == 1) return - - ! Get tb_qual_flag_h + call get_dataset_integer_2d(file_id, dataset, n, m, tb_qual_flag_v, ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if dataset = "/Brightness_Temperature/tb_qual_flag_h/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_integer(file_id, dataset, dataset_id, tb_qual_flag_h, & - dims, ierr) - if (ierr == 1) return - - ! Get sc_nadir_angle + call get_dataset_integer_2d(file_id, dataset, n, m, tb_qual_flag_h, ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if dataset = "/Spacecraft_Data/sc_nadir_angle/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real_1d(file_id, dataset, dataset_id, sc_nadir_angle, & - dims, ierr) - if (ierr == 1) return - - ! Get antenna_scan_angle + call get_dataset_real_1d(file_id, dataset, n, sc_nadir_angle, ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if dataset = "/Brightness_Temperature/antenna_scan_angle/" - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return - call read_dataset_real(file_id, dataset, dataset_id, & - antenna_scan_angle, dims, ierr) - if (ierr == 1) return + call get_dataset_real_2d(file_id, dataset, n, m, antenna_scan_angle, & + ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if ! We will try to get tb_v_surface_corrected, but this is missing ! in older NRT files. If absent, we will substitute tb_v. - ! NOTE: If a *read* error occurs, the file will assumed to be - ! corrupt all arrays will be nuked. - ! Get tb_v_surface_corrected dataset = "/Brightness_Temperature/tb_v_surface_corrected/" - call get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field=.true.) - if (ierr == 1) then - ierr = 0 + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + if (link_exists) then + call get_dataset_real_2d(file_id, dataset, n, m, & + tb_v_surface_corrected, & + ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if + else dataset = "/Brightness_Temperature/tb_v/" write(LDT_logunit,*)'[WARN] Will try substituting ', trim(dataset) - call get_dataset_id(file_id, dataset, dataset_id, ierr) - if (ierr == 1) return + call get_dataset_real_2d(file_id, dataset, n, m, & + tb_v_surface_corrected, & + ierr) + if (ierr == 1) then + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + call freeall(ierr) + return + end if end if - call read_dataset_real(file_id, dataset, dataset_id, & - tb_v_surface_corrected, & - dims, ierr) - if (ierr == 1) return ! Clean up call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) + ierr = 0 return contains + ! Internal subroutine + subroutine get_dataset_integer_2d(file_id, dataset, n, m, var2d, ierr) + + ! Defaults + implicit none + + ! Arguments + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer, intent(out) :: n + integer, intent(out) :: m + integer*4, allocatable, intent(out) :: var2d(:,:) + integer, intent(out) :: ierr + + ! Locals + integer(HID_T) :: dataset_id + logical :: link_exists + integer :: hdferr + integer(HID_T) :: dspace_id + integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: rank + + ierr = 0 + + ! See if the dataset is in the file + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + if (.not. link_exists) then + write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Get the dataset id + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dspace id for the variable dimensions + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the rank of the dataset in the file. + call h5sget_simple_extent_ndims_f(dspace_id, rank, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get rank for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check that the rank is 2. + if (rank .ne. 2) then + write(LDT_logunit,*) & + '[ERR] Wrong rank for ', trim(dataset), & + ', expected 2, found ', rank + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dimensions + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close access to the dataspace. + call h5sclose_f(dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close access to dataspace for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Allocate and initialize the array + n = dims(1) + m = dims(2) + allocate(var2d(n,m)) + var2d = 0 + + ! Read the dataset + call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, var2d, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Close access to the dataset + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + return + end subroutine get_dataset_integer_2d + + ! Internal subroutine + subroutine get_dataset_real_2d(file_id, dataset, n, m, var2d, ierr) + + ! Defaults + implicit none + + ! Arguments + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer, intent(out) :: n + integer, intent(out) :: m + real*4, allocatable, intent(out) :: var2d(:,:) + integer, intent(out) :: ierr + + ! Locals + integer(HID_T) :: dataset_id + logical :: link_exists + integer :: hdferr + integer(HID_T) :: dspace_id + integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: rank + + ierr = 0 + + ! See if the dataset is in the file + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + if (.not. link_exists) then + write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Get the dataset id + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dspace id for the variable dimensions + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the rank of the dataset in the file. + call h5sget_simple_extent_ndims_f(dspace_id, rank, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get rank for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check that the rank is 2. + if (rank .ne. 2) then + write(LDT_logunit,*) & + '[ERR] Wrong rank for ', trim(dataset), & + ', expected 2, found ', rank + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dimensions + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close access to the dataspace. + call h5sclose_f(dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close access to dataspace for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Allocate and initialize the array + n = dims(1) + m = dims(2) + allocate(var2d(n,m)) + var2d = 0 + + ! Read the dataset + call h5dread_f(dataset_id, H5T_IEEE_F32LE, var2d, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Close access to the dataset + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + return + end subroutine get_dataset_real_2d + + ! Internal subroutine + subroutine get_dataset_real_1d(file_id, dataset, n, var1d, ierr) + + ! Defaults + implicit none + + ! Arguments + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer, intent(out) :: n + real*4, allocatable, intent(out) :: var1d(:) + integer, intent(out) :: ierr + + ! Locals + integer(HID_T) :: dataset_id + logical :: link_exists + integer :: hdferr + integer(HID_T) :: dspace_id + integer(HSIZE_T) :: dims(1), maxdims(1) + integer :: rank + + ierr = 0 + + ! See if the dataset is in the file + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + if (.not. link_exists) then + write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Get the dataset id + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dspace id for the variable dimensions + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the rank of the dataset in the file. + call h5sget_simple_extent_ndims_f(dspace_id, rank, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get rank for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check that the rank is 1. + if (rank .ne. 1) then + write(LDT_logunit,*) & + '[ERR] Wrong rank for ', trim(dataset), & + ', expected 1, found ', rank + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dimensions + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close access to the dataspace. + call h5sclose_f(dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close access to dataspace for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Allocate and initialize the array + n = dims(1) + allocate(var1d(n)) + var1d = 0 + + ! Read the dataset + call h5dread_f(dataset_id, H5T_IEEE_F32LE, var1d, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Close access to the dataset + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + return + end subroutine get_dataset_real_1d + ! Internal subroutine subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & handle_missing_nrt_field) @@ -547,7 +959,16 @@ subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & integer(HSIZE_T), intent(in) :: dims(:) integer, intent(out) :: ierr integer :: hdferr + write(LDT_logunit,*)'EMK: Start of read_dataset_real...' + write(LDT_logunit,*)'EMK: file_id = ', file_id + write(LDT_logunit,*)'EMK: dataset = ', trim(dataset) + write(LDT_logunit,*)'EMK: dataset_id = ', dataset_id + write(LDT_logunit,*)'EMK: dims = ', dims + flush(LDT_logunit) + call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) + write(LDT_logunit,*)'EMK: After h5dread_f in read_dataset_real...' + flush(LDT_logunit) if (hdferr == -1) then write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) call h5dclose_f(dataset_id, hdferr) @@ -565,6 +986,8 @@ subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & call freeall(ierr) return end if + write(LDT_logunit,*)'EMK: Ending of read_dataset_real...' + flush(LDT_logunit) end subroutine read_dataset_real ! Internal subroutine From 7985451cb438a91320969e75d75ca52795b2a82d Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Thu, 18 Apr 2024 17:06:44 -0400 Subject: [PATCH 321/328] L1B time variable now stored in real*8. This is for consistentcy with the HDF5 file, where the pixel times are stored as doubles (required, because time is seconds from 12Z 1 Jan 2000). --- ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 | 4 +- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 6 +- ldt/SMAP_E_OPL/TOOLSUBS.F90 | 199 +++++++++++++++++--- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 16 +- ldt/SMAP_E_OPL/read_DailyTeffStats.F90 | 16 +- 5 files changed, 206 insertions(+), 35 deletions(-) diff --git a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 index 6a68f5e9f..90ad7b676 100644 --- a/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 +++ b/ldt/SMAP_E_OPL/LDT_smap_e_oplMod.F90 @@ -274,7 +274,7 @@ subroutine LDT_smap_e_oplRun(n) real :: teff_02(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: teff_03(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: SnowDepth(LDT_rc%lnc(n),LDT_rc%lnr(n)) - real :: TIMEsec(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real*8 :: TIMEsec(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: UTChr(LDT_rc%lnc(n),LDT_rc%lnr(n)) integer :: L1B_dir_len integer :: doy_pre, doy_curr @@ -502,6 +502,8 @@ subroutine LDT_smap_e_oplRun(n) ! get UTC call get_UTC(n,TIMEsec,UTChr) + !write(LDT_logunit,*)'EMK: UTChr = ', UTChr + ! retrieve ierr = LDT_create_subdirs(len_trim(SMAPeOPL%SMoutdir), & trim(SMAPeOPL%SMoutdir)) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index 57f0f45ad..76d5e95b4 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -45,12 +45,14 @@ subroutine SMAPL1BRESAMPLE_SUBSET(SMAPFILE,L1B_dir,Orbit,ARFS_TIME,rc) integer :: ierr integer :: rc - REAL*4,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B, TBV_COR_L1B + REAL*8,DIMENSION(:,:),ALLOCATABLE :: TIME_L1B + REAL*4,DIMENSION(:,:),ALLOCATABLE :: TBV_COR_L1B REAL*4,DIMENSION(:,:),ALLOCATABLE :: LAT_L1B, LON_L1B, SCNANG_L1B REAL*4,DIMENSION(:),ALLOCATABLE :: ANTSCN_L1B INTEGER*4,DIMENSION(:,:),ALLOCATABLE :: TBVFLAG_L1B, TBHFLAG_L1B REAL*8,DIMENSION(:), ALLOCATABLE :: ARFS_LAT, ARFS_LON - REAL*4,DIMENSION(2560,1920) :: ARFS_TIME, ARFS_COR_TBV + REAL*8,DIMENSION(2560,1920) :: ARFS_TIME + REAL*4,DIMENSION(2560,1920) :: ARFS_COR_TBV REAL :: T1, T2 diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 70f7021f7..5bb917a4a 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -310,7 +310,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & ! Arguments character(*), intent(in) :: filename - real*4, allocatable, intent(out) :: tb_time_seconds(:,:) + real*8, allocatable, intent(out) :: tb_time_seconds(:,:) real*4, allocatable, intent(out) :: tb_v_surface_corrected(:,:) real*4, allocatable, intent(out) :: tb_lat(:,:), tb_lon(:,:) integer*4, allocatable, intent(out) :: tb_qual_flag_v(:,:) @@ -378,7 +378,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & ! Get the data dataset = "/Brightness_Temperature/tb_lat/" - call get_dataset_real_2d(file_id, dataset, n, m, tb_lat, ierr) + call get_dataset_real4_2d(file_id, dataset, n, m, tb_lat, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -386,7 +386,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if dataset = "/Brightness_Temperature/tb_lon/" - call get_dataset_real_2d(file_id, dataset, n, m, tb_lon, ierr) + call get_dataset_real4_2d(file_id, dataset, n, m, tb_lon, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -394,7 +394,8 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if dataset = "/Brightness_Temperature/tb_time_seconds/" - call get_dataset_real_2d(file_id, dataset, n, m, tb_time_seconds, ierr) + call get_dataset_real8_2d(file_id, dataset, n, m, tb_time_seconds, & + ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -402,7 +403,8 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if dataset = "/Brightness_Temperature/tb_qual_flag_v/" - call get_dataset_integer_2d(file_id, dataset, n, m, tb_qual_flag_v, ierr) + call get_dataset_integer2_2d(file_id, dataset, n, m, & + tb_qual_flag_v, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -410,15 +412,17 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if dataset = "/Brightness_Temperature/tb_qual_flag_h/" - call get_dataset_integer_2d(file_id, dataset, n, m, tb_qual_flag_h, ierr) + call get_dataset_integer2_2d(file_id, dataset, n, m, & + tb_qual_flag_h, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) call freeall(ierr) return end if + dataset = "/Spacecraft_Data/sc_nadir_angle/" - call get_dataset_real_1d(file_id, dataset, n, sc_nadir_angle, ierr) + call get_dataset_real4_1d(file_id, dataset, n, sc_nadir_angle, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -426,8 +430,8 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & return end if dataset = "/Brightness_Temperature/antenna_scan_angle/" - call get_dataset_real_2d(file_id, dataset, n, m, antenna_scan_angle, & - ierr) + call get_dataset_real4_2d(file_id, dataset, n, m, & + antenna_scan_angle, ierr) if (ierr == 1) then call h5fclose_f(file_id, hdferr) call h5close_f(hdferr) @@ -440,7 +444,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & dataset = "/Brightness_Temperature/tb_v_surface_corrected/" call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) if (link_exists) then - call get_dataset_real_2d(file_id, dataset, n, m, & + call get_dataset_real4_2d(file_id, dataset, n, m, & tb_v_surface_corrected, & ierr) if (ierr == 1) then @@ -452,7 +456,7 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & else dataset = "/Brightness_Temperature/tb_v/" write(LDT_logunit,*)'[WARN] Will try substituting ', trim(dataset) - call get_dataset_real_2d(file_id, dataset, n, m, & + call get_dataset_real4_2d(file_id, dataset, n, m, & tb_v_surface_corrected, & ierr) if (ierr == 1) then @@ -474,7 +478,8 @@ SUBROUTINE GetSMAP_L1B_NRT_subset(filename, tb_time_seconds, & contains ! Internal subroutine - subroutine get_dataset_integer_2d(file_id, dataset, n, m, var2d, ierr) + subroutine get_dataset_integer2_2d(file_id, dataset, n, m, var2d, & + ierr) ! Defaults implicit none @@ -488,7 +493,7 @@ subroutine get_dataset_integer_2d(file_id, dataset, n, m, var2d, ierr) integer, intent(out) :: ierr ! Locals - integer(HID_T) :: dataset_id + integer(HID_T) :: dataset_id, datatype_id logical :: link_exists integer :: hdferr integer(HID_T) :: dspace_id @@ -593,7 +598,9 @@ subroutine get_dataset_integer_2d(file_id, dataset, n, m, var2d, ierr) allocate(var2d(n,m)) var2d = 0 - ! Read the dataset + ! Read the dataset. Fortran doesn't have unsigned integers, + ! so we save the 16-bit unsigned integer in a 32-bit signed + ! integer (should have the room). call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, var2d, dims, hdferr) if (hdferr == -1) then write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) @@ -616,10 +623,10 @@ subroutine get_dataset_integer_2d(file_id, dataset, n, m, var2d, ierr) end if return - end subroutine get_dataset_integer_2d + end subroutine get_dataset_integer2_2d ! Internal subroutine - subroutine get_dataset_real_2d(file_id, dataset, n, m, var2d, ierr) + subroutine get_dataset_real4_2d(file_id, dataset, n, m, var2d, ierr) ! Defaults implicit none @@ -633,7 +640,7 @@ subroutine get_dataset_real_2d(file_id, dataset, n, m, var2d, ierr) integer, intent(out) :: ierr ! Locals - integer(HID_T) :: dataset_id + integer(HID_T) :: dataset_id, datatype_id logical :: link_exists integer :: hdferr integer(HID_T) :: dspace_id @@ -739,7 +746,153 @@ subroutine get_dataset_real_2d(file_id, dataset, n, m, var2d, ierr) var2d = 0 ! Read the dataset - call h5dread_f(dataset_id, H5T_IEEE_F32LE, var2d, dims, hdferr) + call h5dread_f(dataset_id, H5T_NATIVE_REAL, var2d, dims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Close access to the dataset + call h5dclose_f(dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & + trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + return + end subroutine get_dataset_real4_2d + + ! Internal subroutine + subroutine get_dataset_real8_2d(file_id, dataset, n, m, var2d, ierr) + + ! Defaults + implicit none + + ! Arguments + integer(HID_T), intent(in) :: file_id + character(*), intent(in) :: dataset + integer, intent(out) :: n + integer, intent(out) :: m + real*8, allocatable, intent(out) :: var2d(:,:) + integer, intent(out) :: ierr + + ! Locals + integer(HID_T) :: dataset_id, datatype_id + logical :: link_exists + integer :: hdferr + integer(HID_T) :: dspace_id + integer(HSIZE_T) :: dims(2), maxdims(2) + integer :: rank + + ierr = 0 + + ! See if the dataset is in the file + call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + if (.not. link_exists) then + write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + endif + + ! Get the dataset id + call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dspace id for the variable dimensions + call h5dget_space_f(dataset_id, dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot find dimensions for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the rank of the dataset in the file. + call h5sget_simple_extent_ndims_f(dspace_id, rank, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get rank for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check that the rank is 2. + if (rank .ne. 2) then + write(LDT_logunit,*) & + '[ERR] Wrong rank for ', trim(dataset), & + ', expected 2, found ', rank + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Get the dimensions + call h5sget_simple_extent_dims_f(dspace_id, dims, maxdims, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get dimensions for ', & + trim(dataset) + call h5sclose_f(dspace_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close access to the dataspace. + call h5sclose_f(dspace_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*) & + '[ERR] Cannot close access to dataspace for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Allocate and initialize the array + n = dims(1) + m = dims(2) + allocate(var2d(n,m)) + var2d = 0 + + ! Read the dataset + call h5dread_f(dataset_id, H5T_NATIVE_DOUBLE, var2d, dims, hdferr) if (hdferr == -1) then write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) call h5dclose_f(dataset_id, hdferr) @@ -761,10 +914,10 @@ subroutine get_dataset_real_2d(file_id, dataset, n, m, var2d, ierr) end if return - end subroutine get_dataset_real_2d + end subroutine get_dataset_real8_2d ! Internal subroutine - subroutine get_dataset_real_1d(file_id, dataset, n, var1d, ierr) + subroutine get_dataset_real4_1d(file_id, dataset, n, var1d, ierr) ! Defaults implicit none @@ -777,7 +930,7 @@ subroutine get_dataset_real_1d(file_id, dataset, n, var1d, ierr) integer, intent(out) :: ierr ! Locals - integer(HID_T) :: dataset_id + integer(HID_T) :: dataset_id, datatype_id logical :: link_exists integer :: hdferr integer(HID_T) :: dspace_id @@ -882,7 +1035,7 @@ subroutine get_dataset_real_1d(file_id, dataset, n, var1d, ierr) var1d = 0 ! Read the dataset - call h5dread_f(dataset_id, H5T_IEEE_F32LE, var1d, dims, hdferr) + call h5dread_f(dataset_id, H5T_NATIVE_REAL, var1d, dims, hdferr) if (hdferr == -1) then write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) call h5dclose_f(dataset_id, hdferr) @@ -904,7 +1057,7 @@ subroutine get_dataset_real_1d(file_id, dataset, n, var1d, ierr) end if return - end subroutine get_dataset_real_1d + end subroutine get_dataset_real4_1d ! Internal subroutine subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 59c0ccdbc..813c06726 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -219,14 +219,17 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & INTEGER(4), PARAMETER :: qualitybit = 0 REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 REAL(8) :: gcdist, lat1, lon1, lat2, lon2 - REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim, tbvl1b_cor + REAL*8,DIMENSION(nrows_l1btb,ncols_l1btb) :: tim + REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbvl1b_cor REAL*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: lat_l1b, lon_l1b, antenna_scan_angle REAL*4,DIMENSION(ncols_l1btb) :: sc_nadir_angle INTEGER*4,DIMENSION(nrows_l1btb,ncols_l1btb) :: tbv_qual_flag, tbh_qual_flag INTEGER(4),DIMENSION(:,:),ALLOCATABLE :: zerodistflag REAL*8,DIMENSION(:),ALLOCATABLE :: ref_lat, ref_lon - REAL*4,DIMENSION(2560,1920) :: arfs_tim, arfs_tbv_cor - REAL*4,DIMENSION(2560,1920) :: arfs_wt_tim, arfs_wt_cor_tbv + REAL*8,DIMENSION(2560,1920) :: arfs_tim + REAL*4,DIMENSION(2560,1920) :: arfs_tbv_cor + REAL*8,DIMENSION(2560,1920) :: arfs_wt_tim + REAL*4,DIMENSION(2560,1920) :: arfs_wt_cor_tbv INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) @@ -281,8 +284,11 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & IF (zerodistflag (rr,cc).EQ.0) THEN IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) - arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) - arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + !arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) + !arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) + arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / (gcdist*gcdist) + arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / (gcdist*gcdist) + END IF IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) diff --git a/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 b/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 index d5a333dda..9757eda27 100644 --- a/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 +++ b/ldt/SMAP_E_OPL/read_DailyTeffStats.F90 @@ -251,17 +251,19 @@ subroutine get_UTC(n,TIMEsec,UTChr) ! ! !USES: use LDT_coreMod + use LDT_logMod, only: LDT_logunit implicit none ! !ARGUMENTS: integer, intent(in) :: n - real :: TIMEsec(LDT_rc%lnc(n),LDT_rc%lnr(n)) + real*8 :: TIMEsec(LDT_rc%lnc(n),LDT_rc%lnr(n)) real :: UTChr(LDT_rc%lnc(n),LDT_rc%lnr(n)) !EOP integer :: ilat, ilon, imo, ida - real :: TIMEday, TIMEhr + real*8 :: TIMEday + real :: TIMEhr real :: UTCyr, UTCmo, UTCda integer :: count_yr, dayremove @@ -269,8 +271,10 @@ subroutine get_UTC(n,TIMEsec,UTChr) do ilon=1,LDT_rc%lnc(n) if (TIMEsec(ilon,ilat).gt.0) then - !write(*,*) 'TIMEsec= ', TIMEsec(ilon,ilat) - TIMEday = TIMEsec(ilon,ilat)/(60*60*24) + !write(LDT_logunit,*) 'EMK: ilon,ilat, TIMEsec= ', & + ! ilon, ilat, TIMEsec(ilon,ilat) + + TIMEday = TIMEsec(ilon,ilat)/DBLE(60*60*24) !write(*,*) 'TIMEday= ', TIMEday count_yr = 0 @@ -327,6 +331,10 @@ subroutine get_UTC(n,TIMEsec,UTChr) UTCda = UTCda + 1 UTChr(ilon,ilat) = UTChr(ilon,ilat) - 24 endif + + !write(LDT_logunit,*) 'EMK: ilon,ilat,TIMEsec,UTChr= ', & + ! ilon, ilat, TIMEsec(ilon,ilat), UTChr(ilon,ilat) + else UTChr(ilon,ilat) = LDT_rc%udef endif From 36352f69cbc59b0d3810c1f99a81b8b181d80c1e Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 19 Apr 2024 12:13:19 -0400 Subject: [PATCH 322/328] Added checks for L1B variable data classes and sizes. --- ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 | 1 + ldt/SMAP_E_OPL/TOOLSUBS.F90 | 472 ++++++++++++++------ 2 files changed, 327 insertions(+), 146 deletions(-) diff --git a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 index 76d5e95b4..57a4343a0 100644 --- a/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 +++ b/ldt/SMAP_E_OPL/SMAPL1BTOL1C_ARFS_SUBSET.F90 @@ -15,6 +15,7 @@ ! 18 Dec 2021: Yonghwan Kwon; modified for LDT ! 09 Feb 2023: Eric Kemp; now processes subset of fields, no output of ! data to separate binary files. +! 19 Apr 2024: Eric Kemp; changed pixel times to REAL*8. ! ! DESCRIPTION: RESAMPLE SMAPL1B TB TO AIR FORCE GRID ! INPUT : SMAP - L1B Brightness Temperature diff --git a/ldt/SMAP_E_OPL/TOOLSUBS.F90 b/ldt/SMAP_E_OPL/TOOLSUBS.F90 index 5bb917a4a..3bba00378 100644 --- a/ldt/SMAP_E_OPL/TOOLSUBS.F90 +++ b/ldt/SMAP_E_OPL/TOOLSUBS.F90 @@ -499,6 +499,9 @@ subroutine get_dataset_integer2_2d(file_id, dataset, n, m, var2d, & integer(HID_T) :: dspace_id integer(HSIZE_T) :: dims(2), maxdims(2) integer :: rank + integer :: class + integer(SIZE_T) :: size + integer :: sign ierr = 0 @@ -529,6 +532,104 @@ subroutine get_dataset_integer2_2d(file_id, dataset, n, m, var2d, & return end if + ! Get the datatype id + call h5dget_type_f(dataset_id, datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the datatype class + call h5tget_class_f(datatype_id, class, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get class for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (class .ne. H5T_INTEGER_F) then + write(LDT_logunit,*)'[ERR] Bad class for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected ', H5T_INTEGER_F, & + ', found ', class + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the size of the datatype. + call h5tget_size_f(datatype_id, size, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get size for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (size .ne. 2) then + write(LDT_logunit,*)'[ERR] Wrong byte size found for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected 2, found ', size + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the sign type of the datatype. Should be unsigned. + call h5tget_sign_f(datatype_id, sign, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get sign type for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (sign .ne. H5T_SGN_NONE_F) then + write(LDT_logunit,*)'[ERR] Wrong sign type found for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected ', H5T_SGN_NONE_F, & + ', found ', sign + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close the datatype + call h5tclose_f(datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + ! Get the dspace id for the variable dimensions call h5dget_space_f(dataset_id, dspace_id, hdferr) if (hdferr == -1) then @@ -646,6 +747,8 @@ subroutine get_dataset_real4_2d(file_id, dataset, n, m, var2d, ierr) integer(HID_T) :: dspace_id integer(HSIZE_T) :: dims(2), maxdims(2) integer :: rank + integer :: class + integer(SIZE_T) :: size ierr = 0 @@ -676,6 +779,79 @@ subroutine get_dataset_real4_2d(file_id, dataset, n, m, var2d, ierr) return end if + ! Get the datatype id + call h5dget_type_f(dataset_id, datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the datatype class + call h5tget_class_f(datatype_id, class, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get class for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (class .ne. H5T_FLOAT_F) then + write(LDT_logunit,*)'[ERR] Bad class for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected ', H5T_FLOAT_F, & + ', found ', class + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the size of the datatype + call h5tget_size_f(datatype_id, size, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get size for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (size .ne. 4) then + write(LDT_logunit,*)'[ERR] Wrong byte size found for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected 4, found ', size + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close the datatype + call h5tclose_f(datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + ! Get the dspace id for the variable dimensions call h5dget_space_f(dataset_id, dspace_id, hdferr) if (hdferr == -1) then @@ -791,6 +967,8 @@ subroutine get_dataset_real8_2d(file_id, dataset, n, m, var2d, ierr) integer(HID_T) :: dspace_id integer(HSIZE_T) :: dims(2), maxdims(2) integer :: rank + integer :: class + integer(SIZE_T) :: size ierr = 0 @@ -821,6 +999,79 @@ subroutine get_dataset_real8_2d(file_id, dataset, n, m, var2d, ierr) return end if + ! Get the datatype id + call h5dget_type_f(dataset_id, datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the datatype class + call h5tget_class_f(datatype_id, class, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get class for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (class .ne. H5T_FLOAT_F) then + write(LDT_logunit,*)'[ERR] Bad class for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected ', H5T_FLOAT_F, & + ', found ', class + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the size of the datatype + call h5tget_size_f(datatype_id, size, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get size for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (size .ne. 8) then + write(LDT_logunit,*)'[ERR] Wrong byte size found for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected 8, found ', size + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close the datatype + call h5tclose_f(datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + ! Get the dspace id for the variable dimensions call h5dget_space_f(dataset_id, dspace_id, hdferr) if (hdferr == -1) then @@ -936,6 +1187,8 @@ subroutine get_dataset_real4_1d(file_id, dataset, n, var1d, ierr) integer(HID_T) :: dspace_id integer(HSIZE_T) :: dims(1), maxdims(1) integer :: rank + integer :: class + integer(SIZE_T) :: size ierr = 0 @@ -966,6 +1219,79 @@ subroutine get_dataset_real4_1d(file_id, dataset, n, var1d, ierr) return end if + ! Get the datatype id + call h5dget_type_f(dataset_id, datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the datatype class + call h5tget_class_f(datatype_id, class, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get class for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (class .ne. H5T_FLOAT_F) then + write(LDT_logunit,*)'[ERR] Bad class for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected ', H5T_FLOAT_F, & + ', found ', class + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Check the size of the datatype + call h5tget_size_f(datatype_id, size, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot get size for ', & + trim(dataset) + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + if (size .ne. 4) then + write(LDT_logunit,*)'[ERR] Wrong byte size found for ', & + trim(dataset) + write(LDT_logunit,*)'[ERR] Expected 4, found ', size + call h5tclose_f(datatype_id, hdferr) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + + ! Close the datatype + call h5tclose_f(datatype_id, hdferr) + if (hdferr == -1) then + write(LDT_logunit,*)'[ERR] Cannot close datatype for ', & + trim(dataset) + call h5dclose_f(dataset_id, hdferr) + call h5fclose_f(file_id, hdferr) + call h5close_f(hdferr) + ierr = 1 + return + end if + ! Get the dspace id for the variable dimensions call h5dget_space_f(dataset_id, dspace_id, hdferr) if (hdferr == -1) then @@ -1059,152 +1385,6 @@ subroutine get_dataset_real4_1d(file_id, dataset, n, var1d, ierr) return end subroutine get_dataset_real4_1d - ! Internal subroutine - subroutine get_dataset_id(file_id, dataset, dataset_id, ierr, & - handle_missing_nrt_field) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(out) :: dataset_id - integer, intent(out) :: ierr - logical, optional, intent(in) :: handle_missing_nrt_field - logical :: link_exists - integer :: hdferr - call h5lexists_f(file_id, trim(dataset), link_exists, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Problem finding ', trim(dataset) - ierr = 1 - if (handle_missing_nrt_field) return - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - if (.not. link_exists) then - write(LDT_logunit,*)'[ERR] Nonexistent dataset ', trim(dataset) - ierr = 1 - if (handle_missing_nrt_field) return - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dopen_f(file_id, trim(dataset), dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot open dataset ', trim(dataset) - ierr = 1 - if (handle_missing_nrt_field) return - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine get_dataset_id - - ! Internal subroutine - subroutine read_dataset_real(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - real*4, intent(inout) :: buf(:,:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - write(LDT_logunit,*)'EMK: Start of read_dataset_real...' - write(LDT_logunit,*)'EMK: file_id = ', file_id - write(LDT_logunit,*)'EMK: dataset = ', trim(dataset) - write(LDT_logunit,*)'EMK: dataset_id = ', dataset_id - write(LDT_logunit,*)'EMK: dims = ', dims - flush(LDT_logunit) - - call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) - write(LDT_logunit,*)'EMK: After h5dread_f in read_dataset_real...' - flush(LDT_logunit) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - write(LDT_logunit,*)'EMK: Ending of read_dataset_real...' - flush(LDT_logunit) - end subroutine read_dataset_real - - ! Internal subroutine - subroutine read_dataset_real_1d(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - real*4, intent(inout) :: buf(:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - call h5dread_f(dataset_id, H5T_IEEE_F32LE, buf, dims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine read_dataset_real_1d - - ! Internal subroutine - subroutine read_dataset_integer(file_id, dataset, dataset_id, buf, & - dims, ierr) - implicit none - integer(HID_T), intent(in) :: file_id - character(*), intent(in) :: dataset - integer(HID_T), intent(in) :: dataset_id - integer*4, intent(inout) :: buf(:,:) - integer(HSIZE_T), intent(in) :: dims(:) - integer, intent(out) :: ierr - integer :: hdferr - call h5dread_f(dataset_id, H5T_NATIVE_INTEGER, buf, dims, hdferr) - if (hdferr == -1) then - write(LDT_logunit,*)'[ERR] Cannot read dataset ', trim(dataset) - call h5dclose_f(dataset_id, hdferr) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - endif - call h5dclose_f(dataset_id, hdferr) - if (hdferr == -1) then - write(LDT_Logunit,*)'[ERR] Problem closing dataset ', & - trim(dataset) - call h5fclose_f(file_id, hdferr) - call h5close_f(hdferr) - call freeall(ierr) - return - end if - end subroutine read_dataset_integer - ! Internal subroutine. Warning -- deallocates memory in ! parent subroutine and resets two variables. This is intended ! for gracefully handling errors returned from HDF5. From 0c21fbaf828036c6d64221bfc54cbbd1d344de1c Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 19 Apr 2024 13:37:55 -0400 Subject: [PATCH 323/328] Tweaked checks for missing values. Idea is to avoid floating point approximation differences between systems. --- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 813c06726..4fa73f137 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -272,10 +272,14 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & IF (gcdist < search_radius) THEN !RESAMPLE ONLY WITHIN THE SEARCH RANGE IF (gcdist < 0.0001D0) THEN !The TB is right on the grid center zerodistflag (rr,cc) = 1 - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + !IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + IF ( .not. tim(jj,ii) < 0) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tim(rr,cc) = tim(jj,ii) ; arfs_wt_tim(rr,cc) = 1.0 END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + !IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + IF ( .not. tbvl1b_cor(jj,ii) < 0 ) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = tbvl1b_cor(jj,ii) ; arfs_wt_cor_tbv(rr,cc) = 1.0 arfs_samplenumv(rr,cc)=1 !Sample number only calculate for correct tb k=k+1; @@ -283,14 +287,18 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & ELSE IF (zerodistflag (rr,cc).EQ.0) THEN - IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + !IF ((ABS (tim(jj,ii) - (-9999.0)).GT.1.0D-7)) THEN !DO IF NOT FILLVALUE(-9999) + IF ( .not. tim(jj,ii) < 0 ) THEN !DO IF NOT FILLVALUE(-9999) + !arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / SNGL (gcdist*gcdist) !arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / SNGL (gcdist*gcdist) arfs_tim(rr,cc) = arfs_tim(rr,cc) + tim(jj,ii) / (gcdist*gcdist) arfs_wt_tim(rr,cc) = arfs_wt_tim(rr,cc) + 1.0 / (gcdist*gcdist) END IF - IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + !IF ((ABS (tbvl1b_cor(jj,ii) - (-9999.0))).GT.1.0D-7) THEN !DO IF NOT FILLVALUE(-9999) + IF ( .not. tbvl1b_cor(jj,ii) < 0 ) THEN !DO IF NOT FILLVALUE(-9999) + arfs_tbv_cor(rr,cc) = arfs_tbv_cor(rr,cc) + tbvl1b_cor(jj,ii) / SNGL (gcdist*gcdist) arfs_wt_cor_tbv(rr,cc) = arfs_wt_cor_tbv(rr,cc) + 1.0 / SNGL (gcdist*gcdist) arfs_samplenumv(rr,cc)=arfs_samplenumv(rr,cc)+1.0 !Sample number only calculate for correct tb From 0e1df14522fa38b62f60a72a4efefe6be4a79416 Mon Sep 17 00:00:00 2001 From: Yeosang Yoon Date: Fri, 5 Apr 2024 10:07:58 -0400 Subject: [PATCH 324/328] Fix bug slope value along the coastal area (cherry picked from commit 2d68c7c6f930a613dc875e97a1c37e578dff5138) --- ldt/params/topo/read_MERIT1K_slope.F90 | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/ldt/params/topo/read_MERIT1K_slope.F90 b/ldt/params/topo/read_MERIT1K_slope.F90 index f3afcb554..8aae117c0 100755 --- a/ldt/params/topo/read_MERIT1K_slope.F90 +++ b/ldt/params/topo/read_MERIT1K_slope.F90 @@ -18,6 +18,7 @@ ! 01 Aug 2012: KR Arsenault; Expanded for elevation tiling ! 30 May 2017: KR Arsenault; Expanded for Antarctica ! 03 Mar 2020: Yeosang Yoon; Modify codes for MERIT DEM +! 04 Apr 2024: Yeosang Yoon; Fix bug slope value along the coastal area ! ! !INTERFACE: subroutine read_MERIT1K_slope( n, num_bins, fgrd, slopeave ) @@ -279,6 +280,11 @@ subroutine read_MERIT1K_slope( n, num_bins, fgrd, slopeave ) do r = 1, subpnr do c = 1, subpnc subset_elev(c,r) = yrev_elev(lon_line(c,r),lat_line(c,r)) + + ! for coastal areas + if (subset_elev(c,r) .eq. LDT_rc%udef) then + subset_elev(c,r) = 0. + endif enddo enddo deallocate( yrev_elev ) From 39311185675d57b9087c6127ab05038193c870c1 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Tue, 23 Apr 2024 08:34:07 -0400 Subject: [PATCH 325/328] Bug fixes to ensure files are closed and file unit numbers released. --- lis/metforcing/usaf/USAF_GagesMod.F90 | 15 ++++++--------- lis/metforcing/usaf/USAF_PreobsReaderMod.F90 | 19 ++++++++++--------- 2 files changed, 16 insertions(+), 18 deletions(-) diff --git a/lis/metforcing/usaf/USAF_GagesMod.F90 b/lis/metforcing/usaf/USAF_GagesMod.F90 index f3df49a9e..51c8c47b1 100644 --- a/lis/metforcing/usaf/USAF_GagesMod.F90 +++ b/lis/metforcing/usaf/USAF_GagesMod.F90 @@ -1753,8 +1753,7 @@ subroutine USAF_gages_write_data(this, filename) end do 300 continue - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file end subroutine USAF_gages_write_data @@ -1824,8 +1823,8 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) end if return end if - iunit = LIS_getNextUnitNumber() + iunit = LIS_getNextUnitNumber() open(iunit, file=trim(filename), iostat=istat) if (istat .ne. 0) then write(LIS_logunit,*)'[WARN] Problem opening ', trim(filename) @@ -1837,6 +1836,7 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) alert_number, message) alert_number = alert_number + 1 end if + call LIS_releaseUnitNumber(iunit) return end if @@ -1852,8 +1852,7 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) alert_number, message) alert_number = alert_number + 1 end if - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file return end if @@ -1868,8 +1867,7 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) alert_number, message) alert_number = alert_number + 1 end if - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file return end if @@ -1923,8 +1921,7 @@ subroutine USAF_gages_read_data(this, filename, date10, alert_number) i9, 1x, i9) end do - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file 300 continue ! If read was successful, copy to USAF_gages_t structure. diff --git a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 index 7c069421e..e92329c55 100644 --- a/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 +++ b/lis/metforcing/usaf/USAF_PreobsReaderMod.F90 @@ -171,6 +171,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) end if + call LIS_releaseUnitNumber(iunit) if (use_expanded_station_ids == 1) exit ! These files are global cycle end if @@ -187,8 +188,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & call LIS_alert('LIS.USAF_read_preobs', & alert_number, message) end if - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file if (use_expanded_station_ids == 1) exit ! These files are global cycle end if @@ -209,9 +209,7 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & end if nsize_total = nsize_total + nsize - close(iunit) - call LIS_releaseUnitNumber(iunit) - + call LIS_releaseUnitNumber(iunit) ! Closes file if (use_expanded_station_ids == 1) exit ! These files are global end do @@ -274,13 +272,14 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & iunit = LIS_getNextUnitNumber() open(iunit, file=trim(filename), status='old', iostat=ierr) - if (ierr .ne. 0) cycle - + if (ierr .ne. 0) then + call LIS_releaseUnitNumber(iunit) + cycle + end if nsize = 0 read(iunit, *, iostat=ierr) nsize if (ierr .ne. 0) then - close(iunit) - call LIS_releaseUnitNumber(iunit) + call LIS_releaseUnitNumber(iunit) ! Closes file if (use_expanded_station_ids == 1) exit cycle end if @@ -553,6 +552,8 @@ subroutine USAF_read_preobs(preobsdir, presavdir, & end if end do + call LIS_releaseUnitNumber(iunit) ! Closes file + if (use_expanded_station_ids == 1) cycle ! These files are global end do ! ihemi From c3dfc61ff2a8cc0d055c5f8421b36f203a9e9f84 Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 26 Apr 2024 14:25:30 -0400 Subject: [PATCH 326/328] Added scripts and templates to run SMAP_E_OPL retrievals. Some of this was supposed to have been committed earlier. --- .../customize_ldt_smapeopl_config.py | 127 ++++++++++++ .../SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl | 53 +++++ .../SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl | 55 +++++ .../ldt.config.smapeopl.noahmp.tmpl | 53 +++++ .../SMAP_E_OPL/new.run_smap_e_opl_discover.sh | 186 +++++++++++++++++ .../SMAP_E_OPL/run_smap_e_opl_discover.sh | 189 ++++++++++++++++++ .../usaf/SMAP_E_OPL/run_smap_e_opl_hpc11.sh | 188 +++++++++++++++++ 7 files changed, 851 insertions(+) create mode 100755 ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl create mode 100755 ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl create mode 100755 ldt/utils/usaf/SMAP_E_OPL/new.run_smap_e_opl_discover.sh create mode 100755 ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh create mode 100755 ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_hpc11.sh diff --git a/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py b/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py new file mode 100755 index 000000000..074671132 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/customize_ldt_smapeopl_config.py @@ -0,0 +1,127 @@ +#!/usr/bin/env python3 + +""" +SCRIPT: customize_ldt_smapeopl_config.py + +Creates a customized ldt.config file for generating SMAP_E_OPL soil +moisture retrieval with LDT. + +User must provide template ldt.config file, valid date/time, and +filelist suffix number via command line arguments. + +To see usage statement, run script on command line w/o arguments. + +REVISION HISTORY: +25 Jan 2024: Eric Kemp. Initial specification. +26 Jan 2024: Eric Kemp. Added filelist suffix number. +""" + +import datetime +import os +import sys + +def _usage(): + """Prints usage statement for script""" + stmt = f"USAGE: {sys.argv[0]} YYYYMMDDHH ldt_config_tmpl_name" + stmt += " filelist_suffix_number" + print(stmt) + +def _proc_valid_datetime(): + """Process command line argument for valid time""" + if len(sys.argv[1]) != 10: + print("ERR, invalid date/time for SMAP_E_OPL!") + print(f"ERR, received {sys.argv[1]}") + _usage() + sys.exit(1) + + yyyymmddhh = sys.argv[1] + try: + yyyy = int(yyyymmddhh[0:4]) + mm = int(yyyymmddhh[4:6]) + dd = int(yyyymmddhh[6:8]) + hh = int(yyyymmddhh[8:]) + validdt = \ + datetime.datetime(year=yyyy, + month=mm, + day=dd, + hour=hh) + except (TypeError, ValueError): + print("ERR, invalid date/time for SMAP_E_OPL!") + print(f"ERR, received {sys.argv[1]}") + _usage() + sys.exit(1) + + return validdt + +def _proc_ldt_config_tmpl_name(): + """Process command line for ldt config template file name""" + ldt_config_tmpl = sys.argv[2] + if not os.path.exists(ldt_config_tmpl): + print(f"ERR, cannot file template file {ldt_config_tmpl}") + _usage() + sys.exit(1) + return ldt_config_tmpl + +def _proc_filelist_suffix_number(): + """Process command line for filelist suffix number""" + suffix_number = sys.argv[3] + try: + int_value = int(suffix_number) + except ValueError: + print("ERR, did not receive valid filelist suffix number!") + _usage() + sys.exit(1) + if int_value < 0: + print("ERR, filelist suffix must be nonnegative!") + _usage() + sys.exit(1) + return int_value + +def _proc_cmd_line(): + """Process command line and return valid datetime for SMAP_E_OPL""" + if len(sys.argv) != 4: + print("ERR, invalid number of command line arguments!") + _usage() + sys.exit(1) + validdt = _proc_valid_datetime() + ldt_config_tmpl = _proc_ldt_config_tmpl_name() + filelist_suffix_number = _proc_filelist_suffix_number() + return validdt, ldt_config_tmpl, filelist_suffix_number + +def _create_new_ldt_config(validdt, ldt_config_tmpl, \ + filelist_suffix_number): + """Create new ldt.config customized to valid date""" + with open(ldt_config_tmpl, "r", encoding='ascii') as file: + lines = file.readlines() + yyyymmddhh = f"{validdt.year:04d}{validdt.month:02d}" + \ + f"{validdt.day:02d}{validdt.hour:02d}" + newfile = f"ldt.config.smapeopl.{yyyymmddhh}" + with open(newfile, "w", encoding='ascii') as file: + for line in lines: + if "SMAP_E_OPL valid date (YYYYMMDDHH):" in line: + newline = "SMAP_E_OPL valid date (YYYYMMDDHH): " + newline += f"{yyyymmddhh}\n" + file.write(newline) + continue + if "LDT diagnostic file:" in line: + newline = "LDT diagnostic file: " + newline += f"ldtlog.{yyyymmddhh}\n" + file.write(newline) + continue + if "SMAP_E_OPL filelist suffix number:" in line: + newline = "SMAP_E_OPL filelist suffix number: " + newline += f"{filelist_suffix_number}\n" + file.write(newline) + continue + # Pass through all other lines + file.write(line) + continue + +def _main(): + """Main driver""" + validdt, ldt_config_tmpl, filelist_suffix_number = _proc_cmd_line() + _create_new_ldt_config(validdt, ldt_config_tmpl, \ + filelist_suffix_number) + +if __name__ == "__main__": + _main() diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl new file mode 100755 index 000000000..f692e8636 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.jules.tmpl @@ -0,0 +1,53 @@ +# == LDT Main Entry Options == + +LDT running mode: "OPL E SMAP soil moisture retrieval" #"LSM parameter processing" # LDT type of run-mode (top-level option) +LDT diagnostic file: ldtlog.2021070200 + + +# Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021070200 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +SMAP_E_OPL LIS soil temperature directory: input/jules50/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/jules50/dec2021 +#SMAP_E_OPL LIS soil temperature directory: input/Jules50_OL + +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/jules50_daily_statistics_15obs.nc +SMAP_E_OPL LIS snow directory: input/USAFSI +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 1 + +# Legacy settings that must be in config file +Processed LSM parameter filename: lis_input.10k.global.ps41.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT output directory: LDTOUT +Undefined value: -9999.0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl new file mode 100755 index 000000000..0bd086692 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noah.tmpl @@ -0,0 +1,55 @@ + +LDT running mode: "OPL E SMAP soil moisture retrieval" +LDT diagnostic file: ldtlog.2021071519 + +#Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021071519 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +#SMAP_E_OPL L1B data directory: input/SMAP_L1B_historical +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +#SMAP_E_OPL L1B data directory: input/SMAP_L1B_fake +#SMAP_E_OPL L1B data type: 2 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) + +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +#SMAP_E_OPL LIS soil temperature directory: input/Noah39_OL +SMAP_E_OPL LIS soil temperature directory: input/noah39/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/noah39/dec2021 +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/noah39_daily_statistics_15obs.nc +#SMAP_E_OPL LIS snow directory: input/Noah39_snow +SMAP_E_OPL LIS snow directory: input/USAFSI +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 0 + +# Legacy settings that must in the config file. +Processed LSM parameter filename: input/lis_input.global.noah39.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT output directory: LDTOUT +Undefined value: -9999.0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl new file mode 100755 index 000000000..dfb0c594f --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/ldt.config.smapeopl.noahmp.tmpl @@ -0,0 +1,53 @@ +#Overall driver options +LDT running mode: "OPL E SMAP soil moisture retrieval" + +#Rotated GALWEM 10-km domain +Map projection of the LIS domain: latlon +Run domain lower left lat: -89.9531250 +Run domain lower left lon: -179.9296875 +Run domain upper right lat: 89.9531250 +Run domain upper right lon: 179.9296875 +Run domain resolution (dx): 0.1406250 +Run domain resolution (dy): 0.0937500 + + +# ------------------------ +# Section for Operational enhanced SMAP soil moisture retrieval +SMAP_E_OPL valid date (YYYYMMDDHH): 2021071519 +SMAP_E_OPL soil moisture output directory: output/SM_retrieval +SMAP_E_OPL L1B data directory: input/SMAP_L1B_TB_NRT +SMAP_E_OPL L1B data type: 1 #1: NRT; 2: Historical(for evaluations) +SMAP_E_OPL write L1B resampled output: 0 #0: off; 1: on +SMAP_E_OPL L1B resampled output directory: output/ARFS_RESAMPLE +SMAP_E_OPL LIS soil temperature directory: input/noahmp401/jul2021 +#SMAP_E_OPL LIS soil temperature directory: input/noahmp401/dec2021 +#SMAP_E_OPL LIS soil temperature directory: input/Noahmp401_OL + +SMAP_E_OPL apply soil temperature bias correction: 1 #0: off; 1: on +SMAP_E_OPL reference Teff daily statistics file: input/geos_daily_statistics_15obs.nc +SMAP_E_OPL LIS Teff daily statistics file: input/noahmp401_daily_statistics_15obs.nc +SMAP_E_OPL LIS snow directory: input/USAFSI + +SMAP_E_OPL snow depth threshold: 0.05 #unit: m +SMAP_E_OPL TAU directory: input/TAU_ARFS_DAILY +SMAP_E_OPL OMEGA file: input/PRMS_RETRIEVAL_ARFS/omega_arfs.dat +SMAP_E_OPL soil bulk density file: input/PRMS_RETRIEVAL_ARFS/bd_arfs_006.dat +SMAP_E_OPL soil clay fraction file: input/PRMS_RETRIEVAL_ARFS/clay_arfs_006.dat +SMAP_E_OPL roughness file: input/PRMS_RETRIEVAL_ARFS/hvalue_arfs.dat +SMAP_E_OPL landcover file: input/PRMS_RETRIEVAL_ARFS/SMAP_LC_ARFS.bin + +# Settings for USAF NRT GHI history files +SMAP_E_OPL LIS ensemble size: 12 +SMAP_E_OPL LIS total number of tiles (including ensembles): 58982400 +SMAP_E_OPL LIS number of tiles per grid point: 1 +SMAP_E_OPL filelist suffix number: 1 + +# Legacy entries that must be in the file. +Processed LSM parameter filename: ./output/lis_input.global.noahmp401.nc +LIS number of nests: 1 +Number of surface model types: 2 +Surface model types: "LSM" "Openwater" +Number of met forcing sources: 0 +LDT diagnostic file: ldtlog.2021071519 +LDT output directory: LDTOUT +Undefined value: -9999.0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/new.run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/new.run_smap_e_opl_discover.sh new file mode 100755 index 000000000..654c97344 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/new.run_smap_e_opl_discover.sh @@ -0,0 +1,186 @@ +#!/bin/sh +#SBATCH --job-name=smapeopl +#SBATCH --time=0:20:00 +#SBATCH --account s1189 +#SBATCH --output smapeopl.slurm.out +#SBATCH --ntasks=13 --ntasks-per-node=1 +#SBATCH --mail-type=ALL +#SBATCH --qos=debug +#-------------------------------------------------------------------------- +# +# SCRIPT: run_smap_e_opl_discover.sh +# +# Batch script for running LDT to generate SMAP_E_OPL retrievals with +# LDT. Customized for NASA Discover supercomputer running SLURM batch +# queueing system. +# +# USAGE: run_smap_e_opl_discover.sh $startdate $starthour $enddate \ +# $endhour $lsm +# where $startdate and $enddate specify the inclusive UTC +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD); +# $starthour and $endhour specify the hours of the respective +# dates (formatted HH); and $lsm is the LSM name, used to select +# the ldt.config template file. +# +# Based on Korn shell script provided by Pang-Wei Liu. +# +# REVISION HISTORY: +# 25 Jan 2024: Eric Kemp. Initial specification. +# 26 Jan 2024: Eric Kemp. Added in-script parallelization following +# autotuning scripts. +# +#-------------------------------------------------------------------------- + +ulimit -s unlimited + +# When a batch script is started, it starts in the user's home directory. +# Change to the directory where job was submitted. +if [ ! -z $SLURM_SUBMIT_DIR ] ; then + cd $SLURM_SUBMIT_DIR || exit 1 +fi + +# Environment +module purge +unset LD_LIBRARY_PATH +module use --append /home/emkemp/privatemodules +module load lisf_7.5_intel_2021.4.0_s2s + +# Paths on local system +SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/scripts +BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/bin +TMPLDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/tmpl + +# Get the command line arguments to specify the training period +if [ -z "$1" ] ; then + echo "ERROR, Missing start date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$2" ] ; then + echo "ERROR, Missing start hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$3" ] ; then + echo "ERROR, Missing end date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$4" ] ; then + echo "ERROR, Missing end hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$5" ] ; then + echo "ERROR, missing LSM option!" && exit 1 +fi + +# Use the command line arguments to set start and end datetime limits. +# Sanity check and report errors if found. + +istart="$1 $2" +iend="$3 $4" +start_dt=$(date "+%F %H" -d "$istart") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad startdate and hour" && exit 1 +fi +end_dt=$(date "+%F %H" -d "$iend") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad enddate and hour" && exit 1 +fi +d="$start_dt" +cur_yyyymmddhh=$(date -d "$start_dt" +%Y%m%d%H) +end_yyyymmddhh=$(date -d "$end_dt" +%Y%m%d%H) + +# Use the LSM command line argument to select the appropriate ldt.config +# template. +lsm="$5" +if [ "$lsm" = "noah" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noah.tmpl" +elif [ "$lsm" = "noahmp" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noahmp.tmpl" +elif [ "$lsm" = "jules" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.jules.tmpl" +else + echo "ERR, invalid LSM option, must be noah, noahmp, or jules" + exit 1 +fi +if [ ! -e $tmplfile ] ; then + echo "ERR, $tmplfile not found!" && exit 1 +fi + +# Other sanity checks +if [ ! -e $BINDIR/LDT ] ; then + echo "ERR, $BINDIR/LDT does not exist!" && exit 1 +fi +if [ ! -e $SCRIPTDIR/customize_ldt_smapeopl_config.py ] ; then + echo "ERR, $SCRIPTDIR/customize_ldt_smapeopl_config.py not found!" + exit 1 +fi + +# Loop through all times. This requires parallel invocations using +# srun. +echo "INFO, started SMAP_E_OPL retrievals at `date`" +i=0 +while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do + + echo "INFO, working on $cur_yyyymmddhh at `date`" + + # Update ldt.config file + $SCRIPTDIR/customize_ldt_smapeopl_config.py "$cur_yyyymmddhh" \ + "$tmplfile" $i || exit 1 + + # Run LDT + srun --ntasks=1 --nodes=1 --exclusive \ + $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + PIDS+=($!) + actives+=(1) + yyyymmddhh+=("$cur_yyyymmddhh") + ((i+=1)) + sleep 1 # Don't overwhelm SLURM + + # Update valid time + d=$(date -d "$d + 1 hours") + cur_yyyymmddhh=$(date -d "$d" +%Y%m%d%H) + +done + +# Wait until all the jobs complete +count=$i +echo "INFO, waiting for $count task(s) to complete..." +while true; do + for i in "${!PIDS[@]}"; do + if [ "${actives[$i]}" -eq 0 ] ; then + continue + fi + pid="${PIDS[$i]}" + # See if pid is still running + ps --pid "$pid" > /dev/null + if [ "$?" -ne 0 ] ; then # ps doesn't see it, so it terminated + wait "$pid" + return_code="$?" + actives[$i]=0 + count=$((count-1)) + if [ "${return_code}" -ne 0 ] ; then + echo "WARN, SMAP_E_OPL ${yyyymmddhh[$i]} failed around `date`" + else + echo "INFO, SMAP_E_OPL ${yyyymmddhh[$i]} finished with no reported error at `date`" + fi + if [ "$count" -gt 0 ] ; then + echo "INFO, Waiting for $count task(s) to complete..." + fi + fi + done + # See if we are all done. Assume we are, and correct if we are not. + alldone=1 + for i in "${!actives[@]}"; do + if [ "${actives[$i]}" -eq 1 ] ; then + alldone=0 + fi + done + if [ "${alldone}" -eq 1 ] ; then + break + fi +done +unset PIDS +unset actives +unset yyyymmddhh + +# The end +exit 0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh new file mode 100755 index 000000000..954634065 --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -0,0 +1,189 @@ +#!/bin/sh +#SBATCH --job-name=smapeopl +#SBATCH --time=0:20:00 +#SBATCH --account s1189 +#SBATCH --output smapeopl.slurm.out +#SBATCH --ntasks=13 --ntasks-per-node=13 +#SBATCH --mail-type=ALL +##SBATCH --qos=debug +#-------------------------------------------------------------------------- +# +# SCRIPT: run_smap_e_opl_discover.sh +# +# Batch script for running LDT to generate SMAP_E_OPL retrievals with +# LDT. Customized for NASA Discover supercomputer running SLURM batch +# queueing system. +# +# USAGE: run_smap_e_opl_discover.sh $startdate $starthour $enddate \ +# $endhour $lsm +# where $startdate and $enddate specify the inclusive UTC +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD +# or YYYYMMDD); $starthour and $endhour specify the hours of the +# respective dates (formatted HH); and $lsm is the LSM name, used +# to select the ldt.config template file. +# +# Based on Korn shell script provided by Pang-Wei Liu. +# +# REVISION HISTORY: +# 25 Jan 2024: Eric Kemp. Initial specification. +# 26 Jan 2024: Eric Kemp. Added in-script parallelization following +# autotuning scripts. +# 28 Feb 2024: Eric Kemp. Now uses single node. +# +#-------------------------------------------------------------------------- + +ulimit -s unlimited + +# When a batch script is started, it starts in the user's home directory. +# Change to the directory where job was submitted. +if [ ! -z $SLURM_SUBMIT_DIR ] ; then + cd $SLURM_SUBMIT_DIR || exit 1 +fi + +# Environment +module purge +unset LD_LIBRARY_PATH +module use --append /home/emkemp/privatemodules +module load lisf_7.5_intel_2021.4.0_s2s + +# Paths on local system +SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/scripts +BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/bin +TMPLDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/tmpl + +# Get the command line arguments to specify the training period +if [ -z "$1" ] ; then + echo "ERROR, Missing start date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$2" ] ; then + echo "ERROR, Missing start hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$3" ] ; then + echo "ERROR, Missing end date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$4" ] ; then + echo "ERROR, Missing end hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$5" ] ; then + echo "ERROR, missing LSM option!" && exit 1 +fi + +# Use the command line arguments to set start and end datetime limits. +# Sanity check and report errors if found. + +istart="$1 $2" +iend="$3 $4" +start_dt=$(date "+%F %H" -d "$istart") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad startdate and hour" && exit 1 +fi +end_dt=$(date "+%F %H" -d "$iend") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad enddate and hour" && exit 1 +fi +d="$start_dt" +cur_yyyymmddhh=$(date -d "$start_dt" +%Y%m%d%H) +end_yyyymmddhh=$(date -d "$end_dt" +%Y%m%d%H) + +# Use the LSM command line argument to select the appropriate ldt.config +# template. +lsm="$5" +if [ "$lsm" = "noah" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noah.tmpl" +elif [ "$lsm" = "noahmp" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noahmp.tmpl" +elif [ "$lsm" = "jules" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.jules.tmpl" +else + echo "ERR, invalid LSM option, expected noah, noahmp, or jules; got $lsm" + exit 1 +fi +if [ ! -e $tmplfile ] ; then + echo "ERR, $tmplfile not found!" && exit 1 +fi + +# Other sanity checks +if [ ! -e $BINDIR/LDT ] ; then + echo "ERR, $BINDIR/LDT does not exist!" && exit 1 +fi +if [ ! -e $SCRIPTDIR/customize_ldt_smapeopl_config.py ] ; then + echo "ERR, $SCRIPTDIR/customize_ldt_smapeopl_config.py not found!" + exit 1 +fi + +# Loop through all times. This requires parallel invocations using +# srun. +echo "INFO, started SMAP_E_OPL retrievals at `date`" +i=0 +while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do + + echo "INFO, working on $cur_yyyymmddhh at `date`" + + # Update ldt.config file + $SCRIPTDIR/customize_ldt_smapeopl_config.py "$cur_yyyymmddhh" \ + "$tmplfile" $i || exit 1 + + # Run LDT + srun --ntasks=1 --cpus-per-task=1 \ + $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + + PIDS+=($!) + actives+=(1) + yyyymmddhh+=("$cur_yyyymmddhh") + ((i+=1)) + sleep 1 # Don't overwhelm SLURM + + # Update valid time + d=$(date -d "$d + 1 hours") + cur_yyyymmddhh=$(date -d "$d" +%Y%m%d%H) + +done + +# Wait until all the jobs complete +count=$i +echo "INFO, waiting for $count task(s) to complete..." +while true; do + for i in "${!PIDS[@]}"; do + if [ "${actives[$i]}" -eq 0 ] ; then + continue + fi + pid="${PIDS[$i]}" + # See if pid is still running + ps --pid "$pid" > /dev/null + if [ "$?" -ne 0 ] ; then # ps doesn't see it, so it terminated + wait "$pid" + return_code="$?" + actives[$i]=0 + count=$((count-1)) + if [ "${return_code}" -ne 0 ] ; then + echo "WARN, SMAP_E_OPL ${yyyymmddhh[$i]} failed around `date`" + else + echo "INFO, SMAP_E_OPL ${yyyymmddhh[$i]} finished with no reported error at `date`" + fi + if [ "$count" -gt 0 ] ; then + echo "INFO, Waiting for $count task(s) to complete..." + fi + fi + done + # See if we are all done. Assume we are, and correct if we are not. + alldone=1 + for i in "${!actives[@]}"; do + if [ "${actives[$i]}" -eq 1 ] ; then + alldone=0 + fi + done + if [ "${alldone}" -eq 1 ] ; then + break + fi +done +unset PIDS +unset actives +unset yyyymmddhh + +# The end +touch smapeopl.job.done +exit 0 diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_hpc11.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_hpc11.sh new file mode 100755 index 000000000..9fabdeb6d --- /dev/null +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_hpc11.sh @@ -0,0 +1,188 @@ +#!/bin/sh +#SBATCH --job-name=smapeopl +#SBATCH --time=0:30:00 +#SBATCH --account=NWP601 +#SBATCH --output smapeopl.slurm.out +#SBATCH --ntasks=13 --ntasks-per-node=13 +#SBATCH --cluster-constraint=blue +#SBATCH --exclusive +#SBATCH --mem=0 +#-------------------------------------------------------------------------- +# +# SCRIPT: run_smap_e_opl_hpc11.sh +# +# Batch script for running LDT to generate SMAP_E_OPL retrievals with +# LDT. Customized for USAF HPC11 supercomputer running SLURM batch +# queueing system. +# +# USAGE: run_smap_e_opl_hpc11.sh $startdate $starthour $enddate \ +# $endhour $lsm +# where $startdate and $enddate specify the inclusive UTC +# date range to run SMAP_E_OPL retrievals (formatted YYYY-MM-DD +# or YYYYMMDD); $starthour and $endhour specify the hours of the +# respective dates (formatted HH); and $lsm is the LSM name, used +# to select the ldt.config template file. +# +# Based on Korn shell script provided by Pang-Wei Liu. +# +# REVISION HISTORY: +# 29 Mar 2024: Eric Kemp. Initial specification, based on Discover script. +# +#-------------------------------------------------------------------------- + +ulimit -s unlimited + +# When a batch script is started, it starts in the user's home directory. +# Change to the directory where job was submitted. +if [ ! -z $SLURM_SUBMIT_DIR ] ; then + cd $SLURM_SUBMIT_DIR || exit 1 +fi + +# Environment +module use --append /ccs/home/emkemp/hpc11/privatemodules +module load lisf_7.6_prgenv_cray_8.5.0_cpe_23.12_draft +module load afw-python/3.10-202312 + +# Paths on local system +SCRIPTDIR=/lustre/storm/nwp601/proj-shared/emkemp/lis76_smap_e_opl/scripts +BINDIR=/lustre/storm/nwp601/proj-shared/emkemp/lis76_smap_e_opl/bin +TMPLDIR=/lustre/storm/nwp601/proj-shared/emkemp/lis76_smap_e_opl/tmpl + +# Get the command line arguments to specify the training period +if [ -z "$1" ] ; then + echo "ERROR, Missing start date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$2" ] ; then + echo "ERROR, Missing start hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$3" ] ; then + echo "ERROR, Missing end date for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$4" ] ; then + echo "ERROR, Missing end hour for SMAP_E_OPL retrievals!" + exit 1 +fi +if [ -z "$5" ] ; then + echo "ERROR, missing LSM option!" && exit 1 +fi + +# Use the command line arguments to set start and end datetime limits. +# Sanity check and report errors if found. + +istart="$1 $2" +iend="$3 $4" +start_dt=$(date "+%F %H" -d "$istart") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad startdate and hour" && exit 1 +fi +end_dt=$(date "+%F %H" -d "$iend") +if [ "$?" -ne 0 ] ; then + echo "ERR, Bad enddate and hour" && exit 1 +fi +d="$start_dt" +cur_yyyymmddhh=$(date -d "$start_dt" +%Y%m%d%H) +end_yyyymmddhh=$(date -d "$end_dt" +%Y%m%d%H) + +# Use the LSM command line argument to select the appropriate ldt.config +# template. +lsm="$5" +if [ "$lsm" = "noah" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noah.tmpl" +elif [ "$lsm" = "noahmp" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.noahmp.tmpl" +elif [ "$lsm" = "jules" ] ; then + tmplfile="$TMPLDIR/ldt.config.smapeopl.jules.tmpl" +else + echo "ERR, invalid LSM option, expected noah, noahmp, or jules; got $lsm" + exit 1 +fi +if [ ! -e $tmplfile ] ; then + echo "ERR, $tmplfile not found!" && exit 1 +fi + +# Other sanity checks +if [ ! -e $BINDIR/LDT ] ; then + echo "ERR, $BINDIR/LDT does not exist!" && exit 1 +fi +if [ ! -e $SCRIPTDIR/customize_ldt_smapeopl_config.py ] ; then + echo "ERR, $SCRIPTDIR/customize_ldt_smapeopl_config.py not found!" + exit 1 +fi + +# Loop through all times. This requires parallel invocations using +# srun. +echo "INFO, started SMAP_E_OPL retrievals at `date`" +i=0 +while [ "$cur_yyyymmddhh" -le "$end_yyyymmddhh" ] ; do + + echo "INFO, working on $cur_yyyymmddhh at `date`" + + # Update ldt.config file + $SCRIPTDIR/customize_ldt_smapeopl_config.py "$cur_yyyymmddhh" \ + "$tmplfile" $i || exit 1 + + # Run LDT + srun --ntasks=1 --cpus-per-task=1 \ + $BINDIR/LDT ldt.config.smapeopl."$cur_yyyymmddhh" & + + PIDS+=($!) + actives+=(1) + yyyymmddhh+=("$cur_yyyymmddhh") + ((i+=1)) + sleep 1 # Don't overwhelm SLURM + + # Update valid time + d=$(date -d "$d + 1 hours") + cur_yyyymmddhh=$(date -d "$d" +%Y%m%d%H) + +done + +# Wait until all the jobs complete +count=$i +echo "INFO, waiting for $count task(s) to complete..." +while true; do + for i in "${!PIDS[@]}"; do + if [ "${actives[$i]}" -eq 0 ] ; then + continue + fi + pid="${PIDS[$i]}" + # See if pid is still running + echo `ps --pid "$pid"` + + ps --pid "$pid" > /dev/null + if [ "$?" -ne 0 ] ; then # ps doesn't see it, so it terminated + wait "$pid" + return_code="$?" + actives[$i]=0 + count=$((count-1)) + if [ "${return_code}" -ne 0 ] ; then + echo "WARN, SMAP_E_OPL ${yyyymmddhh[$i]} failed around `date`" + else + echo "INFO, SMAP_E_OPL ${yyyymmddhh[$i]} finished with no reported error at `date`" + fi + if [ "$count" -gt 0 ] ; then + echo "INFO, Waiting for $count task(s) to complete..." + fi + fi + done + # See if we are all done. Assume we are, and correct if we are not. + alldone=1 + for i in "${!actives[@]}"; do + if [ "${actives[$i]}" -eq 1 ] ; then + alldone=0 + fi + done + if [ "${alldone}" -eq 1 ] ; then + break + fi +done +unset PIDS +unset actives +unset yyyymmddhh + +# The end +touch smapeopl.job.done +exit 0 From 80be5d9282b8f004361c3669caef5d6cf838575a Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 26 Apr 2024 14:26:47 -0400 Subject: [PATCH 327/328] Added initialization of array before use. --- ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 index 4fa73f137..5034a0717 100644 --- a/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 +++ b/ldt/SMAP_E_OPL/invdist_l1b2arfs.F90 @@ -215,6 +215,8 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & sc_nadir_angle, antenna_scan_angle, nrows_l1btb, ncols_l1btb, & ref_lat, ref_lon, arfs_tim, arfs_tbv_cor) + use LDT_logMod, only: LDT_logunit + INTEGER(4) :: ii, jj, k, r, c, rr, rmin, rmax, cc, cmin, cmax, nrows_l1btb, ncols_l1btb INTEGER(4), PARAMETER :: qualitybit = 0 REAL(8), PARAMETER :: RE_KM = 6371.228, search_radius = 20.0, PI = 3.141592653589793238, d2r = PI/180.0 @@ -233,6 +235,8 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & INTEGER*4,DIMENSION(2560,1920) :: arfs_samplenumv ALLOCATE(zerodistflag(size(ref_lon),size(ref_lat))) + zerodistflag = 0 ! EMK Added initialization + !INITIAL THE OUTPUT VARIABLES arfs_tim=0.0 arfs_tbv_cor=0.0 @@ -243,7 +247,10 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & DO ii = 1,ncols_l1btb IF (ABS (sc_nadir_angle(ii)) <= 2.0) THEN DO jj = 1,nrows_l1btb + + IF (ABS (antenna_scan_angle(jj,ii)).LE.360.00) THEN + lat1 = DBLE (lat_l1b(jj,ii)*d2r) lon1 = DBLE (lon_l1b(jj,ii)*d2r) ! FIND ARFS_GRID (r,c) @@ -255,6 +262,7 @@ SUBROUTINE L1BTB2ARFS_INVDIS_SUBSET(tim, tbvl1b_cor, & cmax=c+5 ; IF (cmax > size(ref_lat)) cmax=size(ref_lat) ! IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,jj),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY IF (IBITS (tbv_qual_flag(jj,ii),qualitybit,1) == 0 .AND. IBITS (tbh_qual_flag(jj,ii),qualitybit,1) == 0) THEN !RESAMPLE ONLY WHEN BOTH V and H MEET QUALITY + k=0 ! DO rr = rmin,rmax !Lon direction ! DO cc =cmin,cmax !Lat direction From 24efbcf60e25af823270c9551580c71a9020886d Mon Sep 17 00:00:00 2001 From: Eric Kemp Date: Fri, 26 Apr 2024 14:28:51 -0400 Subject: [PATCH 328/328] Updated for Milan nodes. --- .../usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh index 954634065..e8251557a 100755 --- a/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh +++ b/ldt/utils/usaf/SMAP_E_OPL/run_smap_e_opl_discover.sh @@ -3,9 +3,9 @@ #SBATCH --time=0:20:00 #SBATCH --account s1189 #SBATCH --output smapeopl.slurm.out -#SBATCH --ntasks=13 --ntasks-per-node=13 +#SBATCH --ntasks=13 --ntasks-per-node=13 --constraint="[mil]" #SBATCH --mail-type=ALL -##SBATCH --qos=debug +#SBATCH --qos=debug #-------------------------------------------------------------------------- # # SCRIPT: run_smap_e_opl_discover.sh @@ -43,13 +43,13 @@ fi # Environment module purge unset LD_LIBRARY_PATH -module use --append /home/emkemp/privatemodules -module load lisf_7.5_intel_2021.4.0_s2s +module use --append /home/emkemp/privatemodules/sles15 +module load lisf_7.5_intel_2023.2.1 # Paths on local system -SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/scripts -BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/bin -TMPLDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/lis76_smap_e_opl_scripting/tmpl +SCRIPTDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/ldt76_smap_e_opl/scripts +BINDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/ldt76_smap_e_opl/bin +TMPLDIR=/discover/nobackup/projects/usaf_lis/emkemp/AFWA/ldt76_smap_e_opl/tmpl # Get the command line arguments to specify the training period if [ -z "$1" ] ; then